|   |   |   |   | D | I | Μ | Ε | N | S | Ι | 0 | N |   | 6 | 8 | Ø | Ø | Ø |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| S | Y | S | Т | Ε | М |   | R | Е | F | Е | R | Е | N | С | Е |   | Μ | A | N | U | A | L |
| М | i | с | r | 0 |   | С | r | a | f | t |   | С | 0 | r | р | 0 | r | a | t | i | 0 | n |

6 8 Ø - Ø Ø Ø 1 - 2 Ø Ø

PRELIMINARY

#### NOTICE

\_\_\_\_\_

Micro Craft Corporation reserves the right to make improvements in the product described in this manual at any time and without notice.

#### DISCLAIMER OF ALL WARANTIES AND LIABILITY

MICRO CRAFT CORPORATION MAKES NO WARRANTIES, EITHER EXPRESS OR IMPLIED, WITH RESPECT TO THIS MANUAL OR WITH RESPECT TO THE SOFTWARE DESCRIBED IN THIS MANUAL, ITS QUALITY, PERFORMANCE, MERCHANTIBILITY, OR FITNESS FOR ANY PARTICULAR PURPOSE. MICRO CRAFT CORPORATION SOFTWARE IS SOLD OR LICENSED "AS IS." THE ENTIRE RISK AS TO ITS QUALITY AND PERFORMANCE IS WITH THE BUYER. SHOULD THE PROGRAMS PROVE DEFECTIVE FOLLOWING THEIR PURCHASE, THE BUYER (AND NOT MICRO CRAFT COPPORATION, ITS DISTRIBUTOR, OR ITS RETAILER) ASSUMES THE ENTIRE COST OF ALL NECESSARY SERVICING, REPAIR, OR CORRECTION AND ANY INCIDENTAL OR CONSEQUENTIAL DAMAGES. IN NO EVENT WILL MICRO CRAFT CORPORATION BE LIABLE FOR DIRECT, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES RESULTING FROM ANY DEFECT IN THE SOFTWARE, EVEN IF MICRO CRAFT CORPORATION HAS BEEN ADVISED OF THE POS-SIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF IMPLIED WARRANTIES OR LIABILITY FOR INCIDENTAL OR CONSE-QUENTIAL DAMAGES, SO THE ABOVE LIMITATION OR EXCLUSION MAY NOT APPLY TO YOU.

This manual is copyrighted. All rights are reserved. This document may not, in whole or in part, be copied, photocopied, translated, or reduced to any electronic medium or machine readable form without prior consent, in writing, from Micro Craft Corporation.

Copyright 1983 by Micro Craft Corporation

Micro Craft Corporation 4747 Irving Blvd. Dallas, Texas 75247 (214) 630-2562 Additional copies of this manual may be ordered from your DEALER by using the MICRO CRAFT part number 680-0001-200.

> Ask your DEALER also for a free brochure with a complete list of a Micro Craft manuals and products

> > MICRO CRAFT CORPORATION Customer Support Department 4747 Irving Blvd. Dallas, Texas 75247

|                                                                    | _                                                                                                                                                  | TABLE OF CONTENTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pg.<br>Pg.                                                         | 1<br>3                                                                                                                                             | INTRODUCTION<br>WELCOME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.        | 10<br>10<br>10<br>10<br>10                                                                                                                         | CHAPTER 1 - OVERVIEW<br>POWER SUPPLY<br>MAIN BOARD<br>KEYBOARD<br>KEYBOARD<br>KEYBOARD INTERFACE<br>CRT<br>PROCESSOR<br>MEMORY<br>I/O<br>EXPANSION SLOTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg.<br>Pg. | 15<br>15<br>15<br>16<br>16<br>16<br>17<br>18<br>19<br>20<br>21<br>22<br>22<br>22<br>22<br>23<br>23<br>24<br>25<br>26<br>27<br>27<br>28<br>29<br>31 | CHAPTER 2 - HARDWARE<br>POWER SUPPLY<br>MAIN BOARD<br>J1 - POWER<br>J2 - RESET SWITCH ASSEMBLY<br>J3 - KEYBOARD<br>J4 - VIDEO OUTPUT<br>J5 - MINI STANDARD DISKETTE CONNECTOR (34 Pin)<br>J6 - PARALLEL PRINTER PORT<br>J7 - STANDARD DISKETTE CONNECTOR (50 Pin)<br>J8 - RS-232C INTERFACE<br>J9 - GAME CONTROL (A/D)<br>J10 - SPEAKER<br>J11 - LIGHT PEN<br>J12 - NOT USED AND NOT PHYSICALLY PRESENT<br>J13 - AUTO LINE FEED<br>J14 - AUXILIARY VIDEO<br>KEYBOARD<br>KEYBOARD<br>KEYBOARD INTERFACE<br>PRINTER OUTPUT<br>RS-232<br>REAL TIME CLOCK<br>CRT<br>SPEAKER<br>DISK DRIVES<br>MC68000<br>INTERRUPTS<br>MEMORY<br>EXPANSION SLOTS<br>CO-PROCESSORS<br>CHAPTER 3 - MEMORY ALLOCATION |
| Pg.<br>Pg.<br>Pg.                                                  | 33<br>33                                                                                                                                           | MEMORY CIRCUITRY<br>MEMORY MAP<br>USES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Pg. 37  | CHAPTER 4 - CP/M-68K, CPMBIOS, and ROMBIOS       |
|---------|--------------------------------------------------|
| Pg. 39  | FLOW                                             |
| Pg. 39  | ADDITIONAL CALLS                                 |
| Pg. 40  | FUNCTION 256 - Change DIskette Drive Format      |
| Pg. 41  | FUNCTION 257 - Read Diskette Drive Format        |
| Pg. 42  | FUNCTION 258 - Set the Physical Parameter Table, |
|         | Set the CP/M Disk Parameter Table, or            |
|         | Set the Disk Interlace Table                     |
| Pg. 43  | TERMINAL ATTRIBUTES                              |
| Pg. 43  | CONTROL FUNCTIONS                                |
| Pg. 43  | ESCAPE SEQUENCES                                 |
| Pg. 44  | ROMBIOS                                          |
| Pg. 44  | ROMBIOS FUNCTIONS                                |
| Pg. 45  | INPUT/OUTPUT                                     |
|         |                                                  |
| APPENDI | CES                                              |
| Pg. A-l | TOOL-KIT                                         |
| Pg. B-l | KEYBOARD CODES                                   |
| Pg. C-l | ASCII CODES                                      |
|         |                                                  |

- Pg. D-1EXPANSION SLOT PINOUTSPg. E-1DIRECT I/OPg. F-1ROMBIOS

# INTRODUCTION

### WELCOME TO THE DIMENSION 68000

You are now the owner of the most powerful most compatible, most flexible micro computer available in the world today. You, also, may be assured that the designers of Dimension 68000 intend that the statement above will be true for many years to come!

This manual is a tool for gaining an in-depth understanding of the operation of the DIMENSION 68000. It is NOT a tutorial. It is a collection of facts and other data. CHAPTER 1

OVERVIEW

-

The DIMENSION 68000 system is made up of several functional components or systems. Those systems are:

- The Power Supply
- The Main Board
- The Keyboard
- The CRT Interface
- The Processor (CPU)
- The Memory
- The I/O (Input/Output)
- The Expansion Slots
- The Floppy Disks and Controllers

These systems, together, handle all of the operations that are performed by the DIMENSION  $68000\,.$ 

This manual often gives directional instructions for the location, by the user, of various systems, parts, and components. In this manual, all directional instructions will refer to the orientation depicted in the view (looking down on the top) below:



The directions "Front" and "down" are towards the diskette drives and the reset switch. The directions "back" and "up" are away from the drives and toward the REAR PANEL.

To remove the top cover from the system unit of the DIMENSION 68000, use the following steps:

- TURN OFF the POWER
- TURN the system unit over (upside down)
- USING a PHILLIPS HEAD SCREWDRIVER, LOOSEN the SIX (6) SCREWS that are holding the top cover. These screws are NOT removable from the bottom cover of the system unit. The screws are designed to be held captive in the bottom cover so that they will not be lost.
- With the loosened cover still in place, TURN the system unit back over (right side up)
- LIFT off the top cover

Looking down upon the system unit (with the top cover removed), the system unit looks like the picture below.



The POWER SUPPLY

The POWER SUPPLY is enclosed in the metal cover on the right side inside the system unit. It supplies +5 VDC @ 8 A., +12 VDC @ 2.5 A., and -12 VDC @ 2 A. It is a high-frequency "switching"-type power supply.

The MAIN BOARD

The MAIN BOARD is the large printed circuit board which takes up most of the bottom of the case of the system unit. The MAIN BOARD is the actually the computer.

On the MAIN BOARD are the integrated circuits, components, and the expansion slots. The microprocessor (or "brain") of the DIMENSION 68000 is the Motorola (or equivalent) MC68000L8 device. The 68000 has an addressing capacity of 16 M Bytes. The MAIN BOARD can have up to 512 K Bytes of RAM (Random Access Memory) in 128 K Byte increments.

Also, on the MAIN BOARD are 8 K Bytes of ROM (Read Only Memory). The ROM is used to hold the system MONITOR and the ROMBIOS.

The six long peripheral slots that are toward the middle back of the MAIN BOARD can each hold a card. The cards can be any one of the following types:

- An Emulator Card (examples; Z-80, 8086, and 6512)
- A Memory Expansion Card
- A Hard Disk Controller
- A Peripheral Controller
- A Peripheral Device

The KEYBOARD System

The Keyboard system is composed of two parts; the Keyboard and the Keyboard Interface.

The Keyboard

The Keyboard unit, that plugs into the back of the DIMENSION 68000 system unit, is a microprocessor controlled assembly that is capable of handling in excess of 30 characters per second. The Keyboard assembly transmits the characters, that are typed in, to the DIMENSION 68000 system using the following characteristics:

- 30 characters/second
- 8 bit characters
- ASCII (American Standard Code for Information Interchange) encoding
- asynchronous transmission

CHAPTER 1

Page 10

#### The Keyboard Interface

The Keyboard Interface circuitry receives the characters from the Keyboard assembly. The asynchronous transmission technique adds a "start" bit and adds a "stop" bit to each character, and then transmits the character, with the added bits, in a serial mode, from the Keyboard assembly to the Keyboard Interface. The Keyboard Interface removes the added "start" and "stop" bits from each character received, and converts the character from a serial mode to a parallel mode. This is implemented using one serial channel of the Signetics 2681 Dual Universal Asynchronous Receiver/Transmitter (DUART) chip.

### The CRT Interface

The CRT Interface provides a video output signal for the connection of a CRT or other video display device. The CRT interface supplies a video signal with the following characteristics:

- RS-170 compatible signal
- Composite video (sync + video)
- Capable of COLOR and MONOCHROME operation

#### The Processor (CPU)

The Processor (or CPU - Central Processing Unit) is a Motorola MC68000 (or equivalent) microprocessor integrated circuit (or chip). The Motorola MC68000 device is internally a 32 Bit microprocessor. The MC68000 has 16 Bit wide data paths.

#### The Memory

There are two (2) types of memory in the DIMENSION 68000; RAM (Random Access Memory) and ROM (Read Only Memory). The Main Board can hold 128 K Bytes, 256 K Bytes, 384 K Bytes, or 512 K Bytes of RAM. The amount of RAM can be expanded from 512 K Bytes up to 16 M Bytes by using memory expansion cards. There are 8 K Bytes of ROM.

The I/O (Input/Output)

The I/O (Input/Output) for the DIMENSION 68000 system unit consists of the following devices:

- The Keyboard Interface
- The CRT Interface
- The Diskette Drives
- The Parallel Printer Port
- The RS-232C Interface
- The Game Control Interface

Optionally, there can be connectors on the rear panel to connect the following:

- Additional Mini (5 1/4", 3 1/2", 3 1/4", etc.) Diskette Drives - Additional 8 Inch (Full Size) Diskette Drives (up to four total)

The Expansion Slots

There are six (6) Expansion Slots inside the system unit. The Expansion Slots provide the capability to plug in various types of cards. Some of the types of cards are:

- Emulator Card(s)
- Hard Disk Interface Card
- RS-232 Ports Card(s) 8 ports per card
- Analog/Digital Interface Card(s)
   512 K Byte RAM Memory Cards

It is expected that, in the future, Micro Craft Corporation and other manufacturers will be providing many types of cards to plug into the Expansion Slots.

## CHAPTER 1

SYSTEM REFERENCE MANUAL

### CHAPTER 2

HARDWARE

- 1

The POWER SUPPLY

The POWER SUPPLY for the DIMENSION 68000 is a high-frequency "switching"-type unit. It supplies the following voltages and currents:

+5 VDC +,- 1% @ 8 Amps +12 VDC +,- 5% @ 2.5 Amps -12 VDC +,- 5% @ 2 Amps

These voltages are supplied to the MAIN BOARD and to the Disk Drives. Power supplied to the MAIN BOARD is available to the Expansion Slots, and to the Game Control connector (J9) on the MAIN BOARD.

The POWER SUPPLY requires 115 VAC @ 3 Amps (MAX.) to operate. The POWER SUPPLY for the DIMENSION 68000, optionally, may be configured to operate from 220 VAC power. The POWER SUPPLY input power, whether 115 VAC or 220 VAC, must be of a frequency in the range of from 50 Hz. to 400 Hz. The input power to the POWER SUPPLY is filtered for RFI (Radio Frequency Interference). The input power to the POWER SUPPLY also has power line surge suppression applied.

The MAIN BOARD

The MAIN BOARD has the Expansion Slots, the integrated circuits (including the 68000 microprocessor), the components, and the connectors that link the MAIN BOARD to the POWER SUPPLY, the Keyboard, etc. The connectors on the MAIN BOARD are detailed below.

J1 - POWER

MAIN BOARD

| 456          | PIN | USAGE   | The Connector Necessary      |
|--------------|-----|---------|------------------------------|
|              |     |         | to Mate With the Connector   |
| /            | 1   | +5 VDC  | on the MAIN BOARD is made    |
| 000          | 2   | GROUND  | using a MOLEX P/N Ø3-Ø9-1Ø64 |
| 1            | 3   | +12 VDC | recepticle and MOLEX         |
|              | 4   | +5 VDC  | P/N 02-09-1118 pins          |
|              | 5   | GROUND  | (or the equivalent).         |
| ++           | 6   | -12 VDC |                              |
| 123          |     |         |                              |
| Top View of  |     |         |                              |
| Connector on |     |         |                              |



| ++    | +       | PIN      | USAGE     | The      |
|-------|---------|----------|-----------|----------|
| 11    |         |          |           | to       |
| 0     | 1       | 1        | RESET     | on       |
| 11    |         | 2        | GROUND    | P/N      |
| 10    | 2       | 3        | NORMAL    | equ      |
| 11    | 1       | 4        | LED POWER | <b>1</b> |
| 1 0   | 3       |          |           |          |
|       |         |          |           |          |
| 0     | 4       |          |           |          |
|       | -       |          |           |          |
|       |         |          |           |          |
| ++=== | т<br>1  |          |           |          |
|       | iew of  | The PAIN |           |          |
|       | ctor on | indicate | ès        |          |
| MAIN  | BOARD   | pin l.   |           |          |
|       |         |          |           |          |

5

The Connector Necessary to Mate With the Connector on the MAIN BOARD is a MOLEX P/N 22-26-9041 (or the equivalent).

J3 - KEYBOARD



PIN USAGE --- ----1 SIGNAL FROM KEYBOARD 2 3 4 GROUND

+5 VDC POWER

TO KEYBOARD

The Connector Necessary to Mate With the Connector at rear of SYSTEM UNIT is a 5 PIN, "DIN"-type, MALE

View of Front of Connector at rear of SYSTEM UNIT

#### J4 - VIDEO OUTPUT

|   | PIN     | USAGE  | The Connector Necessary    |
|---|---------|--------|----------------------------|
|   |         |        | to Mate With the Connector |
| 0 | Center  | SIGNAL | on the REAR PANEL is an    |
|   | Outside | GROUND | RCA type MALE              |

## J5 - MINI STANDARD DISKETTE CONNECTOR (34 Pin)

| ++             | PIN | USAGE      | The Connector Necessary    |
|----------------|-----|------------|----------------------------|
| [++]           |     |            | to Mate With the Connector |
| 0 0  ]         | 1   | GROUND     | on the MAIN BOARD is an    |
| 0 0            | 2   |            | ANSLEY P/N 609-34000 (or   |
| 0 0            | 3   | GROUND     | the equivalent)            |
| 0 0            | 4   |            | <b>_</b> ,                 |
| 0 0            | 5   | GROUND     |                            |
| 00             | 6   | DRSEL 3 *  | NOTE: An * after a signal  |
| 0 0 ++         | 7   | GROUND     | name indicates that        |
|                | 8   | INDEX*     | the logic for that         |
| 00             | 9   | GROUND     | signal is inverted,        |
|                | 10  | DRSEL Ø *  | that is to say that        |
| 0 0 ++         | 11  | GROUND     | the signal is active       |
| 0 0            | 12  | DRSEL 1 *  | on a "Ø" instead of        |
| 0 0            | 13  | GROUND     | a "1".                     |
| 0 0 0          | 14  | DRSEL 2 *  |                            |
| 0 0            | 15  | GROUND     |                            |
| 00             | 16  |            |                            |
| 00 01          | 17  | GROUND     |                            |
| ++             | 18  | M DIR *    |                            |
| ++             | 19  | GROUND     |                            |
| View of the    | 2Ø  | M STEP *   |                            |
| Connector on   | 21  | GROUND     |                            |
| the MAIN BOARD | 22  | M W DATA * |                            |
|                | 23  | GROUND     |                            |
| The PAINT DOT  | 24  | WR ENA *   |                            |
| indicates      | 25  | GROUND     |                            |
| pin l          | 26  |            |                            |
| -              | 27  | GROUND     |                            |
|                | 28  |            |                            |
|                | 29  | GROUND     |                            |
|                | ЗØ  | RD DATA    |                            |
|                | 31  | GROUND     |                            |
|                | 32  | M HEAD *   |                            |
|                | 33  | GROUND     |                            |
|                | 34  |            |                            |
|                |     |            |                            |

## J6 - PARALLEL PRINTER PORT



| PIN                   | USAGE                          |
|-----------------------|--------------------------------|
| 1                     | STROBE*                        |
|                       | DØ*                            |
| 2<br>3<br>4<br>5<br>6 | DI*                            |
| 4                     | D2*                            |
| 5                     | D3*                            |
| 6                     | D4*                            |
| 7                     | D5*                            |
| 8                     | D <b>6*</b>                    |
| 9                     | D <b>7</b> *                   |
| 10                    | ACKNLG*                        |
| 11                    | RDY*                           |
| 12                    | Not Connected<br>Not Connected |
| 13                    | Not Connected                  |
| 14                    | AUTO LINE FEED                 |
| 15                    | Not Connected                  |
| 16                    | Not Connected                  |
| 17                    | GROUND                         |
| 18                    | Not Connected                  |
| 19                    | GROUND                         |
| 2Ø                    | GROUND                         |
| 21                    | GROUND                         |
| 22                    | GROUND                         |
| 23                    | GROUND                         |
| 24                    | GROUND                         |
| 25                    | GROUND                         |
| 26                    | GROUND                         |
| 27                    | GROUND                         |
| 28                    | GROUND                         |
| 29                    | GROUND                         |
| 30                    | GROUND                         |
| 31                    | INIT*                          |
| 32                    | Not Connected                  |
| 33<br>34              | GROUND                         |
| 34<br>35              | Not Connected<br>Not Connected |
| 35                    | Not Connected                  |
| 20                    | Not Connected                  |

\*

The Connector Necessary to Mate With the Connector on the REAR PANEL is an Amphenol 36 Pin "Blue Ribbon" type

NOTE: An \* after the signal name indicates that the logic for that signal is inverted, that is to say that the signal is active on a "0" instead of a "1".

## J7 - STANDARD DISKETTE CONNECTOR (50 Pin)

|                                                            | PIN<br>1<br>2<br>3<br>4<br>5                                                                             | USAGE<br><br>GROUND<br>M LOW C *<br>GROUND<br>MOTOR OFF Ø *<br>GROUND                                                                                                     | The Connector Necessary<br>to Mate With the Connector<br>on the MAIN BOARD is an<br>ANSLEY P/N 609-5000 (or<br>the equivalent)                                                |
|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 0<br>0 0<br>0 0<br>0 0<br>0 0<br>0 0<br>++<br>0 0<br>0 0 | 6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16                                               | MOTOR OFF 1 *<br>GROUND<br>MOTOR OFF 2 *<br>GROUND<br>2 SIDED *<br>GROUND<br>GROUND<br>M HEAD *<br>GROUND                                                                 | NOTE: An * after a signal<br>name indicates that<br>the logic for that<br>signal is inverted,<br>that is to say that<br>the signal is active<br>on a "0" instead of<br>a "1". |
|                                                            | 17<br>18<br>19<br>20<br>21<br>22<br>23<br>24<br>25<br>26                                                 | GROUND<br>M HEAD LD *<br>GROUND<br>INDEX *<br>GROUND<br>MOTOR OFF 3 *<br>GROUND<br>DR SEL Ø *                                                                             |                                                                                                                                                                               |
| ++<br>View of the<br>Connector on<br>the MAIN BOARD        | 27<br>28<br>29<br>30<br>31<br>32                                                                         | GROUND<br>DR SEL 1 *<br>GROUND<br>DR SEL 2 *<br>GROUND<br>DR SEL 3 *                                                                                                      |                                                                                                                                                                               |
| The PAINT DOT<br>indicates<br>pin 1                        | 33<br>34<br>35<br>36<br>37<br>38<br>39<br>40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>50 | GROUND<br>M DIR *<br>GROUND<br>M STEP *<br>GROUND<br>M W DATA *<br>GROUND<br>WR ENA *<br>GROUND<br>TK ØØ *<br>GROUND<br>W PROT *<br>GROUND<br>RD DATA<br>GROUND<br>GROUND |                                                                                                                                                                               |

## J8 - RS-232C INTERFACE

| 1  |      | PIN<br>1<br>2<br>3<br>4<br>5<br>6 | USAGE<br>GROUND<br>XMIT DATA<br>RECV DATA<br>"MARK"<br>NOT USED | The Connector Necessary<br>to Mate With the Connector<br>on the REAR PANEL is a<br>25 PIN, "D Subminiature"<br>type MALE (DB25P) |
|----|------|-----------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
|    | 0    | 7                                 | NOT USED<br>GROUND                                              | NOTE: "MARK" indicates a<br>high logic signal                                                                                    |
|    | 0    | 8                                 | DCD                                                             | (+12 VDC)                                                                                                                        |
|    | 0    | 8<br>9<br>1Ø                      |                                                                 |                                                                                                                                  |
|    | 0    | 10                                |                                                                 |                                                                                                                                  |
|    | 0    | 11                                |                                                                 |                                                                                                                                  |
|    | 0    | 12                                |                                                                 |                                                                                                                                  |
|    | 0    | 13                                |                                                                 |                                                                                                                                  |
|    | 0    | 14                                |                                                                 |                                                                                                                                  |
|    | 0    | 15                                |                                                                 |                                                                                                                                  |
|    | 0    | 16                                |                                                                 |                                                                                                                                  |
|    | 0    | 17                                |                                                                 |                                                                                                                                  |
|    | 0    | 18                                |                                                                 |                                                                                                                                  |
|    | 0    | 19                                |                                                                 |                                                                                                                                  |
|    | 0    | 2Ø                                | "MARK"                                                          |                                                                                                                                  |
|    | 0    | 21                                |                                                                 |                                                                                                                                  |
|    | 0    | 22                                |                                                                 |                                                                                                                                  |
|    | 0/25 | 23                                |                                                                 |                                                                                                                                  |
| 13 | 0/   | 24                                |                                                                 |                                                                                                                                  |
|    | /    | 25                                |                                                                 |                                                                                                                                  |

View of Connector on REAR PANEL J9 - GAME CONTROL (A/D)

| 1    |                | PIN | USAGE         | The Connector Necessary<br>to Mate With the Connector |
|------|----------------|-----|---------------|-------------------------------------------------------|
| _    | 0 \ 9          | 1   | +5 VDC        | on the REAR PANEL is a                                |
|      | 0              | 2   | SW l (Bit Ø)  | 15 PIN, "D Subminiature"                              |
|      | 0              | 3   | POT 1 (Bit 4) | type MALE (DB15P)                                     |
|      | 0              | 4   | GROUND        |                                                       |
|      | 0              | 5   | GROUND        |                                                       |
|      | 0              | 6   | POT 2 (Bit 5) |                                                       |
|      | 0              | 7   | SW 2 (Bit 1)  |                                                       |
|      | 0              | 8   | +5 VDC        |                                                       |
|      | 0              | 9   | +5 VDC        |                                                       |
| 1    | 0              | 10  | SW 3 (Bit 2)  |                                                       |
|      | 0              | 11  | POT 3 (Bit 6) |                                                       |
|      | 0              | 12  | GROUND        |                                                       |
|      | o / 15         | 13  | POT 4 (Bit 7) |                                                       |
| 8    | 0/             | 14  | SW 4 (Bit 3)  |                                                       |
|      |                | 15  | +5 VDC        |                                                       |
| View | w of Connector |     |               |                                                       |
| on I | REAR PANEL     |     |               |                                                       |

,

J1Ø - SPEAKER

-

| +++               |     |   | PIN | USAGE         | The Connector Necessary      |  |  |
|-------------------|-----|---|-----|---------------|------------------------------|--|--|
|                   |     |   |     |               | to Mate With the Connector   |  |  |
| 0                 |     | 1 | 1   | +5 VDC        | on the MAIN BOARD is a MOLEX |  |  |
| 1                 | 11  |   | 2   | SIGNAL        | P/N 22-26-9021 (or the       |  |  |
| 0                 |     | 2 |     |               | equivalent).                 |  |  |
| +                 | -++ |   |     |               |                              |  |  |
| View of Connector |     |   | The | PAINT DOT     |                              |  |  |
| on MAIN BOARD     |     |   | ind | licates pin l |                              |  |  |

The Connector Necessary to Mate With the Connector on the MAIN BOARD is a MOLEX P/N 22-26-9041 (or the

equivalent).

-

| J11 | - | LIGHT | PEN |
|-----|---|-------|-----|
| JTT | - | LIGHT | PLN |

| +                               | + | ŧ | PIN       | USAGE         |  |
|---------------------------------|---|---|-----------|---------------|--|
|                                 |   | _ |           |               |  |
|                                 | 0 | 1 | 1         | RESET         |  |
|                                 |   |   | 2         | GROUND        |  |
|                                 | 0 | 2 | 3         | NORMAL        |  |
|                                 | 0 | 3 | 4         | LED POWER     |  |
|                                 |   | 5 |           |               |  |
|                                 | 0 | 4 |           |               |  |
|                                 |   | - |           |               |  |
| +++                             |   |   |           |               |  |
| View of Connector The PAINT DOT |   |   | PAINT DOT |               |  |
| on MAIN BOARD                   |   |   | ind       | licates pin l |  |

J12 - NOT USED AND NOT PHYSICALLY PRESENT

J13 - AUTO LINE FEED

-

| ++   | -+        | PIN     | USAGE          | The Connector Necessary      |
|------|-----------|---------|----------------|------------------------------|
|      |           |         |                | to Mate With the Connector   |
| 0    | 1         | 1       | LOGIC "1"      | on the MAIN BOARD is a MOLEX |
|      | }         |         | (+5 VDC BFFRD) | P/N 22-26-9031 (or the       |
| 0    | 2         | 2       | CONTROL LINE   | equivalent).                 |
|      |           | 3       | GROUND         |                              |
| 0    | 3         |         | (LOGIC "Ø")    |                              |
|      | (         |         |                |                              |
| ++   | -+        |         |                |                              |
| View | of Connec | tor The | PAINT DOT      |                              |

| view or | Connector | THE PAINT | DOT   |
|---------|-----------|-----------|-------|
| on MAIN | BOARD     | indicates | pin l |

J14 - AUXILIARY VIDEO

|     | -          |              |     |                 |                              |
|-----|------------|--------------|-----|-----------------|------------------------------|
| +   | • <b>+</b> | +            | PIN | USAGE           | The Connector Necessary      |
|     |            | J            |     |                 | to Mate With the Connector   |
|     | 0          | 1            | 1   | +5 VDC          | on the MAIN BOARD is a MOLEX |
| - 1 | 1          |              | 2   | SIGNAL          | P/N 22-26-9031 (or the       |
|     | 0          | 2            |     | (Signal is      | equivalent).                 |
| - 1 |            |              |     | NOT Adjustable) |                              |
|     | 0          | 3            | 3   | GROUND          |                              |
|     |            |              |     |                 |                              |
| +   | ++         | +            |     |                 |                              |
| v   | 'iew d     | of Connector | Th  | e PAINT DOT     |                              |
| c   | n MAI      | IN BOARD     | in  | dicates pin l   |                              |

A schematic of the MAIN BOARD is included in the APPENDICES.

The KEYBOARD System

The Keyboard system is composed of two parts; the Keyboard and the Keyboard Interface.

The Keyboard

The Keyboard is a microprocessor controlled assembly that is capable of handling in excess of 30 characters per second. The Keyboard transmits characters to the DIMENSION 68000 system using the following character-istics:

- 30 characters/second
- 8 bit characters
- ASCII (American Standard Code for Information Interchange) encoding

e

- asynchronous transmission
- Power required = +5 VDC at 250 mA.
- Rollover = 2 key
- Special Keys =

The Keyboard Interface

The Keyboard Interface receives the characters from the Keyboard assembly. The asynchronous transmission that is used between the Keyboard and the Keyboard Interface adds a "start" bit and a "stop" bit to each character. The Keyboard Interface removes the added "start" and "stop" bits from each character received.

Memory Mapped Locations
 FFC401 = Keyboard Mode Register
 FFC403 = Keyboard Status
 FFC405 = Keyboard Interface Command Register
 FFC407 = Keyboard Data
 FFC409 = Auxilliary Command Register

A list of the keys, on the keyboard, and the codes that each key generates is included in the KEYBOARD CODES APPENDIX. Also, a detailed description of the keyboard and the keyboard interface is included in the DIRECT I/O APPENDIX.

The Keyboard Interface, the Printer, the RS-232C Interface, and the Real Time Clock are all handled by a Signetics (or equivalent) 2681 type Dual Universal Asynchronous Receiver / Transmitter (DUART) integrated circuit (chip).

SYSTEM REFERENCE MANUAL

#### The PRINTER OUTPUT

The PRINTER OUTPUT is handled through the DUART chip that is described above. The PRINTER OUTPUT is unusual in that the user writes the character to be printed to the SET OUTPUT Register, and then writes the character to the RESET OUTPUT Register.

Memory Mapped Locations
 FFC41B = Printer Port Configuration Register
 FFC41B = Printer Port Status
 FFC41D = Printer Port Data SET Register
 FFC41F = Printer Port Data RESET Register

The AUTO LINE FEED \* signal is strappable for either enabling the auto line feed function or disabling it. This strapping is done at J13 on the MAIN BOARD. The strapping options for J13 are discussed above under the topic MAIN BOARD.

A detailed discussion of the printer port is contained in the DIRECT I/O APPENDIX.

The RS-232 Interface

The RS-232C Interface is handled through the DUART chip that is described above. The RS-232 Interface is capable of handling bit-per-second rates of from 75 BPS to 19.2 KBPS. (It is not proper to speak of Baud rate on an RS-232 Interface. Baud rate is properly defined as the number of signalling changes per second on a telephone or telegraph communications line. Baud rate is normally considered to be the signalling changes per second between modems. Baud rate and bit rate are not always the same.)

- Memory Mapped Locations

FFC409 = Auxilliary Control Register FFC40B = Interrupt Mask Register FFC411 = Mode Registers (1 and 2) FFC413 = Clock Select Register FFC413 = Status Register FFC415 = Command Register FFC417 = Output Data Register FFC417 = Input Data Register FFC418 = Input Port for DCD

A detailed discussion of the RS-232C interface is contained in the DI-RECT I/O APPENDIX. The REAL TIME CLOCK

The REAL TIME CLOCK is handled through the DUART chip that is described above. Neither the ROMBIOS nor the CP/M BIOS use interrupts, and therefore they do not use the REAL TIME CLOCK.

- Memory Mapped Locations
FFC409 = Auxilliary Control Register
FFC409 = Input Port Change Register
FFC40B = Interrupt Mask Register
FFC40B = Interrupt Status Register
FFC40D = Counter/Timer Upper Register (Most Significant Byte)
FFC40F = Counter/Timer Lower Register (Least Significant Byte)

A detailed discussion of the REAL TIME CLOCK is contained in the DIRECT I/O APPENDIX.

The CRT Interface

The CRT Interface provides a video output signal to connect a CRT or other video display device. The CRT interface supplies a video signal with the following characteristics:

- EIA RS-170 compatible signal
- (EIA = Electronic Industries Association)
- NTSC Positive Composite Color Video
- (NTSC = National Television Standards Committee)
- Capable of COLOR and MONOCHROME operation
- Adjustable output level (Ø to 1 Volt Pk to Pk)

The tint of the color signal is adjustable by means of a trimmer capacitor that is located on the MAIN BOARD. Also, there is potentiometer that is used to adjust the level of the output signal that is routed to the main video connector on the rear panel.

On the MAIN BOARD is an auxiliary video connector which is described above. The signal available on the auxiliary video connector is an NTSC compatible positive video signal. The black level is about 0.75 Volts, the white level is about 2.0 Volts, and the sync tip level is 0 Volts. The output level is NOT adjustable, and the output is NOT protected against short circuits.

- Memory Mapped Locations

FF8001 = CRT Controller Register Address Selection Register
FF8003 = CRT Controller Addressed Register Data
FF8005 = Display Buffer Address High Byte
FF8009 = CRT Display Write Mode Register
FF800A = Reset CRT Controller

A detailed description of the CRT Interface is included in the DIRECT I/O APPENDIX.

#### The SPEAKER

The SPEAKER is inside the case of the system unit. It is driven by half of a 74LS74 flip-flop through a Darlington amplifier circuit. The SPEAKER connection is described above. The SPEAKER used is a one. It is an 8 ohm unit.

The SPEAKER is controlled by a soft switch. The switch can put the cone of the SPEAKER into the "in" position or the "out" position. This switch operates in the same fashion as a TOGGLE switch. Each time a program references the memory address associated with the SPEAKER switch, the speaker will change state: move from "in" to "out" or from "out" to "in". Each time the state of the SPEAKER is changed, a tiny "click" is produced. By referencing the address of the SPEAKER switch very frequently and continuously, a program can cause the generation of a steady tone from the speaker. A program can reference the address of the SPEAKER switch by performing either a "read" or a "write" to that address.

- Memory Mapped Locations FFC800 = Speaker Toggle Address

The SPEAKER is also described in the DIRECT I/O APPENDIX.

The DISK DRIVES

The DISK DRIVES that are standard on the DIMENSION 68000 are half height, 5 1/4 inch, double-sided, double-density, half-steppable, 40 track diskette drives. They are capable of storing up to 400 KBytes of data.

Optionally available, are 80 track diskette units that are capable of storing up to 800 KBytes. As well as 8 inch diskette drives, 3 1/2 inch diskette drives, and 3 1/4 inch diskette drives.

The controller for the diskettes is the NEC uPD765A integrated circuit.

- Memory Mapped Locations FFDØØ1 = Diskette Controller Status FFDØØ3 = Data Register FFDØØ5 = Control Register

Further information is available in the PINOUT APPENDIX and the DIRECT I/O APPENDIX. A detailed description of the controller is available in the NEC DATA SHEET for the uPD765A.

The MC68000

The MC68000 microprocessor used in the DIMENSION 68000 is an 8 MHz. device. It has 16 bit wide data paths (but all of the internal architecture is 32 bits wide). The 68000 chip has the following registers:

8 DATA REGISTERS that are 32 bits wide 7 ADDRESS REGISTERS that are 32 bits wide 1 USER STACK POINTER that is 32 bits wide 1 SUPERVISOR STACK POINTER that is 32 bits wide 1 PROGRAM COUNTER that is 32 bits wide 1 STATUS REGISTER that is 16 bits wide

The 68000 allows 5 data types:

Bits BCD Digits (4 bits/BCD Digit - 1 BCD DIGIT = 1 Nybble) Bytes (8 bits) Words (16 bits) Long Words (32 bits)

The 68000 has the capability of directly addressing 16 MBytes of memory. There are 14 addressing modes on 61 basic instructions for over 1000 total instruction types.

For a detailed discussion of the 68000 microprocessor, see the MOTOROLA MC68000 USER'S MANUAL.

INTERRUPTS

The DIMENSION 68000 comes with six maskable levels of interrupts and one non-maskable interrupt level. The maskable interrupt levels are levels 1, 2, 3, 4, 5, and 6. The non-maskable interrupt level is level 7. Level 1 is the lowest priority and level 7 is the highest priority. The DUART (which is described above) is set by the hardware circuitry to be the non-maskable interrupt on priority level 7. The DUART has the capability to mask for interrupts the Keyboard, the RS-232, the Printer, and the Real Time Clock. All of the interrupts on the DIMENSION 68000 utilize the Autovector type of interrupt processing.

The Autovector processing computes the interrupt vector number (in hex) by the following formula:

VECTOR NUMBER = (PRIORITY-LEVEL +  $\emptyset$ 24)

The above formula gives the interrupt vector number in hexadecimal. The Autovector processing computes the location of the interrupt vector (in hex) by the following formula:

VECTOR LOCATION = VECTOR NUMBER \* 4

SYSTEM REFERENCE MANUAL

The location of the vector address contains the address of an interrupt routine. The following chart shows the assignments for priority level, vector number, and vector address for the DIMENSION 68000.

| DEVICE | PRIORITY<br>LEVEL<br>(decimal) | VECTOR<br>NUMBER<br>(decimal) | LOCATION OF<br>VECTOR ADDRESS<br>(hex) |
|--------|--------------------------------|-------------------------------|----------------------------------------|
|        |                                |                               |                                        |
| SLOT 6 | 1                              | 25                            | Ø64                                    |
| SLOT 5 | 2                              | 26                            | Ø68                                    |
| SLOT 4 | 3                              | 27                            | Ø6C                                    |
| SLOT 3 | 4                              | 28                            | Ø7Ø                                    |
| SLOT 2 | 5                              | 29                            | Ø74                                    |
| SLOT 1 | 6                              | 30                            | Ø78                                    |
| DUART  | 7                              | 31                            | Ø7C                                    |

. . . . . . . .

Additionally, there are exception vectors. Vectors Ø and 1 are taken as a pair and not as two separate vectors. The following chart shows the assignments for the vector number, the vector address, and its usage.

| VECTOR<br>NUMBER<br>(decimal)           | VECTOR<br>ADDRESS<br>(hex) | ASSIGNMENT                              | USED BY |
|-----------------------------------------|----------------------------|-----------------------------------------|---------|
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |                            |                                         |         |
| Ø                                       | ØØØ                        | Reset: Initial Supervisor Stack Pointer | BOOT    |
|                                         | ØØ4                        | Reset: Initial Program Counter          |         |
| 2                                       | ØØ8                        | Bus Error                               | CP/M    |
| 3                                       | ØØC                        | Address Error                           | CP/M    |
| 4                                       | Ø1Ø                        | Illegal Instruction                     | CP/M    |
| 5                                       | Ø14                        | Zero Divide                             | CP/M    |
| 6                                       | Ø18                        | CHK Instruction                         | CP/M    |
| 7                                       | ØlC                        | TRAPV Instruction                       | CP/M    |
| 8                                       | Ø2Ø                        | Privelege Violation                     | CP/M    |
| 9                                       | Ø24                        | Trace                                   | CP/M    |
| 10                                      | Ø28                        | Line 1010 Emulator                      | CP/M    |
| 11                                      | Ø2C                        | Line llll Emulator                      | CP/M    |
| 12 - 24                                 | 030-060                    | NOT USED                                | NO USER |
| 32 - 255                                | Ø80-3FF                    | NOT USED                                | NO USER |
|                                         |                            |                                         |         |

#### MEMORY

The DIMENSION 68000 memory is byte addressable. Each memory address has associated with it an additional bit that is used for emulation trapping. If a memory address is accessed, and the emulation trap bit is on, then the emulation strobe bit, on the bus and at the slots, is toggled.

The DIMENSION 68000 can address up to 16 MBytes of memory. This is made possible by the use of a 24 Bit wide address.

The DIMENSION 68000 memory has, in its associated circuitry, bus arbitration logic. The bus arbitration priorities are:

| HIGHEST | CRT CONTROLLER | R CIRCUITRY |
|---------|----------------|-------------|
|         | EXPANSION SLOT | r 6         |
|         | EXPANSION SLOT | r 5         |
|         | EXPANSION SLOT | r 4         |
|         | EXPANSION SLOT | r 3         |
|         | EXPANSION SLOT | r 2         |
|         | EXPANSION SLOT | r 1         |
| LOWEST  | MC68000 CPU    |             |

#### EXPANSION SLOTS

Each EXPANSION SLOTS can accept a plug in card. Each slot directly connects to the system's bus. A detailed discussion of the connections for the EXPANSION SLOTS is contained in the EXPANSION SLOT PINOUT APPENDIX.

Each EXPANSION SLOT has four signals that are unique to that slot. They are:

| - | BOARD | ENABLE      | FROM | SYSTEM |
|---|-------|-------------|------|--------|
| - | BOARD | REQUEST     | то   | SYSTEM |
| - | BOARD | ACKNOWLEDGE | FROM | SYSTEM |
| - | BOARD | INTERRUPT   | то   | SYSTEM |

The Micro Craft Corporation supplies an expansion slot board prototyping kit. This kit contains a prototyping board, a set of expansion slot board drawings, data regarding the signals available on the expansion slot connector, and data about the DIMENSION 68000 system circuitry.

### CO-PROCESSORS

The DIMENSION 68000 has been designed to allow the simultaneous use of more than one processor. All of the emulator cards have a microprocessor chip on them. This makes all of the emulator cards, co-processors. Some other possible co-processor uses are: - an array processor

- a mathematical floating point processor
- a mathematical multiply and divide processor
- a specific machine emulator
- an intelligent device controller

СНАРТЕК З

MEMORY ALLOCATION

#### MEMORY CIRCUITRY

The MEMORY CIRCUITRY contains bus arbitration logic circuitry and emulation trapping circuitry. The bus arbitration logic circuitry is designed to give to the CRT Controller circuitry the highest priority. The next highest priority to EXPANSION SLOT 6, then, EXPANSION SLOTS 5, 4, 3, 2, and 1. The lowest priority is the MC68000 CPU.

The emulation trapping circuitry for the memory is implemented by including in the memory design an additional bit with each byte of memory. The additional bit is used as an emulation trapping flag. If the bit is on for a specific byte, and that byte is accessed, then the emulation circuitry causes the emulation strobe bit in the system bus to be pulsed. This does NOT hold true for accesses by the CRT Controller circuitry, NOR does it hold true for accesses by the MC68000 CPU.

#### MEMORY MAP

The DIMENSION 68000 memory contains both Read Only Memory (ROM) and Random Access Memory (RAM). The system memory is allocated as follows.

| ADDRESS             | FUNCTION                                            |
|---------------------|-----------------------------------------------------|
|                     |                                                     |
| ************ INTERR | UPT VECTORS ************************************    |
| ØØØØØØ              | RESET - Initial Stack Pointer                       |
| 000004              | RESET - Initial Program Counter (PC)                |
| 000008              | BUS ERROR                                           |
| ØØØØØC              | ADDRESS ERROR                                       |
| 000010              | ILLEGAL INSTRUCTION                                 |
| 000014              | DIVIDE BY Ø                                         |
| 000018              | CHECK INSTRUCTION                                   |
| ØØØØ1C              | TRAPV INSTRUCTION                                   |
| ØØØØ2Ø              | PRIVILEGE INSTRUCTION                               |
| 000024              | TRACE                                               |
| 000028              | OPCODE 1010 EMULATION                               |
| ØØØØ2C              | OPCODE 1111 EMULATION                               |
| 000030 - 00005F     | Reserved                                            |
| 000060              | SPURIOUS INTERRUPT                                  |
| 000064              | LEVEL 1 INTERRUPT                                   |
| 000068              | LEVEL 2 INTERRUPT                                   |
| ØØØØ6C              | LEVEL 3 INTERRUPT                                   |
| 000070              | LEVEL 4 INTERRUPT                                   |
| 000074              | LEVEL 5 INTERRUPT                                   |
| 000078              | LEVEL 6 INTERRUPT                                   |
| ØØØØ7C              | LEVEL 7 INTERRUPT - DUART - Keyboard, Printer, etc. |
| 000080 - 0000BF     | TRAP VECTORS                                        |
| 0000C0 - 0000FF     | Reserved                                            |

| ADDRESS                            | FUNCTION                                                      |
|------------------------------------|---------------------------------------------------------------|
| ****                               | HERAL CONTROLLER BOOT RAM *********************************** |
| ØØØ1ØØ - ØØØ113                    | CONTROLLER 1                                                  |
| 000114 - 000127                    | CONTROLLER 2                                                  |
| ØØØ128 - ØØØ13B                    | CONTROLLER 3                                                  |
| ØØØ128 - ØØØ13B<br>ØØØ13C - ØØØ14F |                                                               |
|                                    | CONTROLLER 4                                                  |
| ØØØ15Ø - ØØØ163                    | CONTROLLER 5                                                  |
| 000164 - 000177                    | CONTROLLER 6                                                  |
|                                    | VED PERIPHERAL RAM ***********************************        |
| ØØØ178 - ØØØ19B                    | MONITOR RESERVED LOCATIONS                                    |
| ØØØ19C                             | TOP OF RAM                                                    |
| 0001A0 - 0001A7                    | ADDRESS of ROM BASED RESET VECTOR                             |
| 0001A8 - 0001CB                    | CRT PARAMETER TABLE                                           |
| ØØØ1CC - ØØØ1E5                    | BOOT DISK PARAMETER TABLE                                     |
| ØØØ1E6 - ØØØ1E9                    | SYSTEM CONFIGURATION WORD                                     |
| ØØØ1EA - ØØØ1ED                    | ADDRESS OF TEXT SCREEN TABLE                                  |
| ØØØ1EE - ØØØ1F1                    | ADDRESS OF KEYBOARD TABLE                                     |
| ØØØ1F2 - ØØØ1F5                    | ADDRESS of GRAPHICS CHARACTER SET #1 TABLE                    |
| ØØØ1F6 - ØØØ1F9                    | ADDRESS of GRAPHICS CHARACTER SET #2 TABLE                    |
| ØØØ1FA - ØØØ1FD                    | ADDRESS OF PRESENT SCREEN TABLE                               |
| ØØØlFE                             | INTERRUPT MASK FOR 2861 I/O CHIP                              |
| ØØØlFF                             | END OF RESERVED PERIPHERAL RAM                                |
|                                    | RAM AREA **********************************                   |
| ØØØ2ØØ - ØØ119F                    | NORMAL (80 x 50) SCREEN TEXT AREA                             |
| ØØ12ØØ - Ø1FFFF                    | MINIMUM SYSTEM USER RAM                                       |
| 001300                             | Start of CP/M-68K TRANSIENT PROGRAM AREA                      |
| Ø10000 - Ø1FFFF                    | Co-Processor RAM Area, During Emulation (Min)                 |
| Ø10000 - 07FFFF                    | Co-Processor RAM Area, During Emulation (Max)                 |
| Ø20000 - FEFFFF                    | Expanded User RAM Area                                        |
|                                    | VED AREAS ************************************                |
| FFØØØØ - FF1FFF                    | Basic Processor ROM Area (ROMBIOS and MONITOR)                |
| FF2000 - FF7FFF                    | Reserved Area (Graphics RAM)                                  |
|                                    | /OUTPUT REGION ************************************           |
| FF8000 - FF87FF<br>FF8800 - FF8FFF | slot 1                                                        |
|                                    |                                                               |
| FF9000 - FF97FF<br>FF9800 - FF9FFF | Slot 2                                                        |
| FFAØØØ - FFA7FF                    | Slot 3<br>Slot 4                                              |
|                                    | Slot 5                                                        |
| FFA8ØØ - FFAFFF<br>FFBØØØ - FFB7FF | Slot 6                                                        |
|                                    |                                                               |
| FFB8ØØ – FFBFFF                    | Reserved<br>Reserved                                          |
| FFCØØØ - FFC3FF                    |                                                               |
| FFC400 - FFC7FF                    | Keyboard/Printer/Modem/Real Time Clock                        |
| FFC800 - FFCBFF                    | Speaker                                                       |
| FFCCØØ - FFCFFF                    | Game Control                                                  |
| FFDØØØ - FFD3FF                    | Floppy Disk<br>Emulation Controllor                           |
| FFD400 - FFD7FF                    | Emulation Controller                                          |
| FFD8ØØ - FFDBFF                    | Reserved                                                      |
| FFDCØØ - FFDDFF                    | ROM Toggle                                                    |
| FFDEØØ - FFDFFF                    | Reserved                                                      |
| FFEØØØ - FFFFFF                    | Reserved                                                      |

#### USES

The USES for the DIMENSION 68000 system memory are described by the above memory map. Some of the descriptions will be further amplified here.

The area from FFØØØØ to FFIFFF comprise the ROMBIOS area. This name is a combination of ROM and BIOS, where BIOS is short for Basic Input / Output System. The ROMBIOS provides the routines for I/O and for the DIMENSION 68000 system MONITOR. The MONITOR is a collection of routines that are used to "boot" the system and to communicate with the Keyboard and the CRT.

Each interrupt vector is a location in memory that contains the address of a software routine (or a ROMBIOS routine) that handles the interrupt that is associated with that specific location. The interrupt vectors are used by CP/M, by the EXPANSION SLOTS, and by the DUART which handles the Keyboard, the Printer Port, the RS-232 Interface, and by the Real Time Clock.

The highest address of the RAM varies depending on the amount of RAM that is installed. The following chart shows the relationship between the amount of memory installed and the highest address in RAM.

| ľ |
|---|
|   |
| 3 |
| • |
|   |
|   |
|   |
|   |
|   |
|   |

16 MB FEFFFF

SYSTEM REFERENCE MANUAL

CHAPTER 4

.

CP/M-68K, CPMBIOS, AND ROMBIOS

#### FLOW

The CP/M-68K operating system is basically composed of three parts; the Console Command Processor (CCP), the Basic Disk Operating System (BDOS), and the Basic Input / Output System (BIOS). The CCP handles the commands that are typed in from the console (or are entered from a submit file) such as DIR, or SUB.

The BDOS handles the functions such as file access, drive access, system/program control, and exceptions. The BDOS partially handles character Input/Output (I/O) functions.

The largest part of the character I/O handling and all of the basic I/O handling is performed by the CP/M BIOS. The CP/M BIOS accesses the I/O functions that are provided in the DIMENSION 68000 Read Only Memory BIOS (ROMBIOS). The ROMBIOS actually controls the I/O controllers and I/O devices.

The CP/M operating system is described more fully in the CP/M-68K Operating System User's Guide and it the CP/M Operating System Programmer's Guide. Both manuals are from Digital Research, Inc. Digital Research, Inc., is the company that developed CP/M and it is the company that licenses the use of CP/M.

# ADDITIONAL CALLS

There is a list of the CP/M-68K functions in the CP/M Operating System Programmer's Guide. The Micro Craft Corporation has added three additional functions to the CP/M-68K operating system for use on the DIMEN-SION 68000 computer. The additional functions are presented in the following pages.

```
FUNCTION 256: Change Diskette Drive Format
Entry Parameters:
     Register D\emptyset \cdot W = 1\emptyset\emptysetH = 256 (decimal)
     Register Dl.W = New Disk Drive Unit Number
                    where \emptyset = Drive A:
                          1 = Drive B:
                          2 = Drive C:
                          3 = Drive D:
                          4 = \text{Drive E:}
                          5 = Drive F:
                          6 = Drive G:
                          7 = Drive H:
     Register D2.W = New Disk Drive Format
                    where \emptyset = null
                          1 = Std 40 track
                          2 = Std 80 track
                          3 = IBM single side (CPM 86) 8 sector
                          4 = IBM double side (CPM 86) 8 sector
                          5 = TRS 80
                          6 = KayPro
                          7 = Cromemco
                          8 = Osborne
                          9 = IBM 3740 8 Inch Single Side, Density
                          A = TRS 16 Double Side, Density
                          B = User Defined
 Returned Values:
```

NONE

```
Page 41
```

```
FUNCTION 257: Read Diskette Drive Format
Entry Parameters:
    Register D\emptyset.W = 1\emptysetIH = 257 (decimal)
    Register D1.W = Disk Unit Number
                   where \emptyset = Drive A:
                         1 = Drive B:
                         2 = Drive C:
                         3 = Drive D:
                         4 = Drive E:
                         5 = Drive F:
                         6 = Drive G:
                         7 = Drive H:
Returned Values:
    Register DØ.W = Selected Drive Type
                   where \emptyset = \text{null}
                         1 = Std 40 track
                         2 = Std 80 track
                         3 = IBM single side (CPM 86) 8 sector
                         4 = IBM double side (CPM 86) 8 sector
                         5 = TRS 80
                         6 = KayPro
                         7 = Cromemco
                         8 = Osborne
                         9 = IBM 3740 8 Inch Single Side, Density
                         A = TRS 16 Double Side, Density
                         B = User Defined
```

Page 42

```
FUNCTION 258: Set the Physical Parameter Table,
            Set the CP/M Disk Parameter, or
             Set the Disk Interlace Table
______
 Entry Parameters:
    Register D\emptyset.W = 1\emptyset2H = 258 (decimal)
    Register D1.W = Command Select
                  where \emptyset = Ignore
                       1 = Set Physical Parameters
                           (DPRMTX 16 words)
                       2 = Set CP/M Disk Parameter Block Table
                           (DPBX 8 words)
                       3 = Set Interlace Table
                           (XLTX 64 words)
    Register D2.L = Table Address
Returned Values:
```

1 .

NONE

## TERMINAL ATTRIBUTES

The DIMENSION 68000 CP/M BIOS has been augmented to provide a set of "ESCAPE SEQUENCES" that will handle various screen functions on the CRT display. Also, several "CONTROL" screen functions have been implemented. The following charts list the "ESCAPE SEQUENCES" and the "CONTROL" functions. These functions are accessed by outputting the code or codes through the CP/M "CONOUT" function.

CONTROL FUNCTIONS

------

ASCIT

HEY

| HEX   |              |             |
|-------|--------------|-------------|
| VALUE | FUNCTION     |             |
|       |              |             |
| в1    | Clear Screen |             |
| Ø7    | Bell         |             |
| в7    | Home         |             |
| 91    | Cursor Up    |             |
| 92    | Cursor Left  |             |
| 93    | Cursor Right |             |
| 94    | Cursor Down  | (Line Feed) |
|       |              |             |

v

ESCAPE SEQUENCES (Escape plus the hex value listed)

| пбл   | ASCII |                            |
|-------|-------|----------------------------|
| VALUE | CODE  | FUNCTION                   |
|       |       |                            |
| 48    | Н     | Home Cursor                |
| 3D    | =     | Position Cursor            |
| 76    | v     | Clear Screen & Home Cursor |
| 41    | Α     | Cursor Up                  |
| 42    | В     | Cursor Down                |
| 43    | С     | Cursor Right               |
| 44    | D     | Cursor Left                |
| 4B    | К     | Erase End of Line          |
| 4A    | J     | Erase End of Page          |
| 78    | х     | Clear End of Line          |
| 79    | У     | Clear End of Page          |
| 63    | С     | Turn On Cursor Flag        |
| 64    | d     | Turn Off Cursor Flag       |
| 65    | е     | Turn On Inverse Flag       |
| 66    | f     | Turn Off Inverse Flag      |
|       |       |                            |

#### ROMBIOS

The CP/M functions operate by performing calls to the appropriate routines in the ROMBIOS. ROMBIOS is an acronym for the ROM Based Input / Output System. The usage of the ROMBIOS is fully described in the ROM-BIOS Appendix to this manual. A chart showing the ROMBIOS functions is included to illustrate the contents of the ROMBIOS.

ROMBIOS FUNCTIONS

\_\_\_\_\_\_

= Initialize CRT Controller 1 = Output a character to the screen 2 3 = Clear the TEXT screen 4 = Read a key stroke 5 = Get keyboard status 6 = Boot from disk 7 = Start the built-in monitor 8 = Read selected disk drive status 9 = Select disk drive and turn motor ON 10 = Deselect disk drive and turn motor OFF 11 = Seek to selected disk track 12 = Seek to track Ø and recalibrate disk - rezero 13 = Seek to track and read a sector 14 = Seek to track and write a sector 15 = Seek to track and format a track 16 = Format the entire disk 17 = Read the sector ID information 18 = Read the disk status 19 = Reserved $2\emptyset$  = Reserved 21 = Read Printer Status 22 = Output a character to Printer Interface 23 = Position CRT cursor 24 = Read character at present CRT cursor location 25 = Clear Graphics Screen 26 = Set graphics color 27 = Plot X, Y point28 = Reserved29 = Read color at designated point 30 = Output Character to CRT with No Control Characters INPUT / OUTPUT

To fully appreciate the functions supplied in the ROMBIOS, requires a knowledge of the actual input and output circuitry used inside the DIM-ENSION 68000 computer. A detailed discussion of the programming requirements for the input and the output circuitry is included in the DIRECT I/O Appendix to this manual. CHAPTER 5

СР/М-68К

### BDOS AND BIOS

The CP/M operating system is composed of two parts; the Basic Disk Operating System (BDOS) and the Basic Input / Output System (BIOS). The BDOS is that part of the operating system that is independent of the Input/Output.

The BIOS is that part of the operating system that is concerned with Input/Output. The BIOS for the DIMENSION 68000 system uses the ROMBIOS as much as is possible. The CP/M BIOS includes a table that handles diskettes and also handles the RS-232 port. The label that has been assigned to that table is "drivetb". Following is a description of the "drivetb" table.

TABLE OFFSETS

| OFFSET | LENGTH  | DESCRIPTION                              |
|--------|---------|------------------------------------------|
|        |         | ~~~~~~                                   |
| +Ø     | l byte  | Number of Disk types                     |
| +1     | l byte  | DUART reset RS-232 command               |
| +2     | l byte  | DUART select RS-232 command              |
| +3     | l byte  | DUART set 9600 bits per second           |
| +4     | l byte  | DUART set no parity/8 bits               |
| +5     | l byte  | DUART set normal/l stop bit              |
| +6     | l byte  | RS-232 XON/XOFF flag                     |
| +7     | l byte  | Old Track Number                         |
| +8     | 1 byte  | Old Physical Sector Number               |
| +9     | l byte  | New Track Number                         |
| +10    | l byte  | New Sector Number                        |
| +11    | 4 bytes | New DMA Address                          |
| +15    | l byte  | Old Disk Unit                            |
| +16    |         | Retry Count                              |
| +17    | 4 bytes | Save Location for the Dl register        |
| +2Ø    | l byte  | Save Location                            |
| +21    | l byte  | Save Location                            |
| +22    | 2 bytes | Drive                                    |
| +24    |         | Warm Boot Flag                           |
| +26    |         | Number of Memory Regions = 1             |
| +28    | 4 bytes | Starting Address of the Memory Region(s) |
| +32    | 4 bytes | Ending Address of the Memory Region(s)   |

Page 52

## ADDITIONAL CALLS

The DIMENSION 68000 version of CP/M has three functions added to the normal CP/M calls. The functions are:

```
256 - Change Diskette Drive Format
      Entry Parameters:
         Register D\emptyset.W = 1\emptyset\emptysetH = 256 (decimal)
         Register Dl.W = New Disk Drive Unit Number
                          where \emptyset = Drive A:
                                1 = Drive B:
                                2 = Drive C:
                                3 = Drive D:
                                4 = Drive E:
                                5 = Drive F:
                                6 = Drive G:
                                7 = Drive H:
         Register D2.W = New Disk Drive Format
                          where \emptyset = null
                                1 = Std 40 track
                                2 = Std 80 track
                                3 = IBM single side
                                4 = IBM double side
                                5 = TRS 80
                                6 = KavPro
                                7 = Cromemco
                                8 = Osborne
                                9 = IBM 3740 8 Inch Single Side, Density
                                A = TRS 16 Double Side, Density
                                B = User Defined
      Returned Values:
         Register DØ.W
257 - Read Diskette Drive Format
      Entry Parameters:
         Register D\emptyset.W = 1\emptyset1H = 257 (decimal)
         Register Dl.W = Disk Unit Number
                          where \emptyset = Drive A:
                                1 = Drive B:
                                2 = Drive C:
                                3 = Drive D:
                                4 = Drive E:
                                5 = Drive F:
                                6 = Drive G:
                                7 = \text{Drive H}:
```

Retruned Values: Register DØ.W

```
258 - Set the Physical Parameter Table,
     Set the CP/M Disk Parameter, or
     Set the Disk Interlace Table
     _____
     Entry Parameters:
        Register D\emptyset.W = 1\emptyset2H = 258 (decimal)
         Register Dl.W = Command Select
                        where \emptyset = Ignore
                              1 = Set Physical Parameters
                                   (DPRMTX 16 words)
                               2 = Set CP/M Disk Parameter Block Table
                                   (DPBX 8 words)
                               3 = Set Interlace Table
                                   (XLTX 64 words)
        Register D2.L = Table Address
     Returned Values:
        Register DØ.W
```

TERMINAL ATTRIBUTES

The DIMENSION 68000 CP/M BIOS has been augmented to provide a set of "ESCAPE SEQUENCES" that will handle various screen functions on the CRT display. Also, several "CONTROL KEY" screen functions have been implemented. The following charts list the "ESCAPE SEQUENCES" and the "CON-TROL KEY' functions.

CONTROL KEYS \_\_\_\_\_ HEX KEYS TO VALUE PRESS FUNCTION \_\_\_\_\_ \_\_\_\_ \_\_\_\_\_ Bl Alt l Clear Screen Bell F8 Alt 7 Ø7 в7 Home Alt End 1 Cursor Up Alt Dwn 2 Cursor Left Alt Pgd 3 Cursor Right Alt Lft 4 Cursor Down 91 92 93 94 (Line Feed) -----

To generate the escape code (27Hex) Press CTRL plus the '" key

ESCAPE SEQUENCES (Escape plus the key value listed)

| HEX<br>VALUE | KEYS TO<br>PRESS | FUNCTION                   |
|--------------|------------------|----------------------------|
| 48           | Н                | Home Cursor                |
| 3D           | =                | Position Cursor            |
| 76           | v                | Clear Screen & Home Cursor |
| 41           | A                | Cursor Up                  |
| 42           | В                | Cursor Down                |
| 43           | С                | Cursor Right               |
| 44           | D                | Cursor Left                |
| 4B           | К                | Erase End of Line          |
| 4A           | J                | Erase End of Page          |
| 78           | x                | Clear End of Line          |
| 79           | У                | Clear End of Page          |
| 63           | с                | Turn On Cursor Flag        |
| 64           | đ                | Turn Off Cursor Flag       |
| 65           | e                | Turn On Inverse Flag       |
| 66           | f                | Turn Off Inverse Flag      |

#### USAGES

The CP/M call that is used to "Change Diskette Drive Format" is one of the functions that is used by the "RESET" utility program to set the disk formats. The additional calls that have been added to the DIMEN-SION 68000 CP/M system are accessed in the same way as the standard CP/M function calls.

# INDEX

Backup BASIC Central Processor Connecting Dimension Together Connectors Copy CP/M-68K Creating Backup Disks CRT Cursor DIMENSION Disk Drive Configurations Disk Drive Expansion Disk Test Emulators 6512 8086 Z8Ø Expansion Slots Firmware Formatting New Disks FORTRAN 77+ Installation Checklist I/O Devices Keyboard Languages Location Making Disk Copies MC68000L8 Monitor Motherboard OFF/ON Switch Power Power Supply Assembly Program Loading RESET Switch ROMBIOS Startup System Unit Test Unpacking VDU

•

APPENDIX A

The TOOL-KIT

Some users of the DIMENSION 680000 require detailed information on the circuitry, on the software used in the CP/M BIOS, or on the software used in the ROMBIOS. For these users, the Micro Craft Corporation provides a "Tool-Kit" that contains the following items:

- A complete set of the schematic diagrams for the Main Printed Circuit Board of the DIMEMSION 68000 computer.
- A diskette that contains the following items:
  - A copy of the source code for the CP/M BIOS.
  - A copy of the source code for the ROMBIOS.

The Micro Craft Corporation wishes to encourage other parties that wish to manufacture equipment for the DIMENSION 68000. In order to provide that encouragement, the Micro Craft Corporation will license the use of the design information for the DIMENSION 68000 and the software used in the DIMENSION 68000. The license for this use will be ROYALTY FREE.

To arrange for a license for the use of the design information and the software for the DIMENSION 68000, contact the Micro Craft Corporation at the following address.

MICRO CRAFT CORPORATION OEM SALES 4747 IRVING BLVD. DALLAS, TX. 75247

Also, all purchasers of the "Tool-Kit" will be notified of any updates to the software or major changes to the hardware. Copies of these changes will be made available to the purchasers of the "Tool-Kit" for a small SHIPPING AND HANDLING FEE. is.

If your application for the DIMENSION 68000 requires any of the following items: - A copy of the schematic diagram - A copy of the listing for the ROMBIOS - A copy of the listing for the CP/M BIOS These items are available from the Micro Craft Corporation as "The Tool-Kit" for \$99.95 (Residents of Texas add 6 % sales tax). To order "The Tool-Kit", please sign the attached Non-Disclosure Agreement, fill out and mail this form.

----FOLD HERE---------

| Name         | Title |             |  |
|--------------|-------|-------------|--|
| Company      |       | <del></del> |  |
| Address      | ·     |             |  |
| City         | State | Zip         |  |
| Telephone () |       |             |  |

----- FOLD HERE ------

I certify that I will hold as confidential, all proprietary information that I receive from Micro Craft Corporation, and will not divulge that information to anyone without written permission, nor use that inform, ation for any purpose not in the best interests of the Micro Craft Corporation.

Date

Signature

MICRO CRAFT CORPORATION CUSTOMER SERVICE DEPARTMENT 4747 IRVING BLVD. DALLAS, TX. 75247

# APPENDIX B

DIMENSION KEYBOARD CODES

|           | Un-      |          |            | Cnt1/    |          | Alt        | Alt        | Alt      |
|-----------|----------|----------|------------|----------|----------|------------|------------|----------|
| Кеу       | shift    | Shft     | Cntl       | Shft     | Alt      | Shft       | Cntl       | Cnt/Shft |
| A         | 61       | 41       | Cl         | Cl       | El       | Cl         | Cl         | Cl       |
| В         | 62       | 42       | C2         | C2       | E2       | C2         | C2         | C2       |
| С         | 63       | 43       | C3         | C3       | E3       | C3         | C3         | C3       |
| D         | 64       | 44       | C4         | C4       | E4       | C4         | C4         | C4       |
| E         | 65       | 45       | C5         | C5       | E5       | C5         | C5         | C5       |
| F         | 66       | 46       | C6         | C6       | E6       | C6         | C6         | C6       |
| G         | 67       | 47<br>48 | C7         | C7       | E7       | C7         | C7         | C7       |
| H         | 68       |          | C8         | C8       | E8       | C8         | C8<br>C9   | C8       |
| I<br>J    | 69<br>6A | 49<br>4A | C9         | C9<br>CA | E9       | C9<br>CA   | CA         | C9<br>CA |
| J<br>K    | 6A<br>6B | 4A<br>4B | CA<br>CB   | CA<br>CB | EA<br>EB | CA<br>CB   | CA         | CB       |
| к<br>L    | 6B<br>6C | 4B<br>4C | CC         | CC       | EC       | CC         | CC         | CC       |
| ы<br>М    | 6C<br>6D | 4C<br>4D | CD         | CD       | ED       | CD         | CD         | CD       |
| N         | 6E       | 4D<br>4E | CE         | CE       | EE       | CE         | CE         | CE       |
| 0         | 6F       | 4E<br>4F | CE         | CE       | EF       | CF         | CE         | CF       |
| P         | 7Ø       | 5Ø       | DØ         | DØ       | FØ       | DØ         | DØ         | DØ       |
| Q         | 70       | 51       | Dl         | DU       | F1       | Dl         | Dl         | Dl       |
| R         | 72       | 52       | D2         | D2       | F2       | D2         | D2         | D2       |
| S         | 73       | 53       | D3         | D3       | F3       | D3         | D3         | D3       |
| Ť         | 74       | 54       | D4         | D4       | F4       | D4         | D4         | D3       |
| Ū         | 75       | 55       | D5         | D5       | F5       | D5         | D5         | D5       |
| v         | 76       | 56       | D6         | D6       | F6       | D6         | D6         | D6       |
| W         | 77       | 57       | D7         | D7       | F7       | D7         | D7         | D7       |
| х         | 78       | 58       | D8         | D8       | F8       | D8         | D8         | D8       |
| Y         | 79       | 59       | D <b>9</b> | D9       | F9       | D <b>9</b> | D <b>9</b> | D9       |
| Z         | 7A       | 5A       | DA         | DA       | FA       | DA         | DA         | DA       |
| 1!        | 31       | 21       | 31         | 21       | вl       | Al         | Bl         | Al       |
| 2@        | 32       | 4Ø       | 32         | CØ       | В2       | CØ         | В2         | CØ       |
| 3#        | 33       | 23       | 33         | 23       | В3       | A3         | В3         | A3       |
| 4\$       | 34       | 24       | 34         | 24       | В4       | A4         | В4         | A4       |
| 5%        | 35       | 25       | 35         | 25       | B5       | A5         | B5         | A5       |
| 6         | 36       | 5E       | 36         | DE       | B6       | DE         | B6         | DE       |
| 7&        | 37       | 26       | 37         | 26       | B7       | A6         | B7         | A6       |
| 8*        | 38       | 2A       | 38         | 2A       | B8       | AA         | B8         | AA       |
| 9 (<br>Ø) | 39<br>3Ø | 28       | 39<br>20   | 28       | B9       | A8         | B9<br>B0   | A8       |
| Ø)        | 30       | 29       | 3Ø         | 29       | вø       | A9         | вØ         | A9       |

KEYBOARD CODES

| Кеу               | Un-<br>shift | Shft       | Cntl          | Cntl/<br>Shft | Alt | Alt<br>Shft | Alt<br>Cntl   | Alt<br>Cnt/Shft |
|-------------------|--------------|------------|---------------|---------------|-----|-------------|---------------|-----------------|
|                   | <u></u>      |            |               |               |     |             |               |                 |
|                   | <b>2</b> D   | 5F         | DF            | DF            | AD  | DF          | DF            | DF              |
| ==                | 3D           | 2B         | 3D            | 2B            | BD  | AB          | BD            | AB              |
| [                 | 5B           | 7B         | DB            | DB            | DB  | FB          | DB            | DB              |
| <u>]</u> }        | 5D           | <b>7</b> D | DD            | DD            | DD  | FD          | DD            | DD              |
| <b>`</b> ~        | 6Ø           | 7 E        | 60            | 7E            | EØ  | FE          | EØ            | FE              |
| ;:                | 3B           | 3A         | 3B            | 3A            | BB  | BA          | BB            | BA              |
| , 11              | 27           | 22         | 27            | 22            | Α7  | A2          | Α7            | A2              |
| $\mathbf{M}^{-1}$ | 5C           | 7C         | DC            | DC            | DC  | FC          | DC            | DC              |
| ,< .              | 2C           | 3C         | 2C            | 3C            | AC  | BC          | AC            | BC              |
| •>                | 2 E          | ЗE         | <b>2</b> E    | 3 E           | AE  | BE          | AE            | BE              |
| /?                | 2F           | 3F         | 2F            | 3F            | AF  | BF          | AF            | BF              |
| SPC               | 20           | 20         | 20            | 20            | AØ  | AØ          | AØ            | AØ              |
| INS-Ø             | 10           | ØA         | ЕØ            | ЕØ            | 9Ø  | 6 8 A       | ЕØ            | ЕØ              |
| DEL               | 8B           | ØВ         | 7F            | 7 F           | 8B  | 8B          | FF            | FF              |
| END-1             | 11           | ØC         | BE            | BE            | 91  | 8C          | BE            | BE              |
| DWN-2             | 12           | ØD         | FE            | FE            | 92  | 8D          | FE            | FE              |
| PGD-3             | 13           | ØE         | $\mathbf{BF}$ | BF            | 93  | 8 E         | BF            | BF              |
| LFT-4             | 14           | ØF         | AC            | AC            | 94  | 8F          | AC            | AC              |
| 5                 | 15           | 1A         | BA            | BA            | 95  | 9A          | BA            | BA              |
| RGT-6             | 16           | 18         | BB            | BB            | 96  | 9B          | BB            | BB              |
| HOM-7             | 17           | 1C         | FB            | FB            | 97  | 9C          | $\mathbf{FB}$ | FB              |
| UP-8              | 18           | lD         | FD            | FD            | 98  | <b>9</b> D  | FD            | FD              |
| PGU-9             | 19           | 1E         | FC            | FC            | 99  | 9E          | FC            | FC              |
| -                 | 2D           | 2D         | 2D            | 2D            | AD  | AD          | AD            | AD              |
| +                 | 2B           | 2B         | 2B            | 2B            | AB  | AB          | AB            | AB              |
| RTRN              | CD           | CD         | CA            | CA            | CD  | CD          | CA            | CA              |
| BKSPC             | C8           | C8         | 7F            | 7F            | C8  | C8          | FF            | FF              |
| ESC               | DB           | DB         | DB            | DB            | DB  | DB          | DB            | DB              |
| BRK               | 8C           | 8D         | 8D            | 8D            | 8C  | 8D          | 8D            | 8D              |
| PRT-*             | 2A           | lF         | BC            | BC            | AA  | 9F          | BC            | BC              |
| TAB               | С9           | AA         | AB            | AB            | C9  | AA          | AB            | AB              |
| ENTR              | 8 A          | 8A         | 8A            | 8 A           | 8 A | 8A          | 8A            | 8A              |

1

| Un- |       | ······· |      | Cntl/ |     |      | Alt  | Alt      |
|-----|-------|---------|------|-------|-----|------|------|----------|
| Кеу | shift | Shft    | Cntl | Shft  | Alt | Shft | Cntl | Cnt/Shft |
|     | ØØ    | AØ      | 9A   | 9A    | 80  | AØ   | 9A   | 9A       |
| F2  | Øl    | Al      | 9B   | 9B    | 81  | Al   | 9B   | 9B       |
| F3  | Ø2    | A2      | 9C   | 9C    | 82  | A2   | 9C   | 9C       |
| F4  | Ø3    | A3      | 9D   | 9D    | 83  | A3   | 9D   | 9D       |
| F5  | Ø4    | A4      | 9E   | 9 E   | 84  | A4   | 9 E  | 9 E      |
| F6  | Ø5    | A5      | 9F   | 9F    | 85  | A5   | 9F   | 9F       |
| F7  | Ø6    | A6      | AE   | AE    | 86  | A6   | AE   | AE       |
| F8  | Ø7    | A7      | AF   | AF    | 87  | A7   | AF   | AF       |
| F9  | Ø8    | A8      | 8 E  | 8 E   | 88  | A8   | 8 E  | 8 E      |
| FlØ | Ø9    | A9      | 8F   | 8F    | 89  | A9   | 8F   | 8F       |

,

## APPENDIX C

# ASCII CODES

.

American Standard Code for Information Interchange

ASCII CHARACTER SET

(7-BIT CODE)

| T   | MSD  | Ø   | 1    | 2   | 3   | 4      | 5   | 6   | 7        |
|-----|------|-----|------|-----|-----|--------|-----|-----|----------|
|     |      | ØØØ | ØØl  | ØlØ | Ø11 | 100    | 101 | 110 | 111      |
| LSI |      |     |      | L   | L   | L      | L   | •   | <b>-</b> |
| ø   | 0000 | NUL | DLE  | SP  | Ø   | e<br>e | P   | ·   | p        |
| 1   | 0001 | SOH | DC1  | 1   | 1   | A      | Q   | a   | q        |
| 2   | ØØ1Ø | STX | DC2  |     | 2   | В      | R   | b   | r        |
| 3   | 0011 | ETX | DC3  | #   | 3   | С      | S   | С   | S        |
|     |      |     |      |     |     | ~      | -   | -   |          |
| 4   | 0100 | EOT | DC4  | \$  | 4   | D      | Т   | đ   | t        |
| 5   | Ø1Ø1 | ENQ | NAK  | olo | 5   | Е      | U   | e   | u        |
| 6   | Ø11Ø | ACK | S YN | &   | 6   | F      | v   | f   | v        |
| 7   | Ø111 | BEL | ETB  | 1   | 7   | G      | W   | g   | Ŵ        |
| 8   | 1000 | BS  | CAN  | (   | 8   | н      | х   | h   | x        |
| ğ   | 1001 | HT  | EM   | ì   | 9   | I      | Y   | i   | У        |
| Ā   | 1010 | LF  | SUB  | *   |     | Ĵ      | z   | i   | z        |
| В   | 1011 | VT  | ESC  | +   | :   | ĸ      | Ī   | k   | {        |
| _   |      | • - |      |     | •   |        | -   |     | -        |
| С   | 1100 | FF  | FS   | ,   | <   | L      | Ν.  | 1   | 1        |
| D   | 1101 | CR  | GS   | -   | =   | М      | ]   | m   | }        |
| Е   | 1110 | SO  | RS   | •   | >   | N      | ^   | n   | ~        |
| F   | 1111 | SI  | US   | 1   | ?   | 0      |     | 0   | DEL      |
|     |      |     |      |     |     |        |     |     |          |

1

APPENDIX D

EXPANSION SLOT

PINOUT

# EXPANSION SLOT PINOUT

The following illustration identifies the pin locations and pin signatures of the edge connectors (\* = Low TRUE signal,  $\emptyset$ VDC).

## CONNECTOR

| Vcc1<br>Vcc3<br>RST* 5<br>MEMCYC* 7<br>DØ 9<br>D2 11<br>D4 13 | 2VCC +5VDC +,- 1%<br>4VCC @ 1A Max/Pin<br>6 R/W* (slot max 3A)<br>8 CRTREQ*<br>10 D1<br>12 D3<br>14 D5 |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| Data Bus D6 15<br>D8 17<br>D10 19<br>D12 21<br>D14 23         | 16 D7<br>18 D9<br>20 D11<br>22 D13<br>24 D15                                                           |
| LOWC* 25                                                      | 26 DRSEL1*                                                                                             |
| Disk 2SIDE* 27                                                | 28 HLOAD*                                                                                              |
| Drive Exp. INDEX* 29                                          | 30 HEAD*                                                                                               |
| Cnt'l STEP* 31                                                | 32 DIRC*                                                                                               |
| WENA* 33                                                      | 34 WDATA*                                                                                              |
| RDATA 35                                                      | 36 TKØØ*                                                                                               |
| DRSELØ* 37                                                    | 38 WPROT*                                                                                              |
| DRSEL0* 37                                                    | 40 ACK0*                                                                                               |
| DISPEN* 41                                                    | 40 ACK0"<br>42 E                                                                                       |
|                                                               |                                                                                                        |
| INTRP* 43                                                     | 44 EMULATION STROBE                                                                                    |
| VMA* 45                                                       | 46 HLT*                                                                                                |
| F1 47                                                         | 48 F2                                                                                                  |
| (AØ) UDS* 49                                                  | 50 F0                                                                                                  |
| A22 51                                                        | 52 A23                                                                                                 |
| A2Ø 53                                                        | 54 A21                                                                                                 |
| A18 55                                                        | 56 A19                                                                                                 |
| A16 57                                                        | 58 A17                                                                                                 |
| Address Bus A14 59                                            | 60 A15                                                                                                 |
| A12 61                                                        | 62 A13                                                                                                 |
| A1Ø 63                                                        | 64 All                                                                                                 |
| A8 65                                                         | 66 A9                                                                                                  |
| A6 67                                                         | 68 A7                                                                                                  |
| A4 69                                                         | 7Ø A5                                                                                                  |
| A2 71                                                         | 72 A3                                                                                                  |
| -12 VOLTS73                                                   | 74 Al                                                                                                  |
| s1-6* 75                                                      | 76 ACK1-6*                                                                                             |
| +12 VOLTS77                                                   | 78+12 VOLTS                                                                                            |
| INT1-6* 79                                                    | 80 DATAVAL*                                                                                            |
| 14.31818 MHz 81                                               | 82 BD1-6ENA*                                                                                           |
| GROUND 83                                                     | 84 GROUND                                                                                              |
| GROUND 85                                                     | 86 GROUND                                                                                              |

## EXPANSION SLOT PIN DESCRIPTIONS

The following text describes the function of each Expansion Slot pin. The number, located in front of the abbreviation and pin signature identifies which pin (or group of pins) is being described. Asterisks, located behind a pin signature, indicate signals that are low when true (ØVDC).

- 1 4 Vcc +5 VDC +,- 1% @ 1 Amp Max/~'n 3 Amps Max per Expansion Slot (6.5 Amps total for 6 slots)
- 5 RST\* System Master Reset (Ø.1VDC typical) Power On Reset = 200 milliSeconds minimum Reset Button = 200 milliSeconds minimum 68000 RESET Inst = 128 CPU clock Cycles (approximately 17.8 micro-Seconds)
- 6 R/W\* READ/WRITE \* (tri-state) READ = High (2.4VDC) WRITE = Low (Ø.1VDC) Must be tri-state buffered. Pin 76 ACK signal enables the tri-state buffer and enables bus usage.
- 7 MEM/CYC MEMORY CYCLE A high level indicates that a memory cycle has been initiated. Functionally, this pin is the Bus Master's Request \* complement.
- 8 CRTREQ\* CRT REQUEST \* Pulled low by the CRT Controller (6845) to indicate a CRT memory cycle. Used to synchronize ALL Co-Processors to the CRT Controlled memory refresh. Upon completion of a memory cycle, there are approximatly 550 nanoSeconds before the next CRT request.
- 9 24 DØ D15 SYSTEM DATA BUS The data bus is bi-directional and it is 16 bits wide. All of the connections to the data bus must be tri-state buffered. The Pin 76 ACK signal enables the tri-state buffer and the it enables bus usage.

25 - 38 DISK CONTROL 14 control and data lines connected directly to the mini-floppy interface connector. The built-in System Disk Controller may be disabled and replaced by another Expansion Slot resident Controller ( under software control ). This feature permits the usage of special purpose Disk Controllers.

25 LCUR\* LOWCURRENT\* When the Controller is in either a Read or a Write Mode, this signal will cause the lowering of the write current, when this signal is set true (ØVDC). This signal is for use on the inner tracks of a diskette only.

26 DRSEL1\* DRIVE 1 SELECT\* Selects drive number 1, when set true (ØVDC).

27 2SIDE\* DISK TWO SIDED\* When a drive has been selected and the diskette is spinning, this signal will either be set true (ØVDC), for two sided media, or this signal will be set false (+5VDC), for single sided media.

- 28 HLOAD\* HEAD LOAD\* When set true (ØVDC), causes the currently addressed disk drive head to load.
- 29 INDEX\* INDEX\* This pin supplies a true signal (ØVDC), each time an index or sector hole is detected by the index/sector photo-detector. This pin is set false (+5VDC) when no index or hole is sensed. When soft sectored media is used there will be one pulse (200ms) per revolution. For soft sectored media, this pulse is used to indicate the physical beginning of a track.
- 30 HEAD\* HEAD\* Selects head 1 when the pin is true (ØVDC) and head Ø when false (+5VDC).

j= ---

31

STEP\* STEP\*

Moves the head assembly in the direction dedefined by the DISK DIRECTION pin (pin 32). The signal must be true (ØVDC), for a minimum pulse width of 1 microSecond, followed by a false (+5VDC), for a minimum pulse width of 5 milliSeconds between adjacent pulses. The access motion is initated on the transition from logical Ø to logical 1, or at the trailing edge of the pulse. Any change in the signal on the DISK DIRECTION pin (pin 32) must be made, at least, 1 microSecond before the trailing edge of the DISK STEP pulse. Further information on the timing relationships of these signals is available in the Shugart SA455/465 Double-sided Minifloppy (TM) Diskette Storage Drive OEM Manual.

32 DIRC\* DISK DIRECTION\* This pin defines the direction of motion for the head assembly when the DISK STEP (pin 30) pin is pulsed. Either a false (+5VDC) or open circuit defines the direction as out. With this condition established, the motion of the head asseembly will be away from the center of the disk. Conversely, if this pin is true (ØVDC), the direction of motion is inward. With this condition established, the motion of the head assembly will be toward the center of the disk.

33

#### WENA\* WRITE ENABLE\*

A true (ØVDC) condition enables the Write Data Function, permitting data to be written to the disk. A false (+5VDC) on this pin enables the Read Data Function, permitting data to be read from the disk. 34

### WDATA\* WRIFE DATA\*

This pin carries the data that is to be written on the disk. Each transition, from true (+5VDC) to false (ØVDC), will cause a current reversal to the head, causing a bit to be written. This pin is enabled when DISK WRITE ENABLE (pin 33) is true (ØVDC). The DISK WRITE ENABLE pin must be false (+5VDC) during a Read Data Function. Transitions the WRITE DATA pin should not occur until 8 micro Seconds after the DISK WRITE ENABLE goes true. Similarly, transitions on the WRITE DATA pin must stop 8 micro Seconds before the DISK WRITE EN-ABLE goes false. Further information on the timing of these signals is available in the Shugart SA455/465 Double-sided Minifloppy (TM) Diskette Storage Drive OEM Manual.

35

#### RDATA READ DATA

This pin provides the raw disk data (data and clock), as detected by the disk head. Normally this pin is false (+5VDC) and changes to true (ØVDC) when active. Transitions on the READ DATA pin will not be valid until 2 micro seconds after the drive has been selected. Valid READ DATA can continue up to 1 milli second after the DISK WRITE ENABLE pin goes to ØV. A detailed explanation of the timing relationships for these signals is available in the Shugart SA455/465 Double-sided Minifloppy (TM) Diskette Storage Drive OEM Manual.

36

#### TRACK Ø\*

This pin is true ( $\emptyset$ VDC) when the head assembly is positioned at track  $\emptyset$  (outermost track) and the access circuitry is driving current through phase A of the positioner (stepper) motor. This pin is false (+5VDC) when the head assembly is not positioned at track  $\emptyset$ . However, the TRACK  $\emptyset$  signal will go to a logical  $\emptyset$ . this reaction is caused by the positioner motor changing from phase A to phase C. One additonal Step Out Pulse (on pin 31) will change the positioner motor back to phase A and the TRACK  $\emptyset$  \* pin will again go active.

37

DRSELØ\* DRIVE Ø SELECT\* This pin selects drive Ø when true (ØVDC).

ткØ\*

38 WPROT\* WRITE PROTECT\* Provided by the disk drive to give the user an indication when a Write Protected disk is used. The pin is true (ØVDC) when the disk is Write Protected and false (+5VDC) when the disk is not protected. Under normal operation, the drive will inhibit the Write Function when a Write Protected disk is used, in addition to notifying the interface.

39 LDS\* LOWER DATA STROBE\* Used in conjuction with the UPPER DATA STROBE (pin 49) to control data on the Data Bus, as shown in the table below.

> The abbreviations used below are: Undef = Undefined, Valid = Valid data bits (D8-D15 for bits 8-15, D0-D7 for bits 0-7)

| UDS* | LDS* | R/W | D8-D15 | DØ-D7 |
|------|------|-----|--------|-------|
| +5V  | +5V  |     | Undef  | Undef |
| ØV   | øv   | +5V | Valid  | Valid |
| +5V  | øv   | +5V | Undef  | Valid |
| ØV   | +5V  | +5V | Valid  | Undef |
| ØV   | ØV   | ØV  | Valid  | Valid |
| +5V  | øv   | ØV  | Undef  | Valid |
| ØV   | +5V  | ØV  | Valid  | Undef |

40 ACKØ\* ACKNOWLEDGE Ø\* True (ØVDC) when the MC68000 has control of the Data and Address Busses. This signal is the equivalent of a MEMORY ACKNOWLEDGE \* signal to the Expansion Slots.

41 DISPEN\* DISPLAY ENABLE\* True (ØVDC) when the CRT controller circuitry is not in a horizontal or a vertical blanking or retrace time (i.e. when the CRT controller circuitry is in the active display area on the screen).

42 E E SIGNAL The standard enable signal, common to all MC6800 type peripheral devices. The period of the output, of this pin, is ten (10) MC68000 clock periods; consisting of 6 low clocks and 4 high clocks. The MC68000 uses a 7.15909 MHz clock (one-half of a 14.31818 MHz clock). 43 INTRP\* INTERRUPT\* True (ØVDC) when any interrupt request (INTl\*, INT2\*, INT3\*, INT4\*, INT5\*, or INT6\*) is asserted.

- 44 EMULATION STROBE When active (+5VDC), this signal halts the coprocessor whenever that processor has just accessed a memory location that has been tagged by the Emulation Control circuitry. The procedure to set up these Emulation Traps is as follows:
  - 1 Set the addresses that are to be trapped by writing, to address FFD403, a byte that has data bit Ø (which is the least significant bit) set to 1.

Then, read from the address in memory of each word whose address is to be trapped. The addresses to be read must be in the lowest 512K bytes of memory (i.e. in the address range of from ØØØØØØ to Ø7FFFF).

When all the locations have been read that are to be trapped, then write, to address FFD401, a byte that contains all zeroes.

2 - Set the addresses that are not to be trapped by writing, to address FFD403, a byte that has data bit Ø set to Ø.

Then, read from the address in memory of each word whose address is not to be trapped.

When all the locations have been read that are not to be trapped, then write, to address FFD4 $\emptyset$ 1, a byte that contains all zeroes.

### \*\* NOTICE \*\*

Once a write to location FFD403 has occured, the emulation trapping system will be activated. And ANY access to a memory location (by any source - program, CRT controller, DMA device - any source - will set that memory location to the TRAPPED or NOT-TRAPPED condition (according to the byte that was written). The emulation trapping will remain activated until a write (of all zeroes) to location FFD401 occurs.

When a TRAP on a memory location is enabled, any access to that memory location will cause the EMULATION STROBE line to be pulsed to a high (+5 logic level) so as to stop the coprocessor. The emulation routine will have to determine the address that was trapped by the steps that follow:

- Read, from address FFD400, the LSW (Least Significant Word) of the address of the location that was trapped.
- 2 Read, from address FFD402, the MSB (Most Significant Byte) of the address of the location that was trapped.

After execution of the above steps, the emulation routine will have the 24 bit address of the location in memory that was trapped. The emulation routine will then have to determine the appropriate action to take. After the routine has taken the appropriate action, the routine must re-start the co-processor.

VMA\*

45

#### VALID MEMORY ADDRESS\*

Used to signal the presence of a valid address, on the Address Bus, and that the processor is synchronized to the E SIGNAL (pin 42). This signal is used for MC6800 peripheral devices. 46 HLT\* HALT\* A bi-directional signal that is driven by an (open collector output) external device and causes the MC68000 to stop at the completion of the current bus cycle. After the processor stops executing instructions, as in a double bus fault condition, the HALT pin is driven by the processor, to indicate to the external devices that the processor has stopped.

These pins indicate the status and the cycle type currently being executed by the MC68000. The table below defines the relationships, which are valid whenever the ADDRESS STROBE \* is active (0VDC).

| F2 | F1                                                       | FØ | Cýcle Type                                                                                                            |
|----|----------------------------------------------------------|----|-----------------------------------------------------------------------------------------------------------------------|
|    | $ \begin{array}{c}                                     $ |    | undefined<br>User Data<br>User Program<br>undefined<br>Supervisor Data<br>Supervisor Program<br>Interrupf Acknowledge |

49

UDS\* UPPER DATA STROBE\*

Refer to the LOWER DATA STROBE (pin 39) description.

51 - 72, and 74 AØ - A23 ADDRESS BUS This bus is a tri-state, 23 bit wide bus. The connected devices should be at tri-state high impedance until such time as they have been granted a Memory Access Cycle.

| 73 | -12 Volts DC   |                    |
|----|----------------|--------------------|
| ,  | -12 VDC +,- 5% | @ 1.Ø Amp Max/Slot |

75 MREO\* MEMORY REOUEST\* True (ØVDC) when ever a memory cycle is being initiated and is held low Ø until the cycle is completed. Bus conflicts may occur if the CRT is not allowed to have regular memory requests granted (every 1.1 us) so it may be desireable synchronize MEMORY REQUEST with CRT to REQUEST. Refer to the following diagram for an illustration of the relationships between MEMORY REQUEST \* (pin 75), MEMORY ACKNOWLEDGE \* (pin 76), and DATA VALID \* (pin 80). Each Expansion Slot has an individual MEMORY REQUEST \* lead. Slot number 6 has the highest priority, and slot 1 has the lowest priority. 76 MEMORY ACKNOWLEDGE 1 \* ACK1\* ACK2\* MEMORY ACKNOWLEDGE 2 \* ACK3\* MEMORY ACKNOWLEDGE 3 \* ACK4\* MEMORY ACKNOWLEDGE 4 \* MEMORY ACKNOWLEDGE 5 \* ACK5\* ACK6\* MEMORY ACKNOWLEDGE 6 \* This signal, when true (ØVDC) indicates to the slot that it has been granted a memory cycle and therefore has control of the address bus the data bus. This signal is useful to and gate address information onto the address bus and data onto the data bus. Each slot has an individual MEMORY ACKNOWLEDGE \* pin. 77 - 78 +12 Volts DC +12 VDC +,- 5% @ 1 Amp Max/Pin 1.5 Amps Max per Expansion Slot 79 TNT1\* INTERRUPT 1 \* **INTERRUPT 2 \*** INT2\* INTERRUPT 3 \* INT3\* INT4\* **INTERRUPT 4 \*** INTERRUPT 5 \* INT5\* INTERRUPT 6 \* INT6\* This signal is an input to the bus from a specific slot. This signal is used to interrupt the MC68000. Each slot has an individual interrupt line. Slot 6 has the highest priority and slot 1 has the lowest. 8Ø DATAVAL8 DATA VALID \* This common signal, to all Expansion Slots and the CRT and the MC68000, is meaningful only if MEMORY REQUEST \* and MEMORY ACKNOWLEDGE \* are also true (ØVDC). This signal indicates that the data being written into or read from memory is valid.

81

14.31818 MHz This clock is buffered and is used by the 68000 circuitry to derive the 7 MHz clock that is used by the 68000 processor.

82 BD1ENA\* BOARD 1 ENABLE \*
BD2ENA\* BOARD 2 ENABLE \*
BD3ENA\* BOARD 3 ENABLE \*
BD4ENA\* BOARD 4 ENABLE \*
BD5ENA\* BOARD 5 ENABLE \*
BD6ENA\* BOARD 6 ENABLE \*
This signal goes active (ØVDC) whenever the
memory address range for the specific slot is
addressed. The address ranges for each slot
are as follows:
SLOT 1 = FF8800 to FF8FFF
SLOT 2 = FF9000 to FF97FF

SLOT 3 = FF9800 to FF9FFF SLOT 3 = FFA000 to FF9FFF SLOT 4 = FFA000 to FFA7FF SLOT 5 = FFA800 to FFAFFF SLOT 6 = FFB000 to FFB7FF

When this signal goes active, then the addresses for this slot may be read, written, or executed as required.

83 - 86 GROUND GROUND reference for system.

illin .

A.

APPENDIX E

DIRECT I/O

DIRECT I/O

Direct I/O Description

This section describes the various I/O commands available .

ADDRESS READ/WRITE FUNCTION

The following abbreviations are used throughout this section:

- Read Word = RW - Read Byte = RB - Write Word = WW - Write Byte = WB
- Hor = Horizontal
- Vert = Vertical
- Char = Character
- B/W = Black and White
- T/G = Text/Graphics

CRT Controller The CRT controller circuitry is based on the MC6845 chip. FF8ØØ1 WΒ Write CRT Controller Register Selection Input (controls the Address Register for the CRT Controller) CRT Cntl'r CPU Register Register CRT Controller Address Register RØ ØØ Hor Char Total R1 Øl Hor Char Displayed R2 Ø2 Hor Sync Position R3 ØЗ Hor Sync Width R4 Ø4 Vert Char Rows Total Vert Scan Line Adi R5 Ø5 R6 Ø6 Vert Char Rows Displayed R7 Ø7 Vert Sync Position Interlace Mode **R**8 Ø8 R9 Ø9 Number of Scan lines/Char -1 T/G Mode Scan Start RA ØA RB ØВ T/G Mode Scan Stop Buffer Start Address Mid Byte RC ØC RD ØD Buffer Start Address Low Byte RE ØЕ T/G Change Char Add. Hi Byte RF ØF T/G Change Char Add. Low Byte R10 10 Light Pen Char Add. Hi Byte R11 11 Light Pen Char Add. Low Byte Read Data from the Register Addressed FF8003 RB (Addressed by writing to FF8001) FF8ØØ3 Write Data to the Register Addressed WB (Addressed by writing to FF8001) FF8ØØ5 WΒ Write High Byte of Address in Memory of Start of Display Buffer

CRT Controller (cont'd) FF8009 WB Write Mode Register Bit 7 (MSB)  $\emptyset$  = HIRES GRAPHICS 1 = LORES/TEXTBit 6  $\emptyset$  = 8 dot wide character on screen 1 = 7 dot wide character on screen Bit 5  $\emptyset$  = CRT Controller operates ASYNCHRONOUSLY with CPU 1 = CRT Controller operates SYNCHRONOUSLY with CPU Bits 4 and 3  $\emptyset\emptyset = 14$  MHz dot clock  $\emptyset$ 1 = 3.58 MHz dot clock  $1\emptyset = 7$  MHz dot clock 11 = 1.79 MHz dot clock Bit 2  $\emptyset$  = Screen Display ON 1 = Screen Display OFF Bit 1  $\emptyset$  = Standard Text Character Set and LORES 1 = Alternate Text Character Set and HIRES Bit Ø (LSB)  $\emptyset$  = Non-Mixed Screen Mode (i.e. all TEXT or all GRaphics) 1 = Mixed Screen Mode (i.e. Color GRaphics and Monochrome TEXT) MODE DESCRIPTION 44 Off (Refresh Only) AØ Hi Res Text (80 Column) 21 Hi Res Text/Graphics 9Ø Med Res Text (40 Column) 91 Med Res Text/Graphics 20 Hi Res Graphics 21 Med Res Graphics (B/W) Lo Res Graphics (B/W) XX Lo Res Text/Graphics (B/W) XX

CRT Controller (cont'd)

FF8ØØA RB

Reset Controller

Procedure:

The following steps are given as an example of the usage of the CRT controller:

Execute a loop to do the following sequence of steps 18 times:
 Write to the CRT Controller Address Register (FF8001).
 Write the Data that goes to the Register Addressed.

- Write the High Order Byte of the Address (in memory) of the Start of the Display Buffer to the High Order Byte Address Register (FF8005).
- Write the mode desired to the Mode Register (FF8009).

### WARNING

Data may be destroyed in the text or graphics buffer area when the setup procedure is executed.

Typical Parameters (hex)

| CRT CTLR<br>REGISTER<br>ADDRESSED | 40 Col/24Ln | 80 Col/25Ln | 80 col/48Ln | 92 col/24Ln |
|-----------------------------------|-------------|-------------|-------------|-------------|
| RØ                                | Ø4          | ØØ          | ØØ          | ØØ          |
| Rl                                | 37          | 6F          | 6F          | 6F          |
| R2                                | 28          | 5Ø          | 50          | 5Ø          |
| R3                                | 2E          | 5A          | 5A          | 5A          |
| R4                                | 1E          | 1E          | 1E          | lE          |
| R5                                | ØØ          | ØØ          | ØØ          | ØØ          |
| R6                                | 18          | 19          | 18          | 18          |
| R7                                | 1B          | 1B          | 1B          | 1B          |
| R8                                | ØØ          | ØØ          | ØØ          | ØØ          |
| R9                                | Ø8          | Ø8          | Ø9          | Ø9          |
| RA                                | ØØ          | ØØ          | ØØ          | ØØ          |
| RB                                | Øl          | Øl          | Øl          | ØØ          |

### Peripheral Slot Selects

| FF88ØØ - FF8FFF | RW/BW | Read Controller | ROM in slot 1 |
|-----------------|-------|-----------------|---------------|
| FF9000 - FF97FF | RW/BW | Read Controller | ROM in slot 2 |
| FF98ØØ - FF9FFF | RW/BW | Read Controller | ROM in slot 3 |
| FFAØØØ - FFA7FF | RW/BW | Read Controller | ROM in slot 4 |
| FFA8ØØ - FFB7FF | RW/BW | Read Controller | ROM in slot 5 |
| FFBØØØ - FFB7FF | RW/BW | Read Controller | ROM in slot 6 |
| FFB8ØØ - FFBFFF |       | RESERVED        |               |

Above are the memory addresses that are reserved for each controller. As each group of addresses are accessed, then the ENABLE line (for the slot that corresponds to the memory addresses accessed) will go active (TTL logic LOW). When the ENABLE line goes active, then the addresses for the slot may be read, written, or executed as required by each individual controller. NOTICE that the first seven words are reserved as System Information and must be implemented as follows:

| RELATIVE | SYSTEM I | NFORMATION  |
|----------|----------|-------------|
| ADDRESS  | FUNCTION | DESCRIPTION |

|     | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-   |
|-----|--------------------------------------------|
| ØØØ | 16 Bit MANUFACTURER'S CODE  <br>++         |
| ØØ2 | 16 Bit PRODUCT SUBCODE   +                 |
| ØØ4 | 8 Character Controller Description (ASCII) |
| ØØ8 | ++                                         |
| ØØC | I/O VECTOR  <br>++                         |

The data is read 1 byte at a time, in the byte mode.

The Manufacturer's Code is assigned by Micro Craft and uniquely identifies the peripheral manufacturer, for automatic configuration purposes.

The Subcode is defined by the manufacturer to identify the particular model, options or devices attached.

The 8 byte ASCII data is manufacturer definable and will be displayed when the System is "Booted", to identify the particular controller that is installed.

If the I/O Vector is used, it points to the local (Controller Resident) standard I/O routine start address. If the Vector is not used, a null vector is placed in the I/O Vector location. A null vector is defined as FFFF or ØØØØ (hex). All accesses to the Controller addresses (in the slot) use the memory timing mode; that is, data transferred into and out of the boards must accept or present data in 250 nanoSeconds from BOARD ENABLE.

### SYSTEM REFERENCE MANUAL

DIRECT I/O

## Keyboard, Printer, RS-232, and Real Time Clock

The Keyboard, the Printer, the RS-232, and the Real Time Clock (RTC) are all connected into the DIMEMSION 68000 system through a Signetics (or equivalent) SCN2681AC1N40 Dual Universal Asynchronous Receiver / Transmitter (DUART) chip. For a detailed description of the operation of the Signetics SCN2681 DUART chip, see the Signetics Dual Asynchronous Receiver / Transmitter (DUART) data sheet. The registers on the DUART are all one byte in width, and they are addressed as follows:

| Address | Description for Read                                          | Description for Write                           |
|---------|---------------------------------------------------------------|-------------------------------------------------|
|         | ** Channel A is the KEYBOARD                                  | **                                              |
| FFC4Ø1  | Mode Register A (MR1A,MR2A)                                   | Mode Register A (MRlA,MR2A)                     |
| FFC4Ø3  | Status Register A (SRA)                                       | Clock Select Register A (CSRA)                  |
| FFC4Ø5  | * RESERVED *                                                  | Command Register A                              |
| FFC4Ø7  | Recv. Holding Reg. A (RHRA)<br>** Input Port has the Input Li | Transmit Holding Reg. A (THRA)<br>nes **        |
|         | ** IP4 = RS-232 Data Carrier                                  |                                                 |
|         | ** IP1 = Printer ACKNLG*                                      | **                                              |
|         | ** IPØ = Printer READY*                                       | **                                              |
| FFC4Ø9  | Input Port Change Reg. (IPCR)                                 | Aux. Control Register (ACR)                     |
| FFC4ØB  | Interrupt Status Reg. (ISR)                                   | Interrupt Mask Register (IMR)                   |
|         | ** Counter/Timer is the Real T                                | ime Clock **                                    |
| FFC4ØD  | Counter/Timer Upper (CTU)                                     | Counter/Timer Upper Reg. (CTUR)                 |
| FFC4ØF  | Counter/Timer Lower (CTL)                                     | Counter/Timer Lower Reg. (CTLR)                 |
|         | ** Channel B is the RS-232                                    | **                                              |
| FFC411  |                                                               | Mode Register B (MR1B,MR2B)                     |
| FFC413  | Status Register B (SRB)                                       | Clock Select Register B (CSRB)                  |
| FFC415  | * RESERVED *                                                  | Command Register B (CRB)                        |
| FFC417  | Recv. Holding Reg. B (RHRB)                                   | Transmit Holding Reg. B (THRB)                  |
| FFC419  | * RESERVED *                                                  | * RESERVED *                                    |
|         | ** Input Port has the Input Li                                |                                                 |
|         | ** IP4 = RS-232 Data Carrier                                  |                                                 |
|         | <pre>** IP1 = Printer ACKNLG*</pre>                           | **                                              |
|         | ** IPØ = Printer READY*                                       | * *                                             |
| FFC41B  | Input Port<br>** Counter/Timer is the Real T                  | Output Port Config. Reg. (OPCR)<br>ime Clock ** |
|         | ** Output Port is the Printer                                 | **                                              |
| FFC41D  | Start Counter Command                                         | Set Output Port Bits Command                    |
| FFC41F  | Stop Counter COmmand                                          | Reset Output Port Bits Command                  |
|         |                                                               |                                                 |

The DIMENSION 68000 system does not use interrupts in the ROMBIOS, nor are interrupts used in the CP/M-68K BIOS.

Following are descriptions of the usage of the Keyboard, the RS-232, the Real Time Clock, and the Printer.

Keyboard

FFC4Ø3 RB Read Keyboard Status FFC4Ø7 RB Read Keyboard Data

Procedure:

Read Keyboard Status byte (byte wide), if data bit  $\emptyset = 1$  then status is not ready. When the status is ready (data bit  $\emptyset = \emptyset$ ), then read the keyboard data to get the character entered.

The Keyboard Controller is located in conjuction with the RS-232C Serial port, the Printer Interface and the Real Time Clock. The keyboard must be initialized according to the following parameters;

| WB | \$19 | to | \$FFC4Ø5 | Set Control Register<br>- Reset Mode Register Pointer<br>- Disable Keybd Xmit<br>- Enable Keybd Recv |
|----|------|----|----------|------------------------------------------------------------------------------------------------------|
| WB | \$44 | to | \$FFC4Ø3 | Set 300 Baud Rate for Xmit and Recv                                                                  |
| WB | \$FØ | to | \$FFC4Ø9 | Set Aux Control Reg.                                                                                 |
|    |      |    |          | - Bit Rate Generator = Set 2                                                                         |
|    |      |    |          | - Xtal Clock divided by 16                                                                           |
|    |      |    |          | - NO Delta IP bit Interrupts                                                                         |
| WB | \$13 | to | \$FFC4Ø1 | Set Mode Register l                                                                                  |
|    |      |    |          | - Error Mode = Char                                                                                  |
|    |      |    |          | - NO RTS Control                                                                                     |
|    |      |    |          | - NO Recv Interrupt                                                                                  |
|    |      |    |          | - NO Parity                                                                                          |
|    |      |    |          | - 8 Bits per Character                                                                               |
| WB | \$Ø7 | to | \$FFC4Ø1 | Set Mode Register 2                                                                                  |
|    |      |    |          | - Channel Mode = Normal                                                                              |
|    |      |    |          | - NO Xmit RTS Control                                                                                |
|    |      |    |          | - NO CTS Enable                                                                                      |
|    |      |    |          | - ONE Stop Bit                                                                                       |

RS-232

FFC4Ø9 WB Write Aux. Control Register FFC4ØB Write Interrupt Mask Register WB FFC411 WB Write RS-232 Mode Registers (1 and 2) FFC413 WB Write RS-232 Clock Select Register Read RS-232 Status Register FFC413 RB FFC415 WB Write RS-232 Command Register FFC417 WB Write RS-232 Output Data Register Read RS-232 Input Data Register **FFC417** RB FFC41B Read Input Port for DCD (IP4) RB Procedure: To set-up the RS-232 Port, the following steps may be used: WB søø to SFFC4ØB Set Interrupts OFF Set BRG to SET 2 WB SFØ to SFFC409 Set Counter-Timer to XTAL divided by 16 Set DELTA Interrupts OFF Set Baud Rate for XMIT and RECV WB SXX to SFFC413 \$44 = 300 BPS\$55 = 600 BPS\$66 = 1200 BPS\$88 = 2400 BPS\$99 = 4800 BPSSBB = 9600 BPSSCC = 19200 BPS \$40 to \$FFC415 Reset Error Status WB Disable XMIT and RECV WB \$20 to \$FFC415 Reset RS-232 Receiver \$15 to \$FFC415 WB Reset Mode Reg. Pointer Enable XMIT and RECV \$XX to \$FFC411 Set Mode Register 1 WB \$02 = 7 Bits/Char, Even Parity \$06 = 7 Bits/Char, Odd Parity \$ØA = 7 Bits/Char, Mark Parity \$ØE = 7 Bits/Char, Space Parity \$12 = 7 Bits/Char, No Parity \$16 = 7 Bits/Char, No Parity WB \$XX to \$FFC411 Set Mode Register 2 \$07 = Normal Mode, 1 Stop Bit \$47 = Auto Echo Mode, 1 Stop Bit \$87 = Local Loopback Test Mode, 1 Stop Bit \$C7 = Remote Loopback Test Mode, 1 Stop Bit

RS-232 (cont'd) To operate the RS-232 Port, the following commands may be used: If DCD (Data Carrier Detect) checking is desired, then: RB \$FFC41B Get Input Port Byte Test to see if bit  $\tilde{4}$  is a  $\emptyset$ , if so, DCD is ON RB \$FFC413 Get Status Bit  $\emptyset$  = RECV Ready Bit 1 = RECV Holding Reg. Full Bit 2 = XMIT Ready Bit 3 = XMIT Holding Reg. Empty Bit 4 = Overrun Error Bit 5 = Parity Error Bit 6 = Framing Error Bit 7 = Recvd Break RB \$FFC417 Get RECV Character WB \$FFC417 Put XMIT Character

Parallel Printer Port

FFC41D WB Write Printer Data Byte to SET Printer Port Latches FFC41F WB Write Printer Data Byte to RESET Printer Port Latches

FFD801 WB Write Printer Strobe

Procedure:

Initialize the Printer Port by writing a  $\emptyset\emptyset$  (Hex) to the Output Port Config. Register (FFC41B).

Test the Input Port (FFC41B) to determine if the Printer is READY by examining bit  $\emptyset$  (IP $\emptyset$ ). If bit  $\emptyset$  is  $\emptyset$ , then the Printer is ready.

Reset the Printer Port Latches by writing a FF (Hex) to the RESET Printer Port (FFC41F).

Write the data (the character) that is to be sent to the Printer to the SET Printer Port (FFC41D).

Set the STROBE bit by writing anything to the Write Printer Strobe location (FFD801). The Write Printer Strobe location causes the activation of a one-shot circuit which generates the printer strobe.

On the MAIN Printed Circuit Board (Mother Board) is a Jumper Pin Connector (J13) which allows the Parallel Printer Port to be configured so that the AUTO LINE FEED \* signal can be set to a " $\emptyset$ " (GROUND or  $\emptyset$ V) or to a "1" (LOGIC +5). The Jumper Pins are designated pins 1, 2, and 3. Pin 2 is the middle pin. If the Jumper Plug is placed on pins 3 and 2, then the AUTO LINE FEED \* is enabled and a line feed character will be inserted after every carriage return character. If the Jumper Plug is placed on pins 1 and 2, then the AUTO LINE FEED is disabled and NO line feed is inserted.

Speaker

FFC800 RB Toggle Speaker

Procedure:

Each time the speaker is toggled, the speaker cone will make a transition either in or out. Under software control the frequency can be varied between  $\emptyset$  Hz and 25K Hz.

. .

Game Control

| FFCCØØ | RB | Reset  | Timers | 5 |
|--------|----|--------|--------|---|
| FFCC11 | RB | Read S | Switch | Ø |
| FFCC13 | RB | Read S | Switch | 1 |
| FFCC15 | RB | Read S | Switch | 2 |
| FFCC17 | RB | Read S | Switch | 3 |
| FFCC19 | RB | Read H | addle  | 1 |
| FFCClB | RB | Read H | addle  | 2 |
| FFCClD | RB | Read H | Paddle | 3 |
| FFCClF | RB | Read H | Paddle | 4 |

Procedure:

Reading a switch byte will result in a negative number, if the switch is in the closed (pressed) position, and a positive number if the switch is in the open (released) position. To read the paddle position, first the Reset Timers command is executed, followed by reading the desired paddle. A timing loop is executed, to determine the time required for each paddle to change from a negative (not ready) to a positive (ready) number. The timing loop should be set to give a result of Ø when the timer goes positive immediatly, and +255 when the timer takes the maximum time.

Example

| * * * * * * * * * * * * * * * * * * * * | ***                             |
|-----------------------------------------|---------------------------------|
| *                                       | *                               |
| * Ø = Low Resistance (CCW)              | *                               |
| * 255 = High Resistance (CW)            | *                               |
| *                                       | *                               |
| * d2 = Paddle number to chec            | <b>レ *</b>                      |
| *                                       | *                               |
| *********                               | -                               |
|                                         | 0 0 0 0                         |
| and #3,d2                               |                                 |
| lsl #1,d2                               |                                 |
| move #255,dl                            |                                 |
| clr dØ                                  |                                 |
| move.l \$ffcc19,aØ                      |                                 |
| a: tst.b Ø(aØ,d2)                       | wait til last timer if finished |
| bmi a                                   |                                 |
| tst.b \$ffccØØ                          | start timer                     |
| b: $tst.b $ $\emptyset(a\emptyset,d2)$  | test if finished                |
| bpl c                                   |                                 |
| nop                                     |                                 |
| nop                                     |                                 |
| nop                                     |                                 |
| nop                                     |                                 |
| add #1,dØ                               |                                 |
| dbra dl,b                               |                                 |
|                                         | a 255 xanaa ******              |
| c: ******** dØ holds result             | Ø - 255 range *******           |

Floppy Disk

The controller is an NEC uPD765A, and for a detailed description refer to the NEC Data Sheets.

FFDØØ1 RW Read Status

Reading the status returns the status of the INT (Interrupt Flag) in the Most Significant Bit (MSB =  $\emptyset$ ) is zero then INT is set, MSB = 1 is INT reset. The least significant 8 bits are the contents of the Main Status Register (contents of the disk controller).

FFD003 RB Read Data Register Byte FFD003 WB Write Data Register Byte

\_\_\_\_\_

Read and write the Controller Register data registers, as defined in the detailed specification sheets. The Controller may be programmed for 5 1/4" Floppies in the FM (standard) or MFM (double density) modes using non-DMA modes only.

FFDØØ5 WB Write Control BYte

----

The control byte selects the drive, turns the motor ON or OFF, and outputs the terminating character flag on or off.

| BITS  | FUNCTION                                          |        |
|-------|---------------------------------------------------|--------|
| x Ø   | Select Drive Ø                                    |        |
| x x l | Select Drive l                                    |        |
| хØх   | Turn Selected Drive Motor OFF<br>disable Disk Bus | and    |
| x l x | Turn Selected Drive Motor ON and<br>Disk Bus      | enable |
| Øхх   | Terminating Character Flag OFF                    |        |
| 1 x x | Terminating Character Flag ON                     |        |
|       |                                                   |        |

The Terminating Character Flag should be turned ON for one instruction time at the completion of transferring the requested number of bytes of read or write data and then turned immediatly OFF. The controller will complete the read or write execution phase by itself. At the completion of the read or write execution phase, the results registers may be read. Emulation Control

| FFD4ØØ | RW | Read LSB of Trap Address           |
|--------|----|------------------------------------|
| FFD4Ø1 | WB | Disable Write Configuration Memory |
| FFD4Ø2 | RB | Read MSB of Trap Address           |
| FFD4Ø3 | WB | Enable Write Configuration Memory  |

Procedure:

To set up the Emulation Memory;

(1) Set the addresses that are to be trapped by writing, to address FFD403, a byte that has data bit 0 (the LSB) set to 1.

Then, read the data from each location in memory whose address is to be trapped. The addresses to be trapped must be in the lowest 512K bytes of memory (i.e. in the range from 000000 to 07FFFF).

When all of the locations have been read that are to be trapped, then write to address FFD401 a byte that contains all zeroes.

(2) Set the addresses that are not to be trapped by writing, to address FFD403, a byte that has data bit 0 (the LSB) set to 0.

Then, read the data from each location in memory whose address is not to be trapped. These address must also be in the lower 512K bytes of memory.

When all of the locations have been read that are not to be trapped, then write to address FFD401 a byte that contains all zeroes.

When a TRAP on a memory location is enabled, an access to that memory location will cause the EMULATION STROBE line to be pulsed to a high (+5 logic level) so as to stop the coprocessor. The emulation routine will have to determine the address that was trapped by the following steps:

- Read, from address FFD400, the LSW (Least Significant Word) of the address of the location that was trapped.
- Read, from address FFD402, the MSB (Most Significant Byte) of the address of the location that was trapped.

After execution of the above steps, the emulation routine will have the 24 bit address of the location that was trapped. The emulation routine then will have to determine the appropriate action to take. After the routine has taken the appropriate action, the routine must restart the co-processor.

DIRECT I/O

Printer Strobe

FFD8Ø1 WB Write Printer Strobe

Procedure:

When the Write Printer Strobe location is written to (with any data), a one-shot circuit is activated which generates the printer strobe.

Memory Switch

FFDC00 RB Switch Memory and I/O Addresses

Procedure:

The MC68000 processor requires that the intial power-up reset vectors by located at locations 0000000 through 0000007. Since these are required to be in ROM for initial power-up, the ROM and I/O are initially mapped into the addresses 0000000 through 000FFFF. The initial power-up routine then moves the initialization routines to locations 0010000 up in RAM and jumps to it. At the execution of the Switch Memory command, the ROM addresses will be mapped to locations FF0000 through FFFFFF, the CRT Controller to FF8000 and Peripherals to FF9000 through FFFFFF. APPENDIX F

ROMBIOS

## ROMBIOS

This Section contains information on the basic software contained within the System. This software is contain in Read Only Memory (ROM) and is used by the System during start/restart operations.

ROMBIOS is the abbreviation for ROM Based Input/Output System. The contents of ROMBIOS permit the user to create programs utilizing the functions and features of the System without having to repeat the instructions necessary to perform read/write operations to the System's I/O devices.

ROMBIOS is located in the standard System ROMs. The functions available are:

Screen Display
Floppy Disk System
Keyboard

These functions are interfaced through a common standarized structure with a standard address of  $FF\emptyset 1\emptyset\emptyset$  (hex). In each case the DØ register of the CPU is loaded with a 16 bit code which identifies the function.

Additional registers may be loaded with the parameters described below, if required. These registers are loaded before ROMBIOS is called.

ROMBIOS FUNCTION CODES (set in register DØ - word mode)

 $\emptyset$  = Unused Function - immediately returns

- 1 = Initialize CRT Controller
- 2 = Output a character to the screen
- 3 = Clear the TEXT screen
- 4 = Read a key stroke
- 5 = Get keyboard status
- 6 = Boot from disk
- 7 = Start the built-in monitor
- 8 = Read selected disk drive status
- 9 = Select disk drive and turn motor ON

10 = Deselect disk drive and turn motor OFF 11 = Seek to selected disk track 12 = Seek to track  $\emptyset$  and recalibrate disk - rezero 13 = Seek to track and read a sector 14 = Seek to track and write a sector 15 = Seek to track and format a track 16 = Format the entire disk 17 = Read the sector ID information 18 = Read the disk status 19 = Reserved $2\emptyset$  = Reserved 21 = Read Printer Status 22 = Output a character to Printer Interface 23 = Position CRT cursor 24 = Read character at present CRT cursor location 25 = Clear Graphics Screen 26 = Set graphics color 27 = Plot X, Y point28 = Reserved29 = Read color at designated point 30 = Output Character to CRT with No Control Characters

The following is a detailed description of the ROMBIOS Function Codes. In the following descriptions, the contents of the registers are UNDE-TERMINED, unless specified. Each description provides the contents of the registers used by the Function Codes both at the beginning of the Function and at the end of the Function. The final register contents are provided after a JSR \$FF0100 or JSR ROMBIOS instruction. Function Code  $\emptyset$  = Unused

Initial Register Contents:

Not Used

Final Register Contents:

Unchanged

Function:

This function returns immediately to the caller.

Function Code 1 = Initialize CRT Controller

Initial Register Contents:

DØ = 1 (word mode) AØ = Address of CRT Table (longword mode)

Final Register Contents (after JSR \$FF0100 or JSR ROMBIOS.)

AØ = Initial Value (longword mode)

Function:

This function writes the contents of the CRT Table to the CRT Controller and switches the CRT to the requested mode. It also calculates the longword values for MAX LENGTH, LINE LENGTH, PRESENT CHARACTER POINTER and CRT BUFFER ADDRESS and stores them in the CRT Table.

Anytime this function is called, the address of the CRT Table is placed into location ØØØ1FA. Additionally, when this function is called with the Mode Byte set for TEXT, the address of the CRT Table will be placed into location ØØØ1EA. Function Code 2 = Output a character to the CRT screen

Initial register contents:

 $D\emptyset = 2$  (word mode)

D1 = ASCII character value (output character)(word mode)

Final register contents:

Undetermined

Function:

Places the character (indicated by its ASCII value) on the screen at the next character location and moves the reverse video cursor. The PRESENT CHARACTER POINTER value is incremented by 1.

If a character exceeds the end of a line, then an automatic advance to the start of the next line is generated. If the next character position would exceed the CRT Buffer (off of the bottom of the screen), then the entire CRT Buffer contents will be scrolled upward by 1 line and the last line will be blank filled.

If the value of DØ is equal to Ø8 (hex) (ASCII backspace), the PRESENT CHARACTER POINTER is decremented by 1 and the character in that position is displayed in reverse video. If the backspace would result in going beyond the start of the CRT Buffer, then the PRESENT CHARACTER POINTER is not decremented.

If the character in DØ is equal to ØD (hex) (ASCII Carrage Return), the next character position will immediately move to the start of the next line.

If the CRT is in graphics mode, then the following modifications occur:

- Reverse video cursor shown only when present character position exceeds graphics/text switch point. (text CRT parameter table +16 location)
- When scroll is required, then scroll functions extends from bottom of the screen to the graphics/text switch point.

Function Code 3 = Clear the TEXT Screen

Initial Register Contents:

 $D\emptyset = 3$  (word mode)

Final Register Contents:

Undefined

Function:

Clears the TEXT screen buffer (all blanks). This routine leaves the cursor and the PRESENT CHARACTER POINTER positioned at the upper left hand corner of the screen.

Function Code 4 = Read Key From Keyboard

Initial Register Contents:

 $D\emptyset = 4$  (word mode)

Final Register Contents:

 $D\emptyset$  = ASCII code for key (word mode)

Function:

This function does the following steps:

- waits until a key is pressed

- gets the ASCII code for the key

- puts the ASCII code in register DØ
- returns

Function Code 5 = Get Keyboard Status

Initial Register Contents:

 $D\emptyset = 5 \pmod{\text{mode}}$ 

Final Register Contents:

DØ = Status (word mode)

Function:

Determines the status of the keyboard and returns the READY/NOT READY Flag to the DØ register.

If a key has been pressed but not read, then the DØ register will be set to 0000 (hex) to denote keyboard ready.

If no key has been pressed since the last Read Keyboard Function, then the keyboard is not ready and DØ will be set to ØØFF (hex).

Function Code 6 = Boot From Disk

Initial Register Contents:

 $D\emptyset = 6$  (word mode)

Final Register Contents:

Unknown

Function:

The Boot Routine reads disk sector  $\emptyset$ , track  $\emptyset$  from the disk defined by the Boot Disk Parameter Table, located in addresses  $\emptyset\emptyset\emptyset$ lCC to  $\emptyset\emptyset\emptyset$ lF5 (hex), and loads the data read into memory starting at location  $\emptyset1\emptyset\emptyset\emptyset\emptyset$ (hex). At the successful completion of the read, program control is given to the instructions starting at location  $\emptyset1\emptyset\emptyset\emptyset\emptyset$  (hex). Normally, the first sector contains instructions to read the rest of track  $\emptyset$ , which is the Boot Loader for the installed Operating System. Function Code 7 = Start built-in Monitor

Initial Register Contents:

 $D\emptyset = 7 \pmod{\text{mode}}$ 

Final Register Contents:

Unknown

Function:

This function will invoke the ROM resident Monitor. To use minimum space on the stack this function may be JUMP'ed to instead of being called. The only way to return from this mode is to have the operator reboot the System or to go to a user specified location in the calling program. Function Code 8 = Get Drive Status From Selected Disk

Initial Register Contents:

 $D\emptyset$  = 8 (word mode) A\emptyset = Address of Disk Parameter Table (longword mode)

Final Register Contents:

DØ = Drive Status Byte AØ = Initial Value (longword mode)

Function:

This function assumes that the drive is selected and the motor is ON. After execution, the DØ register contains a status byte whose bit values define the following conditions:

Bit 7 6 5 4 3 2 1 Ø

X X = Selected Disk Drive l = disk head number l = disk drive is two-sided l = disk drive at Track Ø l = disk drive Ready l = disk drive is Write Protected l = disk drive Hard Fault Function Code 9 = Select Disk and Turn Motor ON

Initial Register Contents:

- $D\emptyset = 9$  (word mode)
- AØ = Address of Selected Disk Parameter Table (longword mode)

Final Register Contents:

AØ = Initial Value (longword mode)

Function:

Using the contents of the Disk Parameter Table, this function selects the appropriate floppy disk drive and turns the motor ON, if required. If the contents of the table  $+23 = \emptyset$  (disk motor ON flag), then the motor was OFF, so turn the motor ON, set the Motor ON Flag and wait until an index mark is detected and then return. If the Motor ON Flag was set to non-zero, then immediatly return.

## Additional Information:

All of the disk functions require that the AØ register be set to the starting address of the Disk Parameter Table for that particular disk. Normally each disk drive in the System will have it's own Disk Parameter Table. The format for the Disk Parameter Table is given later in this Section. ....

Function Code 10 = Deselect Disk Drive and Turn OFF Motor Initial Register Contents: D0 = 10 (word mode) A0 = Disk Parameter Table address (longword mode) Final Register Contents: A0 = Initial Value (longword mode) Function: This function does the following: - deselect the Disk Drive defined by the Disk Parameter Table - turn the motor OFF - set the MOTOR ON FLAG in the Table to OFF

- return

Function Code 11 = Seek to Selected Track Initial Register Contents: DØ = 11 (word mode) AØ = Disk Parameter Table address (longword mode) Final Register Contents: AØ = Initial Value (longword mode) Function: This function does the following: - assumes that the selected drive motor is ON - moves the head to the new selected track location on the selected drive. - returns This function is of limited value since; - only one drive at a time can be selected

- the read or write functions automatically perform a seek to track.

Function Code 12 = Seek to Track Ø and Recalibrate (rezero)

Initial Register Contents:

 $D\emptyset = 12$  (word mode) A $\emptyset = Disk$  Parameter Table address

Final Register Contents:

 $A\emptyset$  = Initial Value (longword mode)

Function:

This function does the following:

- assumes that the selected disk motor is ON

- rezeroes the disk controller by moving the disk head to the track  $\, \varnothing \,$  location.

Function Code 13 = Seek to Track and Read a Sector Initial Register Contents:  $D\emptyset = 13 \pmod{\text{mode}}$  $A\emptyset$  = Disk Parameter Table address (longword mode) Final Register Contents:  $A\emptyset$  = Initial Value (longword mode) Function: This function does the following: - assumes that the disk drive motor is ON - seeks to the requested track - gets the number of data bytes to read in from either the Bytes/Sector value in the Disk Parameter Table or the Data Bytes/Sector value in the Disk Parameter Table - reads the number of data bytes requested into the buffer address which is defined in the Disk Parameter Table - loads the appropriate status bytes and disk parameters into the Disk Parameter Table.

- returns

Function Code 14 = Seek To Track and Write a Sector

Initial Register Contents:

DØ = 14 (word mode) AØ = Disk Parameter Table address

Final Register Contents:

AØ = Initial value (longword mode)

Function:

This function assumes that the disk drive is selected and that the motor is ON. The drive will seek to the requested track and sector and then the number of user specified bytes will be written from the buffer defined in the Disk Parameter Table. At the completion of the write function, the disk status will be returned to the Disk Parameter Table. Function Code 15 = Seek To and Format a Track

Initial Register Contents:

DØ = 15 (word mode)
D3 = Disk Interlace Table address (longword mode)
AØ = Disk Parameter Table (longword mode)

Final Register Contents:

AØ = Initial Value (longword mode)

Function:

This function assumes that the requested disk is selected and that the motor is ON. The disk drive will seek to the requested track and after the index mark is detected will write the ID data and format data (E5 hex) in the sector. The Sector ID will be the value in the first byte in the Disk Interlace Table. At the completion of writing the previous sector, the Sector ID will be taken from the next value in the Disk Interlace Table. This sequence continues until all of the sectors have been written or until another index mark is detected. The use of the Sector Interlace Table allows the logical sectors to be linearly increasing while the physical placement allows for interlace processing time.

Function Code 16 = Format Entire Disk

Initial Register Contents:

DØ = 16 (word mode)
D3 = Disk Interlace Table address (longword mode)
AØ = Disk Parameter Table (longword mode)

Final Register Contents:

 $A\emptyset$  = Initial Value (longword mode)

Function:

This function will select the requested drive, and turn the motor ON. The function will format the entire disk, starting at track  $\emptyset$  on the selected head. At the completion of the format function the motor will be turned OFF and the drive deselected.

Function Code 17 = Read Sector ID Information

Initial Register Contents:

DØ = 17 (word mode)
AØ = Disk Parameter Table address (longword mode)

Final Register Contents:

AØ = Initial Value (longword mode)

Function:

This function assumes that the requested drive is selected and that the motor is ON. When the first sector mark is located, the data in the Sector ID is read and written into the location specified by the Disk Parameter Table.

Function Code 18 = Return Disk Error Status

Initial Register Status:

DØ = 18 (word mode) AØ = Disk Parameter Table address (longword mode)

Final Register Contents:

Function:

This function sets the DØ register if an error is detected in the previous disk function. If the DØ register is non-zero, then the appropriate status bytes in the Disk Parameter Table can be interrogated to determine the cause of the error. Function Code 19 = Reserved

Initial Register Contents:

Not Used

Final Register Contents:

Unchanged

Function:

This function is Reserved for later use.

Function Code 20 = Reserved
Initial Register Contents:
Not Needed
Final Register Contents:
Unchanged
Function:
This function is Reserved for later use.

. -

Function Code 21 = Read Printer Status

Initial Register Contents:

 $D\emptyset = 21$  (word mode)

Final Register Contents:

Unknown

Function:

This function returns the status of the built-in Printer Interface. If  $D\emptyset = \emptyset$  then the printer is ready. If bit 7 is set, then the printer is busy. If bit 6 is set, then the printer is off-line or not available.

Function Code 22 = Output Character to Printer Interface

Initial Register Contents:

DØ = 22 (word mode)
D1 = ASCII character to be sent to the Printer Interface (word mode)

Final Register Contents:

Unknown

Function:

Waits until the Printer Interface can accept a character and then outputs the character to the Centronics Type Parallel Interface.

Function Code 23 = Position CRT Cursor

Initial Register Contents:

DØ = 23 (word mode) D1 = Column coordinate of cursor (X axis) (word mode) D2 = Line coordinate of cusor (Y axis) (word mode)

Final Register Contents:

AØ = Address of CRT Table (longword mode)

Function:

This function moves the CRT cursor to the position indicated by the Dl and D2 registers. If the cursor is positioned outside the allowable dimensions, then the cursor will be placed at the closest legal X or Y position, respectively (if Dl is greater than characters per line or D2 is greater than the number of lines, or if either is less than l).

The upper left hand corner of the screen is position (1,1).

Function Code 24 = Read Present Character

Initial Register Contents:

 $D\emptyset = 24$  (word mode)

Final Register Contents:

DØ = Present Character (byte mode) AØ = Address of CRT Table (longword mode)

Function:

This function will return the ASCII value of the character that is located at the position that is defined by the present cursor position. Function Code 25 = Clear Graphics Screen

Initial Register Contents:

 $D\emptyset = 25$ 

Final Register Contents:

Unknown

Function:

This function clears the graphics screen.

NOTES:

This function should only be used in GRAPHICS MODE.

The CRT controller MUST be initialized in GRAPHICS MODE before using this function.

Function Code 26 = Set Color Initial Register Contents: DØ = 26 (word mode) D1 = Color Code (word mode) Final Register Contents: AØ = Present Screen Address (longword mode) Function: This function sets the Color Code into the Present Color Byte NOTES:

This function should only be used in GRAPHICS MODE.

The CRT Controller MUST be initialized in GRAPHICS MODE before using this function.

Function Code 27 = Plot X, Y Point

Initial Register Contents:

DØ = 27 (word mode) D1 = X Coordinate (word mode) D2 = Y Cooridante (word mode)

Final Register Contents:

AØ = Present Screen Address(longword mode)

Function:

This function plots a point at the designated X and Y coordinates using the color identified in the Present Color Byte. If the CRT mode is black and white, then the point will be a single pixel at the closest actual coordinate. If the mode is color, then the point will be on the correct scan line but will be placed in the closest horizontal point that can be aliased into the color. Multiple color points, plotted close together, may exhibit color changes depending on the equivalent pixel color point. The values of the X, Y coodinates are defined as a minimum pixel, therefore in the highest resolution mode the X coordinate may be from  $\emptyset$  through 700. Functin Code 28 = Reserved

Initial Register Contents:

 $D\emptyset = 28$  (word mode)

Final Register Contents

Unchanged

Function

This function is Reserved for later use.

• •

Function Code 29 = Read a Pixel Initial Register Contents: DØ = 29 (word mode) D1 = X coordinate (word mode) D2 = Y coordinate (word mode) Final Register Contents: DØ = Color Mode (word mode) AØ = Present Screen Address (longword mode)

Function:

This function reads the color value at the requested X, Y coordinate and returns the value in the DØ register.

Function Code 30 = Output a Character Directly to CRT with NO Control Characters

Initial Register Contents:

DØ = 3Ø (word mode)
D1 = character (word mode)

Final Register Contents:

 $A\emptyset$  = Address of CRT Table

Function:

This function outputs the character in the Dl register to the CRT screen, directly, with NO control characters.

CRT Table Address Offsets +Ø = 1 byte MODE Bit  $7 = \emptyset$ Text mode (byte mapped, hardware character generation = 1 Graphics mode (bit mapped, 1 bit per pixel) 8 bits per character or graphics byte Bit  $6 = \emptyset$ 7 bits per character or graphics byte = 1 Bit  $5 = \emptyset$ CRT and CPU asynchronous with each other CRT and CPU operate synchronously (used in 80 -= 1 100 column mode) Bits 4,3 CRT dot clock frequency 14 MHz  $= \emptyset \emptyset$ = Ø1 7 MHz = 104.77 MHz 3.58 MHz = 11 Bit  $2 = \emptyset$ CRT ON CRT BLANKED = 1 Bit  $1 = \emptyset$ Low Order 256 Character Set High Order 256 Character Set = 1 Bit  $\emptyset = \emptyset$ Monochrome (Black & White) = 1 Color = 1 byte Most Significant Byte (bits 23 - 16) of CRT Buffer addr. +1 +2 = 1 bvte Maximum horizontal character count (RØ) Number of displayed characters per line (R1) +3 = 1 byte Start of horizontal sync position, in character times (R2) +4 = 1 byte +5 = 1 byte Horizontal sync width, in character times (R3) Number of character rows, in vertical direction (R4) +6 = 1 byte +7 = 1 byte Number of scan lines, to adjust vert. freq. (50/60Hz) (R5) Number of vertically displayed rows (R6) +8 = 1 byte +9 = 1 byte Vertical sync position, in row count (R7) Interlace mode (R8) +10 = 1 byte =  $\emptyset$  for non-interlace = 3 for interlace Number of scan lines for a character box minus one (R9) +11 = 1 byte (must be an odd value for interlace mode) Position in character scan to start graphics/text switch +12 = 1 byte (R1Ø) (normally set =  $\emptyset$ ) +13 = 1 byte Width in scan lines -1 of graphics/text start (R11) (normally set =  $\emptyset$ ) Low order CRT Buffer Address (R12-R13) (bits 15 - Ø) +14 = 2 byte +16 = 2 byte Low order CRT Buffer Address where switch from graphics to text takes place (R14-R15) +18 = 2 byte Low order CRT Buffer Address of Light Pen position (R16-R17)

CRT Table Address Offsets (cont'd)

| calculated by the initialize CRT function                    |    |
|--------------------------------------------------------------|----|
|                                                              |    |
| Value = Chars/Line * Lines/Screen                            |    |
| +24 = 4 byte Length of CRT line in bytes                     |    |
| calculated by initialize CRT function                        |    |
| The value is equal to characters/line.                       |    |
| +28 = 4 byte Present character position address in CRT Buffe | er |
| must be within CRT buffer area.                              |    |
| +32 = 4 byte CRT Buffer starting address                     |    |
| calculated by initialize CRT function.                       |    |

Graphics Extensions to CRT Table

These parameters are set up by the Initialize CRT Controller Function (function code = 1) when the Mode Byte is set to Graphics (bit 7 = 1).

| +36 = 1 byte | Present Color Byte<br>Values (hex) for COLOR                           |
|--------------|------------------------------------------------------------------------|
|              | $\emptyset\emptyset$ = Black $\emptyset$ 8 = Dark Aqua                 |
|              | $\emptyset$ l = Dark Blue $\emptyset$ 9 = Bright Blue                  |
|              | $\emptyset 2 = \text{Red}$ $\emptyset A = \text{Grey}$                 |
|              | Ø3 = Magenta ØB = Light Blue                                           |
|              | Ø4 = Dark Green ØC = Green                                             |
|              | Ø5 = Grey ØD = Aqua                                                    |
|              | $\emptyset 6 = \text{Orange} \qquad \emptyset E = \text{Yellow}$       |
|              | Ø7 = Pink $ØF = White$                                                 |
| +38 = 2 byte | Xmax = Number (n) of Bytes (columns) Displayed * 8<br>(Xmax = n * 8)   |
|              | = Number of Bits Displayed                                             |
| +4Ø = 2 byte | Ymax = Number of Rows * Number of Scans *<br>Interlace Factor (1 or 2) |

Disk Parameter Table \_\_\_\_\_\_ Reference: The NEC µP765A Data Sheets +Ø = 1 byte Disk Select Code Bits 7 (LSB) & 6 - DON'T CARE Bit 5 - TC pulsed to 1 to indicate end of block transfer to the 765 controller chip Bit 4 - DATA RATE  $\emptyset = 8$  Inch Data Rate 1 = 5 1/4 Inch Data Rate Bits 3 & 2 - DRIVE NUMBER DRIVE SIZE \_\_\_\_\_ DRIVE 5 1/4 | 8 INCH INCH NUMBER \_+\_\_\_\_+ ØØ DRIVE A DRIVE E DRIVE B DRIVE F Ø1 DRIVE C DRIVE G 10 11 DRIVE D DRIVE H +\_\_\_\_+ Bits 1 & Ø (LSB) - DRIVE SIZE  $\emptyset \emptyset = INVALID$  $\emptyset 1 = 5 1/4$  Inch 10 = INVALID11 = 8 Inch +1 = 1 byte Disk Step Rate and Head Unload Time parameters used by the SPECIFY command Bits 7 (MSB) to 4 - Disk Step Rate where DSR = Disk Step Rate = number of 1 mS. steps minus 1  $\emptyset \emptyset 1 \emptyset = 2 + 1 = 3 \text{ mS}.$ example Bits 3 to Ø (LSB) - Head Unload Time where HUT = Head Unload Time = number of 16 mS. steps minus 1 example 0010 = (2 + 1) \* 16= 3 \* 16 = 48 mS.

Disk Parameter Table (cont'd) \_\_\_\_\_ +2 = 1 byte Disk Head Load Time value and Non-DMA Flag Bits 7 (MSB) to 1 - Head Load Time where HLT = Head Load Time = number of 16 mS. steps minus 1 example 0000010 = (2 + 1) \* 2= 3 \* 2 = 6 mS. Load Time +3 = 1 byte Disk Mode and Command parameter, set up by ROMBIOS this is the uP765 command most significant byte Bit 7 (MSB) - Multi-Track  $\emptyset$  = Not Multi-Track 1 = Multi-Track Read or Write Bit 6 - MF  $\emptyset = FM Mode$ 1 = MFM ModeBit 5 - Skip Deleted Data Ø = Terminate on a Deleted Data Address Mark 1 = Skip over a Deleted Data Address Mark Bits 4 to Ø (LSB) - Command 00000 - 00001 = INVALID00010 = READ A TRACK = SPECIFY 00011 = SENSE DRIVE STATUS 00100 = WRITE DATA ØØ1Ø1 = READ DATA ØØ11Ø ØØ111 = RECALIBRATE 01000 = SENSE INTERRUPT STATUS = WRITE DELETED DATA 01001 = READ ID 01010 Ø1Ø11 = INVALID Ø11ØØ = READ DELETED DATA Ø11Ø1 = FORMAT A TRACK = INVALID Ø111Ø Ø1111 = SEEK 10000 = INVALID 10001 = SCAN EQUAL 10010 - 11001 = INVALID= SCAN LOW OR EQUAL 11001 11010 - 11100 = INVALID11101 = SCAN HIGH OR EQUAL 11110 - 11111 = INVALID

Disk Parameter Table (cont'd) \_\_\_\_\_ +4 = 1 byte Disk Head Select/Drive Select Code, set up by ROMBIOS this is the uP765 command least significant byte Bits 7 (MSB) to 3 - Zeroes 00000 = Zeroes Bit 2 - Head Select  $\emptyset$  = Head  $\emptyset$ 1 = Head 1Bit 1 to Ø - Unit Select  $\emptyset\emptyset = \text{Drive }\emptyset$  $\emptyset$ l = Drive l  $1\emptyset = Drive 2$ 11 = Drive 3+5 = 1 byte Disk Cylinder Address (track) the range is Ø to 255 +6 = 1 byte Disk Head Select the range is Ø to 1 = 1 byte Disk Sector Address +7 Disk Sector Size = 128 \* 2 ^ N bytes/sector +8 = 1 byte where DSS = Disk Sector Size in 128 Byte steps minus 1  $\emptyset$ 3 (hex) = 128 \* 2 ^ 3 example = 128 \* 8 = 1024 Bytes/Sector +9 = 1 byte Disk Sectors/Track (or End Of Track count value) +10 = 1 byte Disk Sector Gap Length +11 = 1 byte Sector Data Length, set to FF (hex), unless Disk Sector Size is set to  $\emptyset$ , then this is bytes per sector Disk Data Buffer Address, starting address of buffer +12 = 4 byte to be read/written

| Disk Paramete | r Table (cont'd)                                         |
|---------------|----------------------------------------------------------|
| +16 = 1 byte  | Status Ø byte, from last operation                       |
| +17 = 1 byte  | Status 1 byte, from last operation                       |
| +18 = 1 byte  | Status 2 byte, from last operation                       |
| +19 = 1 byte  | Cylinder Address, read from Disk ID                      |
| +20 = 1 byte  | Next Head Address                                        |
| +21 = 1 byte  | Next Sector Address                                      |
| +22 = 1 byte  | Disk Sector Size value, read from Disk ID                |
| +23 = 1 byte  | Motor ON Flag, set to $\emptyset$ if OFF, set to 1 if ON |
| +24 = 1 byte  | Disk Steps/Track value = 2^N steps/track                 |
| +25 = 1 byte  | Number of Tracks Per Side value                          |

SYSTEM REFERENCE MANUAL

 D
 I
 M
 E
 N
 S
 I
 O
 N
 6
 8
 Ø
 Ø
 Ø

 S
 Y
 S
 T
 E
 N
 R
 E
 R
 E
 N
 C
 E
 M
 A
 N
 U
 A
 L

INDEX

# INDEX

| Central Processor<br>Connectors<br>CP/M-68K<br>CRT<br>Cursor | 7<br>15, 17, 18, 20, 21, 22<br>34, 37, 39<br>10, 25, 35, 44<br>43 |
|--------------------------------------------------------------|-------------------------------------------------------------------|
| Disk Drive Expansion                                         | 17, 19                                                            |
| Emulators<br>6512<br>8086<br>280<br>Expansion Slots          | 9<br>9<br>9<br>7, 9, 11, 29                                       |
| I/O Devices                                                  | 7, 10, 39, 45                                                     |
| Keyboard                                                     | 7, 9, 23, 33, 35                                                  |
| MC68000L8<br>Monitor                                         | 27<br>34                                                          |
| Power<br>Power Supply Assembly                               | 8<br>7, 9, 15                                                     |
| RESET Switch<br>ROMBIOS                                      | 8, 16<br>9, 25, 34, 35, 37, 39                                    |
| System Unit                                                  | 16                                                                |

# APPENDIX G

MC68000 ASSEMBLY LANGUAGE

.

. .

.

The following material is excerpted from the MOTOROLA MC68000 MICROPROCESSOR USER'S GUIDE.

### **3.1 INTRODUCTION**

This section contains an overview of the form and structure of the MC68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

- Data Movement
- Integer Arithmetic
- Logical
- Shift and Rotate
- Bit Manipulation
- Binary Coded Decimal
- Program Control
- System Control

The complete range of instruction capabilities combined with the flexible addressing modes described in Section 2 provide a very flexible base for program development. Detailed information about each instruction is given in Appendix B.

# 3.2 DATA MOVEMENT OPERATIONS

The basic method of data acquisition (transfer and storage) is provided by the move (MOVE) instruction. The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to register. Address move instructions allow word and long word operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction, there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (LEA), push effective address (PEA), link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 3-1 is a summary of the data movement operations.

### **3.3 INTEGER ARITHMETIC OPERATIONS**

The arithmetic operations include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, with data operations accepting all operand sizes. Address operations are

| Instruction | Operand Size | Operation                                                             |
|-------------|--------------|-----------------------------------------------------------------------|
| EXG         | 32           | Rx ↔ Ry                                                               |
| LEA         | 32           | EA → An                                                               |
| LINK        | -            | $An \rightarrow SP @ -$<br>SP \rightarrow An<br>SP + d \rightarrow SP |
| MOVE        | 8, 16, 32    | (EA)s→ EAd                                                            |
| MOVEM       | 16, 32       | (EA) → An, Dn<br>An, Dn → EA                                          |
| MOVEP       | 16, 32       | $(EA) \rightarrow Dn$ $Dn \rightarrow EA$                             |
| MOVEQ       | 8            | #xxx → Dn                                                             |
| PEA         | 32           | ÆA→SP@-                                                               |
| SWAP        | 32           | Dn [31:16] ↔ Dn [15:0]                                                |
| UNLK        | -            | An → SP<br>SP@ + → An                                                 |

#### Table 3-1. Data Movement Operations

NOTES: s = source

d = destination

[ ] = bit numbers

limited to legal address size operands (16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long product, and a long word dividend with word divisor to produce a word quotient with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 3-2 is a summary of the integer arithmetic operations.

#### **3.4 LOGICAL OPERATIONS**

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 3-3 is a summary of the logical operations.

# **3.5 SHIFT AND ROTATE OPERATIONS**

Shift operations in both directions are provided by the arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand

| Instruction | Operand Size | Operation                     |
|-------------|--------------|-------------------------------|
| ADD         | 8, 16, 32    | Dn + (EA) → Dn                |
|             |              | (EA) + Dn → EA                |
|             |              | (EA) + #xxx → EA              |
|             | 16, 32       | An + (EA) → An                |
| ADDX        | 8, 16, 32    | $Dx + Dy + X \rightarrow Dx$  |
|             | 16, 32       | Ax@ – Aγ@ – + X → Ax@_        |
| CLR         | 8, 16, 32    | 0→EA                          |
| CMP         | 8, 16, 32    | Dn – (EA)                     |
|             |              | (EA) – #xxx                   |
|             |              | Αx@+-Αγ@+                     |
|             | 16, 32       | An – (EA)                     |
| DIVS        | 32 + 16      | Dn/(EA) → Dn                  |
| DIVU        | 32 + 16      | Dn/(EA) → Dn                  |
| EXT         | 8→16         | (Dn)8→ Dn16                   |
|             | 16           | (Dn)16-Dn32                   |
| MULS        | 16*16-32     | Dn*(EA) → 32 Dn               |
| MULU        | 16*16-32     | Dn*(EA) → Dn                  |
| NEG         | 8, 16, 32    | 0-(EA) → EA                   |
| NEGX        | 8, 16, 32    | $0 - (EA) - X \rightarrow EA$ |
| SUB         | 8, 16, 32    | Dn−(EA) → Dn                  |
|             |              | (EA) – Dn → EA                |
|             |              | (EA) – #xxx EA                |
|             | 16, 32       | An – (EA) 🛶 An                |
| SUBX        | 8, 16, 32    | $Dx - Dy - X \rightarrow Dx$  |
|             |              | Ax@ – – Ay@ – – X → Ax@       |
| TAS         | 8            | (EA) – 0, 1 → EA [7]          |
| TST         | 8, 16, 32    | (EA) – 0                      |

### Table 3-2. Integer Arithmetic Operations

NOTE: []= bit number

sizes and allow a shift count specified in the instruction of one or eight bits, or 0 to 63 bits specified in a data register.

Memory shifts and rotates are for word operands only and allow only single-bit shifts or rotates.

Table 3-4 is a summary of the shift and rotate operations.

| Instruction | Operand Size | Operation                                                                                                                            |
|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| AND         | 8, 16, 32    | $\begin{array}{c} Dn \Lambda (EA) \rightarrow Dn \\ (EA) \Lambda Dn \rightarrow EA \\ (EA) \Lambda \#xxx \rightarrow EA \end{array}$ |
| OR          | 8, 16, 32    | $\begin{array}{c} Dn \lor (EA) \rightarrow Dn \\ (EA) \lor Dn \rightarrow EA \\ (EA) \lor \#xxx \rightarrow EA \end{array}$          |
| EOR         | 8, 16, 32    | (Ea) ⊕ Dy → EA<br>(EA) ⊕ #xxx → EA                                                                                                   |
| NOT         | 8, 16, 32    | ~ (EA) → EA                                                                                                                          |

**Table 3-3. Logical Operations** 

~ = invert

SYSTEM REFERENCE MANUAL

| Instruction | Operand Size | Operation                                                                             |
|-------------|--------------|---------------------------------------------------------------------------------------|
| EXG         | 32           | Rx ↔ Ry                                                                               |
| LEA         | 32           | EA → An                                                                               |
| LINK        | -            | $An \longrightarrow SP @ -$<br>SP $\longrightarrow An$<br>SP + d $\longrightarrow$ SP |
| MOVE        | 8, 16, 32    | (EA)s→ EAd                                                                            |
| MOVEM       | 16, 32       | (EA) → An, Dn<br>An, Dn → EA                                                          |
| MOVEP       | 16, 32       | (EA) → Dn<br>Dn → EA                                                                  |
| MOVEQ       | 8            | #xxx → Dn                                                                             |
| PEA         | 32           | EA→ SP@                                                                               |
| SWAP        | 32           | Dn [31:16] ↔ Dn [15:0]                                                                |
| UNLK        | -            | $An \rightarrow SP$ $SP@ + \rightarrow An$                                            |

#### **Table 3-1. Data Movement Operations**

NOTES: s = source d = destination { ] = bit numbers

limited to legal address size operands (16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long product, and a long word dividend with word divisor to produce a word quotient with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 3-2 is a summary of the integer arithmetic operations.

#### **3.4 LOGICAL OPERATIONS**

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 3-3 is a summary of the logical operations.

#### **3.5 SHIFT AND ROTATE OPERATIONS**

Shift operations in both directions are provided by the arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand



Table 3-4. Shift and Rotate Operations

### **3.6 BIT MANIPULATION OPERATIONS**

Bit manipulation operations are accomplished using the following instructions: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 3-5 is a summary of the bit manipulation operations.

| Instruction | Operand Size                                                        | Operation        |
|-------------|---------------------------------------------------------------------|------------------|
| BTST        | 8, 32                                                               | ~bit of (EA) → Z |
| BSET        | 8, 32 $\sim$ bit of (EA) $\rightarrow$<br>1 $\rightarrow$ bit of EA |                  |
| BCLR        | 8, 32                                                               | ~bit of (EA) → Z |

8.32

 $0 \rightarrow bit of EA$ ~ bit of (EA)  $\rightarrow Z$ 

~ bit of (EA) - bit of EA

Table 3-5. Bit Manipulation Operations

#### **3.7 BINARY CODED DECIMAL OPERATIONS**

BCHG

Multiprecision arithmetic operations on binary coded decimal numbers are accomplished using the following instructions: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 3-6 is a summary of the binary coded decimal operations.

| <b>Table 3-6. Binary Coded Decimal Operations</b> | Table 3 | -6. Binar | / Coded | Decimal | Operations |
|---------------------------------------------------|---------|-----------|---------|---------|------------|
|---------------------------------------------------|---------|-----------|---------|---------|------------|

| Instruction | Operand Size | Operation                                                                           |
|-------------|--------------|-------------------------------------------------------------------------------------|
| ABCD        | 8            | $Dx_{10} + Dy_{10} + X \rightarrow Dx$ $Ax@ - 10 + Ay@ - 10 + X \rightarrow Ax@$    |
| SBCD        | 8            | $Dy_{10} - Dy_{10} - X \rightarrow Dx$<br>Ax@ - 10 - Ay@ - 10 - X $\rightarrow$ Ax@ |
| NBCD        | 8            | 0-(EA)10-X-+EA                                                                      |

### 3.8 PROGRAM CONTROL OPERATIONS

Program control operations are accomplished using a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 3-7.

The conditional instructions provide setting and branching for the following conditions:

- CC Carry Clear
- CS Carry Set
- EQ Equal
- F Never True
- GE Greater or Equal
- GT Greater Than
- HI High
- LE Less or Equal

- LS Low or Same
- LT Less Than
- MI Minus
- NE Not Equal
- PL --- Plus
- T Always True
- VC No Overflow
- VS Overflow

| Instruction   | Operation                                                        |
|---------------|------------------------------------------------------------------|
| Conditional   |                                                                  |
| Bcc           | Branch conditionally (14 conditions), 8- and 16-bit displacement |
| DBcc          | Test condition, decrement and branch. 16-bit displacement        |
| Scc           | Set byte conditionally (16 conditions)                           |
| Unconditional |                                                                  |
| BRA           | Branch always, 8- and 16-bit displacement                        |
| BSR           | Branch to subroutine, 8- and 16-bit displacement                 |
| JMP           | Jump                                                             |
| JSR           | Jump to subroutine                                               |
| Returns       |                                                                  |
| RTR           | Return and restore condition codes                               |
| RTS           | Return from subroutine                                           |

### Table 3-7. Program Control Operations

# **3.9 SYSTEM CONTROL OPERATIONS**

System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 3-8.

| Table 3-8. System Control Operation |
|-------------------------------------|
|-------------------------------------|

| Instruction     | Operation                      |
|-----------------|--------------------------------|
| Privileged      |                                |
| ANDI to SR      | Logical AND to status register |
| EORI to SR      | Logical EOR to status register |
| MOVE EA to SR   | Load new status register       |
| MOVE USP        | Move user stack pointer        |
| ORI to SR       | Logical OR to status register  |
| RESET           | Reset external devices         |
| RTE             | Return from exception          |
| STOP            | Stop program execution         |
| Trap Generating |                                |
| СНК             | Check register against bounds  |
| TRAP            | Trap                           |
| TRAPV           | Trap on overflow               |
| Status Register |                                |
| ANDI to CCR     | Logical AND to condition codes |
| EORI to CCR     | Logical EOR to condition codes |
| MOVE EA to CCR  | Load new condition codes       |
| MOVE SR to EA   | Store status register          |
| ORI to CCR      | Logical OR to condition codes  |

# **INSTRUCTION FORMAT SUMMARY**

### **C.1 INTRODUCTION**

This appendix provides a summary of the first word in each instruction of the instruction set. Table C-1 is an operation code (op-code) map which illustrates how bits 15 through 12 are used to specify the operations. The remaining paragraph groups the instructions according to the op-code map.

| Bits<br>15 through 12 | Operation                        | Bits<br>15 through 12 | Operation        |
|-----------------------|----------------------------------|-----------------------|------------------|
| 0000                  | Bit Manipulation/MOVEP/Immediate | 1000                  | OR/DIV/SBCD      |
| 0001                  | Move Byte                        | 1001                  | SUB/SUBX         |
| 0010                  | Move Long                        | 1010                  | (Unassigned)     |
| 0011                  | Move Word                        | 1011                  | CMP/EOR          |
| 0100                  | Miscellaneous                    | 1100                  | AND/MUL/ABCD/EXG |
| 0101                  | ADDQ/SUBQ/Scc/DBcc               | 1101                  | ADD/ADDX         |
| 0110                  | Bcc/BSR                          | 1110                  | Shift/Rotate     |
| 0111                  | MOVEQ                            | 1111                  | (Unassigned)     |

Table C-1. Operation Code Map

|                                              |      | • •             |
|----------------------------------------------|------|-----------------|
| Addressing Mode                              | Mode | Register        |
| Data Register Direct                         | 000  | register number |
| Address Register Direct                      | 001  | register number |
| Address Register Indirect                    | 010  | register number |
| Address Register Indirect with Postincrement | 011  | register number |
| Address Register Indirect with Predecrement  | 100  | register number |
| Address Register Indirect with Displacement  | 101  | register number |
| Address Register Indirect with Index         | 110  | register number |
| Absolute Short                               | 111  | 000             |
| Absolute Long                                | 111  | 001             |
| Program Counter with Displacement            | 111  | 010             |
| Program Counter with Index                   | 111  | 011             |
| Immediate or Status Register                 | 111  | 100             |
|                                              |      |                 |

Table C-2. Effective Address Encoding Summary

| Mnemonic | Condition        | Encoding | Test                                          |
|----------|------------------|----------|-----------------------------------------------|
| Т        | true             | 0000     | 1                                             |
| F        | false            | 0001     | 0                                             |
| н        | high             | 0010     | C•Z                                           |
| LS       | low or same      | 0011     | C+Z                                           |
| CC(HS)   | carry clear      | 0100     | Č                                             |
| CS(LO)   | carry set        | 0101     | С                                             |
| NE       | not equal        | 0110     | Ž                                             |
| EQ       | equal            | 0111     | Z                                             |
| VC       | overflow clear   | 1000     | V                                             |
| VS       | overflow set     | 1001     | V                                             |
| PL       | plus             | 1010     | N                                             |
| MI       | minus            | 1011     | N                                             |
| GE       | greater or equal | 1100     | $N \cdot V + \overline{N} \cdot \overline{V}$ |
| LT       | less than        | 1101     | $N \cdot \overline{V} + \overline{N} \cdot V$ |
| GT       | greater than     | 1110     | N•V•Z+N•V•Z                                   |
| LE       | less or equal    | 1111     | Z+N•V+N•V                                     |

**Table C-3. Conditional Tests** 

# C.2 BIT MANIPULATION, MOVE PERIPHERAL, IMMEDIATE INSTRUCTIONS

| Dynamic Bil | ι. |  |
|-------------|----|--|
|-------------|----|--|

| 15 | 14 | 13 | 12 | 11 | 10     | 9  | 8 | 7  | 6          | 5 | 4    | 3     | 2   | 1     | 0   |
|----|----|----|----|----|--------|----|---|----|------------|---|------|-------|-----|-------|-----|
| 0  | 0  | 0  | 0  | 8  | egist  | er | 1 | Ти | De         |   | Effe | ctive | Add | ress  | ;   |
|    |    | •  |    |    | - g.o. |    |   |    | <b>P</b> • |   | Mode | e     | R   | egist | ter |

Static Bit

MOVEP

|   | 14 |   |   | 11 | 10    | 9  | 8  | 7   | 6  | 5 | 4 | 3 | 2  | 1     | 0  |
|---|----|---|---|----|-------|----|----|-----|----|---|---|---|----|-------|----|
| 0 | 0  | 0 | 0 | R  | egist | er | Op | -Mo | de | 0 | 0 | 1 | Re | egist | er |

Op-Mode field: 100 = transfer word from memory to register 101 = transfer long word from memory to register 110 = transfer word from register to memory

111 = transfer long word from register to memory

**OR Immediate** 

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Si | 70 |   | Effective Address |  |    |       |    |  |
|---|---|---|---|---|---|---|---|----|----|---|-------------------|--|----|-------|----|--|
| 0 |   | Ŭ | U | Ů | U | 0 |   |    | 20 | 1 | Mode              |  | Re | egist | er |  |

01 = word

11 = long word

MC68000 ASSEMBLY LANGUAGE

SYSTEM REFERENCE MANUAL

### VERSION 0.00

# OR Immediate to CCR

|         | iediai |        | CCF  | (                 |      |    |   |   |          |    |   |              |   |         |                |    |
|---------|--------|--------|------|-------------------|------|----|---|---|----------|----|---|--------------|---|---------|----------------|----|
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 0  | 0 | 0 | 0        | 0  | 1 | 1            | 1 | 1       | 0              | 0  |
| OR Imm  | nediat | e to   | SR   |                   |      |    |   |   |          |    |   |              |   |         |                |    |
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 0  | 0 | 0 | 0        | 1  | 1 | 1            | 1 | 1       | 0              | 0  |
| AND Im  | medi   | ate    |      |                   | 4    |    |   |   | <b>L</b> | 1  | P |              |   | 4       |                | LJ |
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 0  | 1 | 0 | Si       | ze |   | Effe<br>Mode |   |         | iress<br>egist |    |
| AND Im  | media  | ate te | o CC | R                 | •    |    |   |   |          | *  | • |              |   | •       |                |    |
|         | 5      | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 0  | 1 | 0 | 0        | 0  | 1 | 1            | 1 | 1       | 0              | 0  |
| AND Im  | media  | ate te | o SR |                   |      |    |   |   |          |    |   |              |   |         |                |    |
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 0  | 1 | 0 | 0        | 1  | 1 | 1            | 1 | 1       | 0              | 0  |
| SUB Im  | nedia  | te     |      |                   |      |    |   |   |          |    |   |              |   |         |                |    |
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 1  | 0 | 0 | Si       | ze |   |              |   | Address |                |    |
|         | L      |        |      |                   |      |    |   |   |          |    |   | Mode         | ) | Re      | gist           | er |
| ADD Imi | nedia  | ate    |      |                   |      |    |   |   |          | k  |   |              |   |         |                |    |
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 0    | 1  | 1 | 0 | Si       | ze |   | Effec        |   |         |                |    |
|         | L      |        |      |                   |      |    |   |   |          |    |   | Mode         |   | Re      | gist           | ər |
| EOR Imr | nedia  | te     |      |                   |      |    |   |   |          | ł  |   |              |   |         |                |    |
|         | 15     | 14     | 13   | 12                | 11   | 10 | 9 | 8 | 7        | 6  | 5 | 4            | 3 | 2       | 1              | 0  |
|         | 0      | 0      | 0    | 0                 | 1    | 0  | 1 | 0 | Si       | ze |   | Effec        |   |         |                |    |
|         |        |        |      |                   |      |    |   |   |          |    |   | Mode         |   | Re      | gist           | ər |
|         | *Size  | e fie  |      | 01 = <sup>-</sup> | word |    | i |   | 1        | T  |   |              |   |         |                |    |

# EOR Immediate to CCR

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

# EOR Immediate to SR

| 15 |   |   |   |   |   | - | - | • | 6 |   |   | - |   |   | 0 |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0  | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |

**CMP** Immediate

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5                 | 4    | 3 | 2  | 1      | 0  |
|----|----|----|----|----|----|---|---|----|----|-------------------|------|---|----|--------|----|
| 0  | 0  | 0  | 0  | 1  | 1  | 0 | 0 | Si | 78 | Effective Address |      |   |    |        |    |
|    |    | •  |    |    |    |   |   |    |    |                   | Mode | • | Re | egiste | er |

Size field: 00 = byte 01 = word 11 = long word

# C.3 MOVE BYTE INSTRUCTION

# **MOVE Byte**

| 15 | 5 | 14 | 13 | 12 | 11 | 10    | 9    | 8     | 7    | 6        | 5 | 4    | 3   | 2    | 1     | 1  |
|----|---|----|----|----|----|-------|------|-------|------|----------|---|------|-----|------|-------|----|
| 0  |   | 0  | 0  | 1  |    | D     | esti | natio | n    |          | Τ |      | Sou | irce |       |    |
|    |   |    |    |    | R  | egist | er   |       | Mode | <u> </u> |   | Mode | Э   | R    | egist | er |

Note Register and Mode location

# **C.4 MOVE LONG INSTRUCTION**

MOVE Long

| 15 | 14 | 13 | 12 | 11 | 10    | 9    | 8     | 7    | 6 | 5 | 4    | 3   | 2    | 1     | 0  |
|----|----|----|----|----|-------|------|-------|------|---|---|------|-----|------|-------|----|
| 0  | 0  | 1  | 0  |    | D     | esti | natio | n    |   |   |      | Sou | irce |       |    |
| Ľ  |    |    | Ŭ  | R  | egist | er   |       | Mode | e |   | Mode | Э   | R    | egist | er |

Note Register and Mode location

# **C.5 MOVE WORD INSTRUCTION**

MOVE Word

|     | Deel     |          |          |               |               |               |                    |      |                      |                           |
|-----|----------|----------|----------|---------------|---------------|---------------|--------------------|------|----------------------|---------------------------|
| 1 1 | Desi     | inatio   | n        |               |               |               | Sou                | Irce |                      |                           |
|     | Register | 1        | Mode     | •             |               | Mode          | •                  | R    | egist                | er                        |
| 1   |          | Register | Register | Register Mode | Register Mode | Register Mode | Register Mode Mode |      | Register Mode Mode R | Register Mode Mode Regist |

Note Register and Mode location

# C.6 MISCELLANEOUS INSTRUCTIONS

# NEGX

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5 | 4    | 3 | 2 | 1     | 0  |
|----|----|----|----|----|----|---|---|----|----|---|------|---|---|-------|----|
| 0  | 1  | 0  | 0  | 0  | 0  | 0 | 0 | SI | ze |   | Effe |   | 1 |       |    |
|    |    |    |    |    |    |   |   |    |    |   | Mode | • | R | egist | er |
|    |    |    |    |    |    |   |   |    | *  |   |      |   |   |       |    |

# MOVE from SR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3     | 2   | 1     | 0  |
|----|----|----|----|----|----|---|---|---|---|---|------|-------|-----|-------|----|
| 0  | 1  | 0  | 0  | 0  | 0  | 0 | 0 | 1 | 1 |   | Effe | ctive | Add | ress  |    |
|    |    |    |    |    | Ľ  | Ľ |   |   |   |   | Mode | 9     | R   | egist | er |

# CLR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5 | 4                                  | 3 | 2 | 1     | 0  |  |  |
|----|----|----|----|----|----|---|---|----|----|---|------------------------------------|---|---|-------|----|--|--|
| 0  | 1  | 0  | 0  | 0  | 0  | 1 | 0 | SI | ze |   | Effective Address<br>Mode Register |   |   |       |    |  |  |
| Ũ  |    |    |    | Ŭ  | ľ  | ' | Ŭ |    | 20 |   | Mode                               | Э | R | egist | er |  |  |
|    |    |    |    |    |    |   |   | ,  | k  |   |                                    |   |   |       |    |  |  |

# NEG

| 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8 | 7  | 6  | 5 | 4    | 3     | 2   | 1     | 0  |
|----|----|----|----|----|----|-----------|---|----|----|---|------|-------|-----|-------|----|
| 0  | 1  | 0  | 0  | 0  | 1  | 0         | 0 | Si | ze |   | Effe | ctive | Add | ress  |    |
| Ŭ  | •  | Ŭ  | Ŭ  | Ŭ  | •  | ľ         | ľ | Ŭ  | 20 |   | Mode | e     | R   | egist | er |
|    | -  |    |    |    |    | • • • • • | • |    |    |   |      |       | L   |       |    |

#### MOVE to CCR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3     | 2   | 1     | 0  |
|----|----|----|----|----|----|---|---|---|---|---|------|-------|-----|-------|----|
| 0  | 1  | 0  | 0  | 0  | 1  | 0 | 0 | 1 | 1 |   | Effe | ctive | Add | ress  |    |
|    |    |    |    |    |    |   |   |   |   |   | Mode | э     | R   | egist | er |

NOT

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8        | 7  | 6  | 5 | 4    | 3     | 2   | 1     | 0  |
|---|----|----|----|----|----|----|---|----------|----|----|---|------|-------|-----|-------|----|
| ſ | 0  | 1  | 0  | 0  | 0  | 1  | 1 | 0        | Si | ze |   | Effe | ctive | Add | lress |    |
|   | Ŭ  | '  | Ŭ  |    | ľ  | '  | ' | ľ        | 0. | 20 |   | Mode | Э     | R   | egist | er |
|   |    |    |    | •  |    | •  |   | <b>.</b> |    | L. |   |      |       | •   |       |    |

# MOVE to SR

| 15 | 14 | 1 | 3 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5             | 4                 | 3 | 2 | 1 | 0 |  |  |
|----|----|---|---|----|----|----|---|---|----|---|---------------|-------------------|---|---|---|---|--|--|
| 0  | 1  |   | n | 0  | 0  | 1  | 1 | 0 | 1  | 1 |               | Effective Address |   |   |   |   |  |  |
| ľ  | '  |   |   | Ŭ  | Ŭ  | •  | • | ľ | 1. | ' | Mode Register |                   |   |   |   |   |  |  |

# NBCD

|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|-------|----------|-------|----------|-------|--------------|------|----------|---|----|-----|---|------|-------|-----|-------|----|
|       | 0        | 1     | 0        | 0     | 1            | 0    | 0        | 0 | 0  | 0   |   | Effe | ctive | Adc | lress |    |
|       |          | •     | ľ        | ľ     | ·            | Ŭ    | ľ        |   |    | ľ   |   | Mod  | е     | R   | egist | er |
|       | <b>.</b> | J     | <b>L</b> | A     |              | ·    | <b>-</b> | • |    | 1   |   |      |       |     |       |    |
| PEA   |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|       | 0        | 1     | 0        | 0     | 1            | 0    | 0        | 0 | 0  | 1   |   | Effe | ctive | Add | Iress |    |
|       |          |       | ľ        | ľ     | `            | ľ    | ľ        | ľ | ľ  | ! ' |   | Mod  | e     | R   | egist | er |
|       |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
| SWAP  |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|       | 0        | 1     | 0        | 0     | 1            | 0    | 0        | 0 | 0  | 1   | 0 | 0    | 0     | R   | egist | er |
|       |          |       | <b>.</b> |       |              |      |          |   |    |     |   | L    |       | L   |       |    |
| MOVEM | Regi     | sters | s to E   | EA    |              |      |          |   |    |     |   |      |       |     |       |    |
|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|       | 0        | 1     | 0        | 0     | 1            | 0    | 0        | 0 | 1  | Sz  |   | Effe | ctive | Add | ress  |    |
|       | -        | -     |          |       |              | Ū    | -        |   |    |     |   | Mod  | Э     | R   | egist | er |
|       | Sz fi    | eld:  | 0 = v    | /ord  | trans        | sfer |          |   |    |     |   |      |       |     |       |    |
|       |          |       | 1 = lo   | ong v | word         | tran | sfer     |   |    |     |   |      |       |     |       |    |
|       |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
| EXTW  |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|       | 0        | 1     | 0        | 0     | 1            | 0    | 0        | 0 | 1  | 0   | 0 | 0    | 0     | R   | egist | er |
|       |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
| EXTL  |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|       | 0        | 1     | 0        | 0     | 1            | 0    | 0        | 0 | 1  | 1   | 0 | 0    | 0     | R   | egist | er |
|       |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
| TST   |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       | 15       | 14    | 13       | 12    | 11           | 10   | 9        | 8 | 7  | 6   | 5 | 4    | 3     | 2   | 1     | 0  |
|       | 0        | 1     | 0        | 0     | 1            | 0    | 1        | 0 | Si | ze  |   |      | ctive |     |       |    |
|       |          |       |          |       |              |      |          |   |    |     |   | Mod  | 9     | R   | əgist | er |
|       | Size     | field |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       |          |       |          |       |              |      |          |   |    |     |   |      |       |     |       |    |
|       |          |       |          | = wo  | ird<br>Ig wo |      |          |   |    |     |   |      |       |     |       |    |

TAS

| TAS     |         |          |            |     |          |              |      |   |     |          | • • |      |          |     |          |           |
|---------|---------|----------|------------|-----|----------|--------------|------|---|-----|----------|-----|------|----------|-----|----------|-----------|
|         | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
|         | 0       | 1        | 0          | 0   | 1        | 0            | 1    | 0 | 1   | 1        |     | Effe | ctive    | Add | iress    | ;         |
|         |         |          |            |     |          |              |      |   |     |          |     | Mod  | e        | R   | egist    | ter       |
| ILLEGA  |         |          |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
| ILLEGA  | L<br>15 | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | F   |      | •        | •   |          | •         |
|         | 0       | 1        | 0          | 0   | 1        | 0            | 1    | 0 | 1   | 1        | 5   | 4    | 3        | 2   | 1        | 0         |
|         | L       | <u> </u> | L <b>-</b> | L   | l        |              | L    |   | L   | <u> </u> | L   |      | <u> </u> | Ŀ   |          | <b></b> _ |
| MOVEM   | EA t    | o Re     | giste      | ərs |          |              |      |   |     |          | ,   |      |          |     |          |           |
|         | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
|         | 0       | 1        | 0          | 0   | 1        | 1            | 0    | 0 | 1   | Sz       |     |      | ctive    |     |          |           |
|         |         |          |            | L_  | <u> </u> | Ļ            |      |   |     |          |     | Mod  | 9        | R   | egist    | er        |
|         | Sz fi   | ield:    |            |     |          | ster<br>tran | sfer |   |     |          |     |      |          |     |          |           |
|         |         |          | • • •      |     |          |              |      |   |     |          |     |      |          |     |          |           |
| TRAP    |         |          |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
|         | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
|         | 0       | 1        | 0          | 0   | 1        | 1            | 1    | 0 | 0   | 1        | 0   | 0    |          | Veo | ctor     |           |
| LINK    |         |          |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
| LINK    | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
|         | 0       | 1        | 0          | 0   | 1        | 1            | 1    | 0 | 0   | 1        | 0   | 1    | 0        |     | egist    |           |
| 1       |         |          |            |     | I        | L            |      |   |     |          |     |      | !        |     |          |           |
| UNLK    |         |          |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
|         | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
|         | 0       | 1        | 0          | 0   | 1        | 1            | 1    | 0 | 0   | 1        | 0   | 1    | 1        | Re  | egist    | er        |
| MOVE to |         | )        |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
|         | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
| 1       | 0       | 1        | 0          | 0   | 1        | 1            | 1    | 0 | 0   | 1        | 1   | 0    | 0        |     | egist    |           |
| (       |         |          |            |     |          |              | J    | 1 | I   |          |     |      |          |     | <u> </u> | l         |
| MOVE fr | om U    | SP       |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
| ſ       | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        |           |
| [       | 0       | 1        | 0          | 0   | 1        | 1            | 1    | 0 | 0   | 1        | 1   | 0    | 1        | Re  | egist    | er        |
| RESET   |         |          |            |     |          |              |      |   |     |          |     |      |          |     |          |           |
|         | 15      | 14       | 13         | 12  | 11       | 10           | 9    | 8 | 7   | 6        | 5   | 4    | 3        | 2   | 1        | 0         |
| ]       | 0       | 1        | 0          | 0   | 1        | 1            | 1    | 0 | 0   | 1        | 1   | 1    | 0        | 0   | 0        | Ő         |
| L       |         | I        | L          |     | ·        |              |      |   | - 1 | I        |     | 1    | - 1      | -   |          |           |

NOP

| NOP   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|-------|---------|----------|-----|----------|----------|-------|----|---|---|---|----------|------|-------|-----|-------------|----|
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | 1        | 1     | 1  | 0 | 0 | 1 | 1        | 1    | 0     | 0   | 0           | 1  |
|       |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
| STOP  |         |          |     |          |          |       | _  | - | _ | _ | _        |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           |    |
|       |         |          | 0   | 0        |          | 1     |    | 0 | 0 | 1 | 1        | 1    | 0     | 0   | 1           | 0  |
| RTE   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | 1        | 1     | 1  | 0 | 0 | 1 | 1        | 1    | 0     | 0   | 1           | 1  |
|       | <b></b> |          | -d  | -l       | ·        | ·     | L  |   | I | L | .1       |      | l     | 4   | <b>1</b>    | JJ |
| RTS   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | 1        | 1     | 1  | 0 | 0 | 1 | 1        | 1    | 0     | 1   | 0           | 1  |
| TRAPV |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
| INAPV | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        |     | 0        | 1        | 1     | 1  | 0 | 0 | 1 | 1        | 1    | 0     | 1   | 1           | Ō  |
|       |         | <u> </u> | _ • | <b>_</b> | <u> </u> |       | L  |   |   | l | <u> </u> |      |       | L   | L .         |    |
| RTR   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | 1        | 1     | 1  | 0 | 0 | 1 | 1        | 1    | 0     | 1   | 1           | 1  |
|       |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
| JSR   | _       |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | 1        | 1     | 1  | 0 | 1 | 0 |          |      |       | Add |             | 1  |
|       |         |          |     |          |          |       |    |   |   |   |          | Mod  | 9     | Re  | egist       | er |
| JMP   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
| UMI   | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       |         |          | T   | r        | <b></b>  |       |    |   |   |   | r -      |      |       | Add |             |    |
|       | 0       | 1        | 0   | 0        | 1        | 1     | 1  | 0 | 1 | 1 |          | Mode |       |     | egist       | er |
|       |         |          | L   | L        | I        |       |    | L |   |   | I        | mou  |       | 1   | <u>gior</u> |    |
| СНК   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | Re       | giste | ər | 1 | 1 | 0 |          | Effe | ctive | Add | ress        |    |
|       | Ŭ       |          | Ŭ   | Ŭ        |          | .g.o. |    | • | · | U |          | Mode |       | Re  | gist        | ər |
|       |         |          |     |          |          |       |    |   |   |   | •        |      |       |     |             |    |
| LEA   |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |
|       | 15      | 14       | 13  | 12       | 11       | 10    | 9  | 8 | 7 | 6 | 5        | 4    | 3     | 2   | 1           | 0  |
|       | 0       | 1        | 0   | 0        | Re       | giste | er | 1 | 1 | 1 |          |      |       | Add |             |    |
|       |         |          |     |          |          |       | –  |   |   |   | İ        | Mode | •     | Re  | gist        | ər |
|       |         |          |     |          |          |       |    |   |   |   |          |      |       |     |             |    |

SYSTEM REFERENCE MANUAL

# C.7 ADD QUICK, SUBTRACT QUICK, SET CONDITIONALLY, DECREMENT INSTRUCTIONS

#### ADDQ



#### SUBQ

| 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7  | 6  | 5 | 4    | 3     | 2   | 1     | 0  |
|----|----|----|----|----|------|---|---|----|----|---|------|-------|-----|-------|----|
| 0  | 1  | 0  | 1  |    | Data |   | 1 | SI | ze |   | Effe | ctive | Add | Iress | ;  |
|    | .  | ľ  |    |    | Data |   | . |    | 20 |   | Mode | е     | R   | egist | er |

Data field: Three bits of immediate data, 0, 1-7, representing a range of: 8, 1-7, respectively.

Size field: 00 = byte 01 = word 10 = long word

Scc

| _ | 15 | 14 | 13 | 12 | 11 | 10   | 9      | 8 | 7 | 6 | 5 | 4    | 3     | 2   | 1     | 0     |
|---|----|----|----|----|----|------|--------|---|---|---|---|------|-------|-----|-------|-------|
|   | 0  | 1  | 0  | 1  |    | Cond | lition |   | 1 | 1 |   | Effe | ctive | Add | ress  | -<br> |
|   |    |    |    |    |    |      |        |   |   |   |   | Mode | Э     | R   | egist | er    |

DBcc

|   | 15   | 14    | 13    | 12    | 11   | 10    | 9      | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1     | 0  |
|---|------|-------|-------|-------|------|-------|--------|---|---|---|---|---|---|----|-------|----|
|   | 0    | 1     | 0     | 1     |      | Conc  | lition | 1 | 1 | 1 | 0 | 0 | 1 | Re | egist | er |
| 1 | Cond | ition | field | 1. 50 | o To | hla C | 2      |   |   |   |   |   |   |    |       |    |

Condition field: See Table C-3

#### **C.8 BRANCH CONDITIONALLY INSTRUCTION**

Bcc

| 15 | 14      | 13 | 12 | 11 | 10   | 9      | 8 | 7 | 6 | 5     | 4    | 3    | 2   | 1 | 0 |
|----|---------|----|----|----|------|--------|---|---|---|-------|------|------|-----|---|---|
| 0  | 1       | 1  | 0  |    | Cond | litior | ١ |   | 1 | 8-bit | Disp | lace | men | t |   |
| -  | 414.1 - |    |    |    |      | ~~     |   |   |   |       |      |      |     |   |   |

Condition field: See Table C-3

BSR

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4    | 3    | 2    | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|-------|------|------|------|---|---|
| 0  | 1  | 1  | 0  | 0  | 0  | 0 | 1 |   | 1 | B-bit | Disp | lace | ment | t |   |

8-bit Displacement field: Twos complement integer representing the relative distance in bytes. If 0, 16-bit displacement is in extension word.

### MOVEQ

| 15 | 14 | 13 | 12 | 11 | 10    | 9  | 8 | 7 | 6 | 5 | 4  | 3   | 2 | 1 | 0 |
|----|----|----|----|----|-------|----|---|---|---|---|----|-----|---|---|---|
| 0  | 1  |    | 1  | R  | egist | er | 0 |   |   |   | Da | ta* |   |   |   |

\*Data is sign extended to a long operand, and all 32 bits are transferred to the data register.

# C.10 OR, DIVIDE, SUBTRACT DECIMAL INSTRUCTIONS

# OR

|      | 15   | 14     | 13    | 12    | 11     | 10               | 9  | 8   | 7                                                                                                                      | 6       | 5    | 4     | 3       | 2   | 1     | 0  |
|------|------|--------|-------|-------|--------|------------------|----|-----|------------------------------------------------------------------------------------------------------------------------|---------|------|-------|---------|-----|-------|----|
|      | 1    | 0      | 0     | 0     | R      | egist            | er | 0   | o-Mo                                                                                                                   | de      |      | Effe  | ctive   | Add | ress  |    |
|      |      | _      |       |       |        | 3                |    | _   |                                                                                                                        |         |      | Mode  | •       | Re  | egist | er |
|      | Op-I | Node   | field | l: By | te V   | Nord             | Lo | ng  |                                                                                                                        |         | Ope  | ratio | n       |     |       |    |
|      |      |        |       | 00    |        | 001              | 01 |     |                                                                                                                        |         |      | ea>   |         |     |       |    |
|      |      |        |       | 10    | 0      | 101              | 11 | 0   | ( <ea< td=""><td>a&gt;)</td><td>Λ (&lt;</td><td>Dn&gt;</td><td>)→ &lt;</td><td>ea&gt;</td><td>&gt;</td><td></td></ea<> | a>)     | Λ (< | Dn>   | )→ <    | ea> | >     |    |
| DIVU |      |        |       |       |        |                  |    |     |                                                                                                                        |         |      |       |         |     |       |    |
|      | 15   | 14     | 13    | 12    | 11     | 10               | 9  | 8   | 7                                                                                                                      | 6       | 5    | 4     | 3       | 2   | 1     | 0  |
|      | 1    | 0      | 0     | 0     | R      | Register         |    |     | 1                                                                                                                      | 1       |      | Effe  | ctive   | Add | ress  |    |
|      |      |        |       | -     |        | Register         |    |     |                                                                                                                        |         |      | Mode  | )       | Re  | egist | er |
| DIVS |      |        |       |       |        |                  |    |     |                                                                                                                        |         |      |       |         |     | x     |    |
|      | 15   | 14     | 13    | 12    | 11     | 10               | 9  | 8   | 7                                                                                                                      | 6       | 5    | 4     | 3       | 2   | 1     | 0  |
|      | 1    | 0      | 0     | 0     | Be     | egist            | er | - 1 | 1                                                                                                                      | 1       |      | Effe  | ctive   | Add | ress  |    |
|      |      | · ·    | Ŭ     | Ŭ     |        | giot             | 0. |     |                                                                                                                        |         | 1    | Mode  | ;       | Re  | egist | er |
| SBCD |      |        |       |       |        |                  |    |     |                                                                                                                        |         |      |       |         |     |       |    |
|      | _ 15 | 14     | 13    | 12    | 11     | 10               | 9  | 8   | 7                                                                                                                      | 6       | 5    | 4     | 3       | 2   | 1     | 0  |
|      | 1    | 0      | 0     | 0     |        | stinat<br>egiste |    | 1   | 0                                                                                                                      | 0       | 0    | 0     | R/<br>M | 1   | ourc  |    |
|      | R/M  | field: | 0 =   | regis | ster-r | egist            | er | •   |                                                                                                                        | <b></b> | A    |       |         |     |       |    |

1 = memory-memory

\*If R/M = 0, specifies a data register.

If R/M = 1, specifies an address register for the predecrement addressing mode.

# **C.11 SUBTRACT, SUBTRACT EXTENDED INSTRUCTIONS**

#### SUB

| 15   | 14   | 13    | 12    | 11   | 10     | 9  | 8  | 7                                                                                                                       | 6   | 5    | 4     | 3     | 2         | 1     | 0  |
|------|------|-------|-------|------|--------|----|----|-------------------------------------------------------------------------------------------------------------------------|-----|------|-------|-------|-----------|-------|----|
| 1    | 0    | 0     | 1     | B    | egist  | er | Or | o-Mo                                                                                                                    | de  |      | Effe  | ctive | Add       | lress |    |
|      |      |       |       |      | - g.c. |    |    | ,                                                                                                                       |     |      | Mode  | •     | R         | egist | er |
| Op-I | Node | field | d: By | te \ | Nord   | Lo | ng |                                                                                                                         |     | Ope  | ratio | n     | •         |       |    |
|      |      |       | 00    | 0    | 001    | 01 | 0  | (< D                                                                                                                    | n>) | + (< | ea>   | )→ <  | (Dn)      | >     |    |
|      |      |       | 10    | 00   | 101    | 11 | 0  | ( <e< td=""><td>a&gt;)</td><td>+ (&lt;</td><td>Dn&gt;</td><td>)→ &lt;</td><td><ea></ea></td><td>&gt;</td><td></td></e<> | a>) | + (< | Dn>   | )→ <  | <ea></ea> | >     |    |

SUBX

| 15   | 14       | 13 | 12   | 11 | 10             | 9 | 8 | 7  | 6  | 5 | 4 | 3   | 2 | 1             | 0 |
|------|----------|----|------|----|----------------|---|---|----|----|---|---|-----|---|---------------|---|
| 1    | 0        | 0  | 1    |    | stina<br>giste |   | 1 | Si | ze | 0 | 0 | R/M |   | ourc<br>giste |   |
| 0/14 | \$1.0 Id |    | ragi |    |                |   |   |    |    |   |   |     |   |               |   |

R/M field: 0 = register-register 1 = memory-memory

\*If R/M = 0, specifies a data register.

If R/M = 1, specifies an address register for the predecrement addressing mode.

#### **C.12 COMPARE, EXCLUSIVE OR INSTRUCTIONS**

CMP



### C.13 AND, MULTIPLY, ADD DECIMAL, EXCHANGE INSTRUCTIONS

AND

| 15   | 14   | 13    | 12    | 11   | 10    | 9   | 8  | 7                                                                                                                                | 6   | 5   | 4     | 3     | 2                                         | 1     | 0  |
|------|------|-------|-------|------|-------|-----|----|----------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------|-------|-------------------------------------------|-------|----|
| 1    | 1    | 0     | 0     | R    | egist | er  | Or | o-Mo                                                                                                                             | de  |     | Effe  | ctive | Add                                       | Iress |    |
|      | -    |       |       |      | . 9   |     |    |                                                                                                                                  |     |     | Mode  | Э     | R                                         | egist | er |
| Op-N | lode | field | d: By | te V | Nord  | Lor | ng |                                                                                                                                  |     | Ope | ratio | n     |                                           |       |    |
|      |      |       | 00    | 0    | 001   | 01  | 0  | ( <d< td=""><td>n&gt;)</td><td>-(&lt;</td><td>ea&gt;</td><td>)→ &lt;</td><td><dn:< td=""><td>&gt;</td><td></td></dn:<></td></d<> | n>) | -(< | ea>   | )→ <  | <dn:< td=""><td>&gt;</td><td></td></dn:<> | >     |    |
|      |      |       | 10    | Ю    | 101   | 11  | 0  | ( <e< td=""><td>a&gt;)</td><td>-(&lt;</td><td>Dn&gt;</td><td>)→ &lt;</td><td><ea></ea></td><td>&gt;</td><td></td></e<>           | a>) | -(< | Dn>   | )→ <  | <ea></ea>                                 | >     |    |

Page G-2Ø MULU

| age G-  | 20                  |       |                  |                |                  |                 |               |              |             |      |       |             |      |                     | VER            | ISIO     |
|---------|---------------------|-------|------------------|----------------|------------------|-----------------|---------------|--------------|-------------|------|-------|-------------|------|---------------------|----------------|----------|
|         | 15                  | 14    | 13               | 12             | 11               | 10              | 9             | 8            | 7           | 6    | 5     | 4           | 3    | 2                   | 1              | 0        |
|         | 1                   | 1     | 0                | 0              | R                | Register        |               |              | 1           | 1    |       | Effe<br>Mod |      | Address<br>Register |                |          |
| MULS    |                     |       |                  |                |                  |                 |               |              |             | -    |       | ·           |      |                     |                |          |
|         | 15                  | 14    | 13               | 12             | 11               | 10              | 9             | 8            | 7           | 6    | 5     | 4           | 3    | 2                   | 1              | 0        |
|         | 1                   | 1     | 0                | 0              | Register         |                 |               | 1            | 1           | 1    |       | Effe<br>Mod |      | Address<br>Register |                |          |
| ABCD    |                     |       |                  |                |                  |                 |               |              |             |      |       |             |      |                     |                |          |
|         | 15                  | 14    | 13               | 12             | 11               | 10              | 9             | 8            | 7           | 6    | 5     | 4           | 3    | 2                   | 1              | 0        |
|         | 1                   | 1     | 0                | 0              |                  | stinat<br>giste |               | 1            | 0           | 0    | 0     | 0           | R/M  | Re                  | ourc<br>giste  | e<br>er* |
|         | R/M                 | fielc |                  |                |                  | regis<br>mem    |               | •            | •           | •    |       | <b>4</b>    | •    |                     |                |          |
|         | *lf F<br>lf T<br>mo | R/M = | : 0, s<br>= 1, s | pecif<br>speci | ies a<br>ifies   | a data<br>an a  | a reg<br>addr | giste<br>ess | r.<br>regis | ster | ior t | he p        | rede | crem                | ent            | addr     |
| EXGD    |                     |       |                  |                |                  |                 |               |              |             |      |       |             |      |                     |                |          |
|         | 15                  | 14    | 13               | 12             | 11               | 10              | 9             | 8            | 7           | 6    | 5     | 4           | 3    | 2                   | 1              | 0        |
|         | 1                   | 1     | 0                | 0              | Data<br>Register |                 |               | 1            | 0           | 1    | 0     | 0           | 0    | Data<br>Register    |                |          |
| EXGA    |                     |       |                  |                |                  |                 |               |              |             |      |       |             |      |                     |                |          |
|         | 15                  | 14    | 13               | 12             | 11               | 10              | 9             | 8            | 7           | 6    | 5     | 4           | 3    | 2                   | 1              | 0        |
|         | 1                   | 1     | 0                | 0              |                  | ddres<br>egiste |               | 1            | 0           | 1    | 0     | 0           | 1    |                     | ldres<br>gist  |          |
| EXGM    |                     |       |                  |                |                  |                 |               |              |             |      |       |             |      |                     |                |          |
|         | 15                  | 14    | 13               | 12             | 11               | 10              | 9             | 8            | 7           | 6    | 5     | 4           | 3    | 2                   | 1              | 0        |
|         | 1                   | 1     | 0                | 0              |                  | Data<br>egiste  | ər            | 1            | 1           | 0    | 0     | 0           | 1    |                     | ldres<br>giste |          |
| C.14 AD | D, AD               | D E   | KTEN             | IDEC           | INS              | TRU             | стіс          | ONS          |             |      |       |             |      |                     |                |          |

ADD

| 15   | 14                                      | 13 | 12 | 11 | 10    | 9  | 8                                       | 7                                     | 6  | 5                 | 4 | 3 | 2        | 1 | 0 |
|------|-----------------------------------------|----|----|----|-------|----|-----------------------------------------|---------------------------------------|----|-------------------|---|---|----------|---|---|
| 1    | 1                                       | 0  | 1  | R  | eaist | er | 0                                       | o-Mo                                  | de | Effective Address |   |   |          |   |   |
|      |                                         |    |    |    | - 9   |    |                                         |                                       |    | Mode              |   |   | Register |   |   |
| Op-N | Op-Mode field: Byte Word Long Operation |    |    |    |       |    |                                         |                                       |    |                   |   |   |          |   |   |
|      |                                         |    | 00 | )0 | 001 0 |    |                                         | ( <dn>) v (<ea>)→ <dn></dn></ea></dn> |    |                   |   |   |          |   |   |
|      |                                         |    | 10 | 00 | 101   | 11 | 10 ( <ea>) v (<dn>)→<ea></ea></dn></ea> |                                       |    |                   |   |   | >        |   |   |

C68000 ASSEMBLY LANGUAGE

SYSTEM REFERENCE MANUAL

ADDX

| 15 | 14 | 13 | 12 | 11 | 10                       | 9 | 8 | 7  | 6  | 5 | 4 | 3   | 2 | 1              | 0 |
|----|----|----|----|----|--------------------------|---|---|----|----|---|---|-----|---|----------------|---|
| 1  | 1  | 0  | 1  | 1  | Destination<br>Register* |   | 1 | Si | ze | 0 | 0 | R/M |   | iourc<br>giste |   |

R/M field: 0 = register-register

1 = memory-memory

\*If R/M = 0, specifies a data register

If R/M = 1, specifies an address register for the predecrement addressing mode.

### **C.15 SHIFT/ROTATE INSTRUCTIONS**

Register



dr field: 0 = right

1 = left

•

MC68000 ASSEMBLY LANGUAGE