

DMC11 IPL microprocessor user's manual



DMC11 IPL microprocessor user's manual

digital equipment corporation • maynard, massachusetts

Copyright © 1976 by Digital Equipment Corporation

The material in this manual is for informational purposes and is subject to change without notice.

Digital Equipment Corporation assumes no responsibility for any errors which may appear in this manual.

Printed in U.S.A.

This document was set on DIGITAL's DECset-8000 computerized typesetting system.

The following are trademarks of Digital Equipment Corporation, Maynard, Massachusetts:

| DEC          | DECtape | PDP              |
|--------------|---------|------------------|
| DECCOMM      | DECUS   | RSTS             |
| DECsystem-10 | DIGITAL | <b>TYPESET-8</b> |
| DECSYSTEM-20 | MASSBUS | TYPESET-11       |
|              |         | UNIBUS           |

#### CONTENTS

.

-

(

r

| CHAPTER 1        | INTRODUCTION                          |
|------------------|---------------------------------------|
| <b>CHAPTER 2</b> | INSTALLATION                          |
| 2.1              | SCOPE                                 |
| 2.2              | UNPACKING AND INSPECTION 2-1          |
| 2.3              | <b>OPTION DESIGNATIONS</b>            |
| 2.4              | MECHANICAL PACKAGING                  |
| 2.5              | PRE-INSTALLATION PROCEDURES           |
| 2.5.1            | General Information                   |
| 2.5.2            | Preinstallation Checkout Procedures   |
| 2.6              | INSTALLATION                          |
| 2.7              | DEVICE ADDRESSES                      |
| 2.7.1            | Introduction                          |
| 2.7.2            | Floating Device Address Assignments   |
| 2.7.3            | Device Address Selection              |
| 2.8              | VECTOR ADDRESSES                      |
| 2.8.1            | Introduction                          |
| 2.8.2            | Floating Vector Address Assignment    |
| 2.8.3            | Vector Address Selection              |
| 2.9              | INSTALLATION CHECKLIST 2-9            |
| CHAPTER 3        | PROGRAMMING INFORMATION               |
| 3.1              | INTRODUCTION                          |
| 3.2              | INTERRUPT VECTORS                     |
| 3.3              | PRIORITY SELECTION                    |
| 3.4              | PDP-11 PROGRAMMING INFORMATION        |
| 3.4.1            | Introduction                          |
| 3.4.2            | Unibus Control and Status Registers   |
| 3.4.2.1          | BSEL0 – Input Register                |
| 3.4.2.2          | BSEL1 Maintenance Register            |
| 3.4.2.3          | BSEL2 Output Register                 |
| 3.4.2.4          | BSEL3 Line Number/Priority Register   |
| 3.4.2.5          | Data Port Message Formats             |
| 3.4.3            | Input Transfers                       |
| 3.4.4            | Output Transfers                      |
| 3.4.5            | Initialization                        |
| 3.4.6            | <b>DDCMP</b> Start Up                 |
| 3.4.7            | Data Transmission                     |
| 3.4.8            | Data Reception                        |
| 3.4.9            | Control Out Transfers                 |
| 3.4.10           | Maintenance Messages                  |
| 3.4.11           | Remote Load Detect and Down Line Load |
| 3.4.12           | Power Fail Recovery                   |
| 3.4.13           | Data Set Control                      |

### **CONTENTS** (Cont)

|       |                                             | 0-           |
|-------|---------------------------------------------|--------------|
| 3.5   | MICROPROCESSOR CONTROL AND STATUS REGISTERS | 215          |
| 3.5.1 | Introduction                                | 3-15         |
| 3.5.2 | OUT BUS*/IN BUS* Registers 0-7              | 3-15         |
| 3.5.3 | NPR Control Register (OUT BUS*/IN BUS* 10)  | 3-17         |
| 3.5.4 | Microprocessor Miscellaneous Register       | 3-17         |
| 3.5.5 | NPR Bus Address and Data Registers          | 3-18         |
|       | (OUT BUS/IN BUS $0-7$ )                     | 3-19         |
| 3.6   | LINE UNIT REGISTERS                         | 3-10         |
| 3.6.1 | In/Out Data Silo Registers (10)             | 2 10         |
| 3.6.2 | Out Control Register (11)                   | 2 20         |
| 3.6.3 | In Control Register (12)                    | 3-20         |
| 3.6.4 | Modem Control Register (13)                 | 3-21         |
| 3.6.5 | Sync Register $(14)$                        | 3-22         |
| 366   | Switch Solootable Devictory (15 - 11()      | 3-23         |
| 3.6.7 | Maintenance Register (17)                   | 3-24<br>3-24 |

#### PDP-11 MEMORY ORGANIZATION AND ADDRESSING CONVENTIONS APPENDIX A

#### **ILLUSTRATIONS**

| Figure No. | Title                                             | Page  |
|------------|---------------------------------------------------|-------|
| 1-1        | DMC11 Remote Line Unit Interface                  | 1 2   |
| 1-2        | DMC11 Local Line Unit Interface                   | . 1-2 |
| 1_2        |                                                   | . 1-3 |
| 1-5        | Microprocessor Simplified Block Diagram           | . 1-5 |
| 2-1        | Microprocessor Device and Vector Address Switches | 2_8   |
| 3-1        | Unibus Control and Status Registers               | . 2-0 |
| 2 2        |                                                   | . 3-3 |
| 3-2        | Microprocessor Registers                          | 3-16  |

#### TABLES

## Title

### Page

| 2-1<br>2-2 | Line Unit Option Designations                       |
|------------|-----------------------------------------------------|
| 2-3        | Guide for Setting Switches to Select Device Address |
| 2-4<br>2-5 | Guide for Setting Switches to Select Vector Address |
|            | on Line Unit                                        |

#### Table No.

Figure No.

### CHAPTER 1 INTRODUCTION

This manual provides the information necessary to install and operate the DMC11 Microprocessor. Specifically, it covers the DMC11-AL and DMC11-AR Microprocessors, which have their ROMs configured to operate under the discipline of the DDCMP protocol. It is organized into three chapters and one appendix as follows.

| Chapter 1  | - | Introduction                                          |
|------------|---|-------------------------------------------------------|
| Chapter 2  | - | Installation                                          |
| Chapter 3  | - | Device Registers and Programming Information          |
| Appendix A | - | PDP-11 Memory Organization and Addressing Conventions |

In this manual, the term DMC11 denotes the DMC11 Network Link, which consists of a microprocessor module and a line unit module. Explicit references to these modules may or may not be prefixed by the term DMC11.

The DMC11-AR Microprocessor module is designated M8200-YA; the DMC11-AL Microprocessor module is designated M8200-YB.

Where the computers are located remotely and connected via common carrier facilities, DMC11s can be configured to interface to synchronous modems such as Bell models 208 and 209.

The DMC11 ensures reliable data transmission by implementing the DDCMP line protocol in firmware using a high-speed microprocessor. The DDCMP protocol detects errors on the channel interconnecting the systems by using a 16-bit Cyclic Redundancy Check (CRC-16). Errors are corrected, when necessary, by automatic retransmissions. Sequence numbers in message headers ensure that messages are delivered in proper order with no omissions or duplications.

A number of advantages are offered by the DMC11 over conventional interfaces that require a combination of hardware and software to implement a protocol. Programming is greatly simplified. Extensive communications expertise is no longer required when programming the DMC11. PDP-11 memory and processor time are not wasted with instructions implementing the protocol. As a direct result, throughput is enhanced because the DMC11 operates at high speeds and is not delayed when the processor has to perform high priority tasks.

There are two versions of the line unit. The M8202 high-speed line unit is intended for local network applications using coaxial cables. The M8202 contains an integral modem that operates at 1M bps or 56K bps.

The M8201 low-speed unit has no integral modem but contains level conversion logic to interface with EIA/CCITT V24 or CCITT V35 compatible modems at speeds up to 19.2K bps and 56K bps, respectively.

1-1

The M8201 and M8202 line units can operate with DDCMP and Bit Stuff protocols.

The line unit is not a stand-alone device. It must be used with a DMC11 Microprocessor.

A separate manual (EK-DMCLU-MM-002) covers the M8201 and M8202 line units.

The microprocessor is a general-purpose control unit that provides a full-duplex parallel data interface between any PDP-11 family central processor and a given DMC11 Line Unit. With the microprocessor/line unit combination, computers can be configured in many different network applications. Where the computers are located at the same facility, DMC11s can be configured for high-speed operation (56,000 or 1,000,000 bps) over inexpensive coaxial cable. The necessary modems are built-in.

Other DMC11 (M8200) features include:

- Down-line loading of satellite computer systems
- Ability to initialize an incorrectly functioning satellite computer system by command over the link (Remote Load Detect)
- Same PDP-11 software supporting local or remote, full- or half-duplex configurations
- Recovery from power failures at either or both ends of a link without loss of data
- 16-bit NPR (DMA) transfers.

A typical configuration is illustrated in Figure 1-1. Shown is the DMC11-DA (M8201) line unit used for synchronous data communications. The M8201 interface converts data from the DMC11 to a binary serial format compatible with the Electronic Industries Association RS-232C interface specification, used as a standard by nearly all low-speed modem manufacturers.



Figure 1-1 DMC11 Remote Line Unit Interface

The other line unit is the M8202 with an integral modem. The overall system function is identical to that of the M8201. In this case, however, because of the built-in modem, the M8202 interfaces directly to a local coaxial cable.

This configuration uses a single coaxial cable for half-duplex operation or two coaxial cables for fullduplex operation (Figure 1-2).



Figure 1-2 DMC11 Local Line Unit Interface

Figure 1-2 defines, in greater detail, the general interface between the microprocessor and any line unit. First, there are two 8-bit parallel data buses; one is an input bus and the other is an output bus. Two separate buses are used to sustain full-duplex operation. In the line unit, the data source is addressed by the microprocessor using the Input/Output register address bus.

The line unit contains eight registers. During a read operation, which uses the Input bus, the microprocessor uses four addressing bits. The most significant bit is held low to show that a line unit register is being read. The other three bits select the line unit register to be read. During a write operation, which uses the Output register, the microprocessor uses four different addressing bits. The most significant bit is an enabling bit and the other three bits select the line unit register to be written into. Simultaneous addressing on the Input and Output buses is possible.

The remaining bus, the control signal interface, delivers timing and control information to the line unit, such as clock sync and data strobe signals.

Data transfers between the DMC11 and the PDP-11 processor are in the form of the three common bus transactions. They are the NPR bus cycle, the interrupt sequence, and the reading (DATI) and writing (DATO) of DMC11 Control and Status Registers (CSRs). The Unibus CSRs are composed of eight bytes of device addresses and are accessed by addresses 76XXX0 through 76XXX7. These device addresses are henceforth referred to as Byte Select (BSEL) 0-7 for indicating individual bytes, and SEL, 0, 2, 4, 6 for indicating word transfers (SEL0 consists of BSEL0 and BSEL1, SEL2 consists of BSEL2 and BSEL3, etc...). BSEL0 and BSEL2 are handshaking CSRs, which interlock transfers through a common data port. This data port is accessed through BSEL4-7 (SEL 4, 6).

When the PDP-11 program wishes to transfer data to the DMC11, the program (through BSEL0) sets up a REQUEST IN (RQI) and a function describing the data to be passed. The DMC11 responds by setting READY IN. BSEL4-7 is then loaded by the PDP-11 program, and clears RQI. The DMC11 takes the data and drops RDYI, which completes the exchange.

Similarly, the DMC11 transfers data to the PDP-11 program by setting READY OUT (RDYO) with a function after having loaded BSEL4-7. The PDP-11 program, after reading the required registers, should then clear RDYO, releasing the port for further use.

The DMC11-AR and DMC11-AL are referenced as microprocessors throughout this manual, as well as in other related documentation. This is due to the fact that ROMs are used as controlling elements. The ROMs act as compact logic arrays that replace a large amount of distributive logic. For example, a 2048-bit ROM is organized as 512 words of 4-bits each. Combining four of these ROMs produces 512 words of 16-bits each. Each word in the ROM is pre-programmed and is unalterable. When addressed, a specific word always produces the same output.

The information stored in the ROMs at the word level can be called <u>microsteps</u>. Executing an appropriate series of microsteps is called a <u>microroutine</u>. It can represent a particular instruction or function. The combination of microroutines is called a microprogram.

As the microroutine is being executed, the ROM output signals are sent to the appropriate circuits in the microprocessor to perform the instruction or function that is repesented by the microroutine.

As illustrated in Figure 1-3, the DMC11 essentially connects the Unibus to the line unit interface through internal registers. This allows the data to be processed by the microprocessor as it passes between the two buses. The processing is dependent on the microprogram residing in the microprocessor. Currently, a microprogram is available to accommodate the DDCMP line protocol.

The block diagram in Figure 1-3 very much resembles a processor, hence the term microprocessor. It has a program counter (PC) addressing the microprogram residing in 1K of ROM. Each micro-instruction is a 16-bit word. Certain bits of the microinstruction then serve as address bits for three additional ROMs, which control data flow and determine what operation to perform on the operands.

The DMC11 and line unit consist of two separate modules interconnected by a one foot cable. Each is ordered separately. Two microprocessor versions and four synchronous line unit versions are available: local operation at 1M bps, local operation at 56K bps, remote operation with EIA/CCITT V24 compatible modems up to 19.2K bps, and remote operation with CCITT V35 compatible modems up to 56K bps.

Both the DMC11-AR and DMC11-AL microprocessor modules (hex SPC) include a 300 ns bipolar microprocessor, a ROM implementing the DDCMP protocol, local scratchpad memory, and a Unibus interface.

The DMC11-MA line unit module (notched hex) includes a built-in modem for local operation at 1M bps over coaxial cable up to 6,000 feet in length.



Figure 1-3 Microprocessor Simplified Block Diagram

.

.

The DMC11-MD line unit module (notched hex) includes a built-in modem for local operation at 56K bps over coaxial cable up to 18,000 feet in length.

Coaxial cables are not included with either line unit. Optional BC03N-A0 coaxial cable is available in 100 foot lengths only. One is required for half-duplex operation and two are required for full-duplex operation.

The two versions of the remote line unit, DMC11-DA and DMC11-FA, use the same module (M8201). Both versions contain level conversion logic that accommodates the EIA/CCITT V24 interface and the CCITT V35 interface. The only difference is the modem cable that is supplied to match the specified interface.

The DMC11-DA is shipped with a 25 foot BC05C cable for the EIA/CCITT V24 interface to accommodate Bell 208 or 209 synchronous modems or their equivalent.

The DMC11-FA is shipped with a 25 foot BC05Z cable for the CCITT V35 interface. This synchronous interface is used in certain European networks and in the domestic Digital Data Service (DDS).

### CHAPTER 2 INSTALLATION

#### 2.1 SCOPE

This chapter provides all necessary information for a successful installation and subsequent checkout of the DMC11 microprocessor subsystem.

#### **2.2 UNPACKING AND INSPECTION**

The microprocessor/line unit system combination arrives at the customer site in one of two ways, either as a part of a complete computer system or as an add-on option. When it arrives as an add-on option, the microprocessor module, line unit module, and associated mounting hardware and cables arrive packaged in a single carton. Inspect the carton visually for any signs of physical damage. Included in the contents of the carton are the following:

- 1. M8200-YA or M8200-YB Microprocessor module
- 2. M8201 or M8202 Line Unit module
- 3. BC08S-1 cable (interconnects microprocessor and line unit)
- 4. BC05C-25 cable (M8201 EIA/CCITT V24 interface only)
- 5. BC05Z-25 cable (M8201 CCITT V35 interface only)
- 6. H325 test connector (M8201 only)
- 7. 12-12528 coaxial cable test connector (M8202 only)
- 8. MAINDEC-11-DZDMC Microprocessor Basic W/R and Up Test
- 9. MAINDEC-11-DZDME Line Unit DDCMP Test
- 10. MAINDEC-11-DZDMF Line Unit Bit Stuff Test
- 11. MAINDEC-11-DZDMG Jump and Free Running Test
- 12. MAINDEC-DEC/XII System Test
- 13. ITEP One Line Test
- 14. EK-DMCUP-MM-001, Microprocessor Manual
- 15. EK-DMCLU-MM-002, Line Unit Manual

#### 2.3 OPTION DESIGNATIONS

There are two microprocessors available, both configured to implement the DDCMP protocol only. The DMC11-AR is for remote applications; the DMC11-AL is for local applications.

The various line units and cables are listed in Table 2-1 and 2-2, respectively.

2-1

| Option   | Description                                                        |
|----------|--------------------------------------------------------------------|
| DMC11-DA | M8201 Line Unit Module with cable for EIA/CCITT V24 interface      |
| DMC11-FA | M8201 Line Unit Module with cable for CCITT V35 interface          |
| DMC11-MA | M8202-YA Line Unit Module with 1M bps integral modem and no cable  |
| DMC11-MD | M8202-YB Line Unit Module with 56K bps integral modem and no cable |

 Table 2-1
 Line Unit Option Designations

 Table 2-2
 Line Unit Cables

| Option   | Description                                                              |
|----------|--------------------------------------------------------------------------|
| BC03N-A0 | 100 foot coaxial cable with connectors, used with M8202 Line Unit module |
| BC05C-25 | 25 foot EIA/CCITT V24 cable for use with DMC11-DA Line Unit              |
| BC05Z-25 | 25 foot CCITT V35 cable for use with DMC11-FA Line Unit                  |

#### 2.4 MECHANICAL PACKAGING

The DMC11 consists of a microprocessor module (hex) and a line unit module (notched hex). These modules plug into any DD11-B Rev E or later, DD11-C, DD11-D, or equivalent SPC system unit. The microprocessor module must always plug into either slot 2 or 3 in the DD11-B or DD11-C. The line unit module may be installed in any of the remaining slots. Should two DMC11s be installed in a single DD11-B, then the line unit module plugs into slot 1 or 4.

The line unit does not interface with the Unibus so module edge connectors A and B are not required. As a result, the corner of the module in the vicinity of the A and B connectors has been removed. This allows the M8201 and M8202 to be installed in the end slots of the DD11-B, C, and D system interfacing units. The module plugs into connectors C, D, E, and F and fits over the Unibus cable connector and short length (approximately 2-1/2 inches) Unibus terminator that are installed in end slot connectors A and B.

The two modules are interconnected by a Berg 40-pin connector and a 1-foot BC08S-1 cable.

#### 2.5 PRE-INSTALLATION PROCEDURES

#### 2.5.1 General Information

Installation of the microprocessor/line unit combination should be done in three phases. First, the microprocessor is physically installed then checked and verified with MAINDEC-11-DZDMC. In this manner the microprocessor is checked as a stand-alone module apart from the line unit. Next, the line unit module is installed and operationally verified with MAINDEC-11-DZDME and MAINDEC-11-DZDMR, which also provides an additional confidence factor for the microprocessor. The third and final installation phase involves the execution of MAINDEC-11-DZDMG, which verifies the operational status of both the microprocessor and the line unit as a free running test. Additionally, this test checks the contents of the ROMs (microcode) and the BRANCH instructions.

A minimum of 8K of memory is necessary for execution of the MAINDEC diagnostics.

Check the power supply to ensure against overloading. The microprocessor/line unit total current requirement for the +5 V supply is approximately 8 A. Additionally, the line unit requires  $\pm 15$  V for the silos and the level conversion logic and the integral modem.

Installation requires two adjacent hex SPC slots, one of which can be either the Unibus input or terminator slot if the modules are 2-1/2 inches or less. The DMC11 microprocessor requires a full hex slot, while the line unit fits into any slot in the DD11 backplane. The microprocessor can be installed in the DD11-B Rev E or higher, DD11-C, DD11-D, or equivalent backplanes. Such an equivalent backplane is that used in the PDP-11/04 or PDP-11/34 computers.

#### 2.5.2 Preinstallation Checkout Procedures

Before installing the microprocessor module, the following functions must be performed.

- 1. Verify that jumper W1 is installed. This jumper should not be removed in the field. It is removed only at the factory during automated module testing to inhibit the oscillator in the microprocessor clock logic.
- 2. The microprocessor device address must be selected in accordance with Paragraph 2.7.
- 3. The microprocessor vector address must be selected in accordance with Paragraph 2.8.
- 4. Verify that a BR5 priority card is installed in position E75.
- 5. Verify that switch numbers 7 and 9 in the DIP switch package, located in position E76, are both OFF. In this package, switches 1-6 are used for the vector address and switches 8 and 10 are not used.

Switch 7 is the Run Inhibit (RI) switch, which is connected between ground and the CLEAR input of the RUN flip-flop. Normally, it is OFF and the RUN flip-flop cannot be cleared directly. Under normal conditions, initialization of the microprocessor directly sets the RUN flip-flop, which allows the microcode to be executed immediately. Because of an internal malfunction or execution of malicious microcode during power up, it is possible for the microprocessor to hang the Unibus. Now, it is not possible to load the diagnostics to determine the fault. Placing the RI switch in the ON position clears the RUN flip-flop and allows the diagnostics to be loaded.

Switch 9 is the Byte Sel 1 Lockout (BS1) switch. It is related to the "computer in a closet" application, where all programs are down-line loaded. When set, the BS1 switch prevents a runaway program in the PDP-11 processor from preventing a boot or down-line loading operation via the DMC11 link. This switch inhibits all maintenance functions.

#### NOTE

Before installing the microprocessor (M8200), remove the NPR Grant wire that runs between pins CA1 and CB1 on the backplane for the slot that is going to accept the M8200. Do not remove the wire for the slot that is going to accept the line unit (M8201 or M8202).

The M8200 Microprocessor presents one load to the Unibus and the M8201 and M8202 Line Units present no load to the Unibus except for power requirements.

The local DMC11 configuration (DMC11-AL Microprocessor and DMC11-MA or DMC11-MD Line Unit) requires bus placement nearest to the PDP-11 processor; this is due to the high rate of NPR transactions that is required. For example, the DMC11-MA Line Unit (1M bps) requires an average of one NPR every 8  $\mu$ s.

#### 2.6 INSTALLATION

After completing the pre-installation checkout procedures in Paragraph 2.5.2, proceed with the installation as follows:

- 1. Insert the microprocessor module in the proper backplane slot.
- 2. Run MAINDEC-11-DZDMC to verify correct operation of the microprocessor.

#### **DIAGNOSTIC NOTE**

If the installation is in a system using a PDP-11/04 or other PDP-11 processor that does not have a switch register, a software switch register is used to allow the user the same switch options. If a switch register is available but contains all 1s (177777), the software switch register is used. Refer to the appropriate diagnostic document for further details.

- 3. Check all appropriate switch settings and jumpers on the line unit module in accordance with the recommendations in Chapter 2, Installation, of the line unit manual (EK-DMC11LU-MM-002).
- 4. Insert the line unit module in the proper backplane slot.
- 5. Interconnect the line unit and microprocessor using cable BC08S-1 which is a 1-foot long, 40 conductor flat mylar cable with H856 female connectors on each end. The mating connector on the microprocessor and line unit is an H854 male connector. On the microprocessor, this connector is designated J1. On the M8201 Line Unit, it is designated J2 and on the M8202 Line Unit it is J1.
- 6. On the M8201, install the BC05C-25 cable to connector J1. On the other end of this cable, connect the H325 test connector.

On the M8202, install the 12-12528 coaxial test connector, which ties the two coaxial pigtails together. These two 3-foot cables are soldered to the M8202.

- 7. On the M8202, check that the integral modem clock is within specificatons. Refer to the line unit manual.
- 8. On the backplane, check that the supply voltages are within the following tolerances:

| Min    | Voltage<br>Nominal | Max    | <b>Backplane</b><br>Pin |
|--------|--------------------|--------|-------------------------|
| +4.75  | +5.0               | +5.25  | C1A2                    |
| -14.25 | -15.0              | -15.75 | C1B2                    |
| +14.25 | +15.0              | +15.75 | CIU1                    |

- 9. Run MAINDEC-11-DZDME and -DZDMF to verify correct line unit operation.
- 10. Run MAINDEC-11-DZDMG to verify correct line unit/microprocessor operation. This diagnostic also tests the microcode and BRANCH instructions.
- 11. Remove the test connector.

For the M8201, connect the BC05C-25 or BC05Z-25 cable to the customer-supplied modem.

#### CAUTION The maximum allowable length for the BC05C and BC05Z cable is 50 feet.

For the M8202, connect the pigtails to the customer coaxial cables or the optional 100-foot BC03N-A0 cable.

#### **2.7 DEVICE ADDRESSES**

#### 2.7.1 Introduction

Starting with the DJ11, new communications devices are to be assigned floating addresses. The addresses for current production devices are to be retained.

The word floating means that addresses are not assigned absolutely for the maximum number of each communications device that can be used in a system.

#### 2.7.2 Floating Device Address Assignments

Floating device addresses are assigned as follows:

- 1. The floating address space starts at location 760010 and extends to location 764000 (octal designations).
- 2. The devices are assigned, in order, by type: DJ11, DH11, DQ11, DU11, DUP11, DMC11, and then the next device introduced into production. Multiple devices of the same type must be assigned contiguous addresses.
- 3. The first address of a new type device must start on a modulo 10<sub>8</sub> boundary, if it contains one to four bus-addressable registers. The starting address of the DH11 must be on a modulo 20<sub>8</sub> boundary because the DH11 has eight registers.
- 4. A gap of 10<sub>8</sub>, starting on a modulo 10<sub>8</sub> boundary, must be left between the last address of one type device and the first address of the next type device. A gap must be left for any device on the list that is not used, if the device following it is used. The equivalent of a gap should be left after the last device assigned to indicate that nothing follows.
- 5. No new type devices can be inserted ahead of a device on the list.
- 6. If additional devices on the list are to be added to a system, they must be assigned contiguously after the original devices of the same type. Reassignment of other type devices already in the system may be required to make room for the additions.

The following examples show typical floating device assignments for communications devices in a system.

Example 1: No DJ11s, 2 DH11s, 2 DQ11s, 1 DUP11, and 1 DMC11

- DJ11 gap 760010 760020 DH11 #0 first address 760040 DH11 #1 first address 760060 DH11 gap 760070 DQ11 #0 first address 760100 DQ11 #1 first address 760110 DQ11 gap 760120 DU11 gap
- 760130 DUP11 #0 first address
- 760140 DUP11 gap
- 760150 DMC11 #0 first address
- 760160 Indicates no more DMC11s and no other devices following

Example 2: 1 DJ11, 1 DH11, 2 DQ11s, 2 DUP11s, and 2 DMC11s

- 760010 DJ11 #0 first address 760020 DJ11 gap 760040 DH11 #0 first address 760060 DH11 gap 760070 DQ11 #0 first address 760100 DQ11 #1 first address 760110 DQ11 gap 760120 DU11 gap 760130 DUP11 #0 first address 760140 DUP11 #1 first address 760150 DUP11 gap 760160 DMC11 #0 first address 760170 DMC11 #1 first address 760200
- 760200 Indicates no more DMC11s and no other devices following

#### 2.7.3 Device Address Selection

In the floating address space (760010-764000), bits 13-17 are always 1s (function of PDP-11 processor). Appendix A shows the PDP-11 memory organization and addressing conventions. Bits 3-12 are selected by switches in the address decoding logic (Table 2-3). With the switch on (closed), the decoder looks for a 0 on the associated Unibus address line. Bits 0, 1, and 2 are decoded to select 1 of 8 registers.

The device address selection switches are contained in one DIP switch package located in position E113. All 10 switches in the package are used. The correlation between switch numbers and address bit numbers is shown in Table 2-3. The ON and OFF positions and the switch numbers are marked on the package. The switches are rocker type and are pushed to the desired position (Figure 2-1).

#### 2.8 VECTOR ADDRESSES

#### 2.8.1 Introduction

Communications devices are assigned floating vector addresses. This eliminates the necessity of assigning addresses absolutely for the maximum number of each device that can be used in the system.

| Switch No. | 10 | 9     | 8  | 7 | 6        | 5        | 4        | 3 | 2 | 1 | Device  |
|------------|----|-------|----|---|----------|----------|----------|---|---|---|---------|
| BIT NO.    | 12 | 11    | 10 | 9 | 8        | /        | 0        | 2 | 4 | 3 | Address |
|            |    |       |    |   |          |          |          |   |   | X | 760010  |
|            |    |       |    |   |          |          |          |   | x |   | 760020  |
|            |    |       |    |   |          |          |          |   | x | x | 760030  |
|            |    |       |    |   |          |          |          | x |   |   | 760040  |
|            |    |       |    |   |          |          |          | x |   | x | 760050  |
|            |    |       |    |   |          |          |          | x | x |   | 760060  |
|            |    |       |    |   |          |          |          | x | x | x | 760070  |
|            |    |       |    |   |          |          | x        |   | Λ |   | 760100  |
|            |    |       |    |   |          | x        |          |   |   |   | 760200  |
|            |    |       |    |   |          |          |          |   |   |   | 760200  |
|            |    |       |    |   | v        | <b>^</b> | <b>^</b> |   |   |   | 760300  |
|            |    |       |    |   |          |          | v        |   |   |   | 760400  |
|            |    |       |    |   |          | v        |          |   |   |   | 760500  |
|            |    |       |    |   |          | X        | v        |   |   |   | /60600  |
|            |    |       |    |   | X        | X        |          |   |   |   | 760700  |
|            |    |       |    | X |          |          |          |   |   |   | 761000  |
|            |    |       | X  |   |          |          |          |   | 1 |   | 762000  |
|            |    |       | X  | Χ |          |          |          |   |   |   | 763000  |
|            |    | X     |    |   |          |          |          |   |   | - | 764000  |
| NOTES:     |    | 10 mm |    |   | <u>ب</u> | *        | *        | × |   | • | 760740  |

Table 2-3 Guide for Setting Switches to Select Device Address

1. X means switch off (open) to respond to logical 1 on the Unibus.

2. Switch numbers are physical positions in switch package 1.



Figure 2-1 Microprocessor Device and Vector Address Switches

#### 2.8.2 Floating Vector Address Assignment

Floating vector addresses are assigned as follows:

- 1. The floating address space starts at location 300 and proceeds upward to 777. Addresses 500-534 are reserved.
- The devices are assigned in order by type: DC11; KL11/DL11-A, B; DP11; DM11-A; DN11; DM11-BB; DR11-A; DR11-C; PA611 Reader; PA611 Punch; DT11; DX11; DL11-C, D, E; DJ11; DH11; GT40; LPS11; VT20; DQ11; KW11-W; DU11; DUP11; DV11; DMC11.
- 3. If any type device is not used in a system, address assignments move up to fill the vacancies.
- 4. If additional devices are to be added to the system, they must be assigned contiguously after the original devices of the same type. Reassignment of other type devices already in the system may be required.

#### 2.8.3 Vector Address Selection

Each drive interrupt vector requires four address locations (two words), which implies only evennumbered addresses. A further constraint is that all vector addresses must end in a 0 or 4. The vector address is specified as a three digit, binary-coded, octal number using Unibus data bits 0-8. Because the vector must end in 0 or 4, bits 1 and 0 are not specified (they are always 0) and bit 2 determines the least significant octal digit of the vector address (0 or 4). The interrupt control logic sends only seven bits (2-8) to the PDP-11 processor to represent the vector address.

The DMC11 is shipped with a BR5 priority selection card installed in the interrupt control logic. This logic generates two vector addresses: RDY I interrupts generate vector addresses of the form XX0, and RDY O interrupts generate vector addresses of the form XX4. For this method of operation, the state of bit 2 is selected by the logic, not by a switch. The two most significant octal digits of the vector address are determined by switches in lines 3-8 (Table 2-4). With the switch OFF (open), a 0 is generated on the associated Unibus data line; with the switch ON (closed), a 1 is generated on the associated Unibus data line.

The vector address selection switches are contained in one DIP package located in position E76 (Figure 2-1). Only 6 of the 10 switches in the package are used for the vector address. The correlation between switch numbers and bit numbers is shown in Table 2-4. The ON and OFF positions and the switch numbers are marked on the package. The switches are rocker type and are pushed to the desired position.

#### 2.9 INSTALLATION CHECKLIST

1.

The following items represent a concise checklist of the important features of the DMC11 installation.

| Power R       | equirements    |
|---------------|----------------|
| M8200         | +5 V @ 4.0 A   |
| <b>M820</b> 1 | +5 V @ 3.0 A   |
|               | +15 V @ 0.03 A |
|               | -15 V @ 0.31 A |
| M8202         | +5 V @ 3.0 A   |
|               | +15 V @ 0.18 A |
|               | -15 V @ 0.46 A |

2-9

|            |   |   |   | * |   |         | 1       |
|------------|---|---|---|---|---|---------|---------|
| Switch No. | 6 | 5 | 4 | 3 | 2 | 1       | Vector  |
| Bit No.    | 8 | 7 | 6 | 5 | 4 | 3       | Address |
|            | x |   |   | x | x | x       | 300     |
|            | Х |   |   | X | X |         | 310     |
|            | Х |   |   | X |   | X       | 320     |
|            | Х |   | 1 | X |   |         | 330     |
|            | Х |   |   |   | X | X       | 340     |
|            | Х |   |   |   | X |         | 350     |
|            | Х |   |   |   |   | X       | 360     |
|            | Х |   |   |   |   |         | 370     |
|            |   | X | X | X | X | X       | 400     |
|            |   |   |   |   |   |         |         |
|            |   | X |   | X | X | X       | 500     |
|            |   |   |   |   |   |         |         |
|            |   |   | X | X | X | X       | 600     |
|            |   |   |   |   |   |         |         |
|            |   |   |   | X | X | X       | 700     |
| NOTES.     |   |   | × |   |   | <b></b> | 670     |

 Table 2-4
 Guide for Setting Switches to Select Vector Address

NOTES:

X means switch off (open) to produce a logical 0 on the Unibus. 1.

Switch numbers are physical positions in switch package 2. 2.

- 2. Unibus Loading. The M8200 presents one Unibus load. The M8301 and M8202 present no Unibus loads.
- 3. Special Installation Requirements
  - M8200 Microprocessor. Before installing, remove the NPR Grant continuity wire that a. runs between pins CA1 and CB1 on the backplane for the slot that is going to accept the M8200. If a system change requires removal of the M8200, the wire must be replaced.
  - M8200 Microprocessor with Local Line Units (DMC11-MA or DMC11-MD). This b. configuration must be placed on the Unibus closest to the PDP-11 processor because of the high rate of NPR transactions that are required. It must also be placed before a DB11-A Bus Repeater if one is used.

- 4. M8200 Microprocessor Switch Settings
  - a. Address Selection (E113)

| Switch No. | Address Bit |
|------------|-------------|
| 1          | 3           |
| 2          | 4           |
| 3          | 5           |
| 4          | 6           |
| 5          | 7           |
| 6          | 8           |
| 7          | 9           |
| 8          | 10          |
| 9          | 11          |
| 10         | 12          |

160270

Switch OFF (open) to respond to logical 1 on Unibus.

Switch ON (closed) to respond to logical 0 on Unibus.

b. Vector Selection (E76)

| Switch No. | Vector Bit |
|------------|------------|
| 1          | 3          |
| 2          | 4          |
| 3          | 5          |
| 4          | 6          |
| 5          | 7          |
| 6          | 8          |

Switch OFF (open) to produce a logical 0 on the Unibus.

Switch ON (closed) to produce a logical 1 on the Unibus.

c. Remaining switches in E76

Switch 7 is RUN INHIBIT (RI) and should be OFF.

Switch 9 is BYTE SEL 1 LOCKOUT (BS1) and should be OFF.

Switches 8 and 10 are not used and should be OFF.

- 5. Line unit switch settings and jumper configuration as shipped.
  - a. Switch Settings
    - (1) Switch Pack No. 2 (E87 on M8201 and E90 on M8202) All switches should be OFF.
    - (2) Switch Pack No. 3 (E88 on M8201 and E91 on M8202) All switches should be OFF.
    - (3) Switch Pack No. 1 (E26 on M8201 and E29 on M8202) The switches should be positioned as shown in Table 2-5.
  - b. The jumpers should be configured as shown in Table 2-5.

| *<br>Switch No. | DMC11-DA<br>M8201 | DMC11-FA<br>M8201 | DMC11-MA/MD<br>M8202 |
|-----------------|-------------------|-------------------|----------------------|
| 1               | OFF               | OFF               | OFF                  |
| 2               | OFF               | OFF               | OFF                  |
| 3               | OFF               | OFF               | OFF                  |
| 4               | OFF               | ON                | OFF                  |
| 5               | OFF               | OFF               | OFF                  |
| 6               | OFF               | OFF               | OFF                  |
| 7               | ON                | ON                | OFF                  |
| 8               | ON                | ON                | <b>O</b> FF          |

# Table 2-5Configuration of Jumpers and<br/>Switch Pack No. 1 on Line Unit

Jumper No.

| 1 | IN          | IN          | IN       |  |
|---|-------------|-------------|----------|--|
| 2 | IN          | IN          | OUT      |  |
| 3 | OUT         | OUT         | OUT      |  |
| 4 | IN          | IN          | OUT      |  |
| 5 | OUT         | OUT         | OUT (FD) |  |
| 6 | Not Present | Not Present | IN (HD)  |  |

#### NOTES

\*Switch pack no. 1 located at E26 on M8201 and E29 on M8202.

FD = Full Duplex.

HD = Half Duplex.

### CHAPTER 3 PROGRAMMING INFORMATION

#### 3.1 INTRODUCTION

This chapter contains general information necessary for PDP-11 programming of the DMC11 Microprocessor. In general, the information is presented by operational categories such as input transfers, output transfers, etc. Also included are descriptions of the Unibus control and status registers, microprocessor control and status registers, and line unit control and status registers.

The information in this chapter is arranged as follows.

| Description                                 | Paragraph<br>Number |
|---------------------------------------------|---------------------|
| Introduction                                | 3.1                 |
| Interrupt Vectors                           | 3.2                 |
| Priority Selection                          | 3.3                 |
| PDP-11 Programming Information              | 3.4                 |
| Introduction                                | 3.4.1               |
| Unibus Control and Status Registers         | 3.4.2               |
| Input Transfers                             | 3.4.3               |
| Output Transfers                            | 3.4.4               |
| Initialization                              | 3.4.5               |
| DDCMP Start Up                              | 3.4.6               |
| Data Transmission                           | 3.4.7               |
| Data Reception                              | 3.4.8               |
| Control Out Transfers                       | 3.4.9               |
| Maintenance Messages                        | 3.4.10              |
| Remote Load Detect and Down Line Load       | 3.4.11              |
| Power Fail Recovery                         | 3.4.12              |
| Microprocessor Control and Status Registers | 3.5                 |
| Line Unit Registers                         | 3.6                 |

#### **3.2 INTERRUPT VECTORS**

The DMC11 generates two vector addresses: input (PDP-11 to microprocessor) interrupts generate vector addresses of the form XX0; and output (microprocessor to PDP-11) interrupts generate vector addresses of the form XX4. The conditions that initiate the interrupts are:

XX0 – An interrupt at address XX0 occurs when the PDP-11 requests the port (SEL4 or SEL6) and the microprocessor responds by asserting Ready In (RDYI) and Interrupt Enable In (IEI).

XX4 – An interrupt at address XX4 occurs when, after charging the port with data, the microprocessor asserts Ready Out (RDYO) and Interrupt Enable Out (IEO).

#### **3.3 PRIORITY SELECTION**

The priority for the interrupts is selectable on the microprocessor via a plug-in priority selection card. It is shipped with a card that establishes BR5 as the priority level.

#### 3.4 PDP-11 PROGRAMMING INFORMATION

#### 3.4.1 Introduction

Programming the DMC11 is described at two levels. The first level describes how a PDP-11 program uses the DMC11 control and status registers together with the interrupt system for transfer of control and status information between the PDP-11 program and the DMC11 microprogram. The second level describes details of these transactions, including formats, details of device and protocol initialization, data transfer, and unusual cases.

In order to successfully program the DMC11, it is not necessary to be familiar with the details of DDCMP protocol operation. These are handled by the DMC11 microprogram. However, some familiarity with the protocol operation is useful in interpreting the significance of the various error counters provided to assess the quality of the circuit connecting the two computers. If a DMC11 is to communicate with a different interface, which uses a software implementation of DDCMP, the person programing the software implementation should consult the DDCMP protocol standard document.

#### 3.4.2 Unibus Control and Status Registers

Communication of control and status information between the PDP-11 and the DMC11 uses eight bytes of control and status registers (CSRs). These are addressed as 76XXX0, 76XXX1, 76XXX2, 76XXX3, 76XXX4, 76XXX5, 76XXX6, and 76XXX7. These device addresses are subsequently referred to as Byte Select 0 to 7 (BSEL0 – BSEL7) for indicating individual bytes and as SEL0, SEL2, SEL4, and SEL6 for indicating words.

#### NOTE

The CSRs are implemented with Random Access Memory (RAM). Thus, at power on, the CSRs come up in random states. As part of the microprocessor initialization, the CSRs (SEL0-6) are cleared with the exception of bit 15 of SEL0 (RUN) which is set. The lower order 8 bits of SEL0 (BSEL0) are cleared first. Due to the high speed of the microprocessor, the registers are cleared before access by the PDP-11 is possible.

BSEL4-7 comprise a 32-bit data port that is used to pass information between the microprocessor and the PDP-11. The transfer of information from the PDP-11 to the microprocessor is called an Input Transfer, often abbreviated IN or I. The transfer of information from the microprocessor to the PDP-11 is called an Output Transfer, often abbreviated OUT or O. These terms are not to be confused with sending and receiving data on the serial line which are called sending or transmission, and receiving or reception.

BSEL0 controls input transfers and BSEL2 controls output transfers. BSEL1 contains bits used for maintenance purposes which are of no concern to the programmer. It also contains the MASTER CLEAR bit which can be used to initialize the DMC11 microprocessor. BSEL2 is not used. A switch on the microprocessor module prevents the PDP-11 program from clearing RUN or performing other maintenance functions in BSEL1 which would disable the microprocessor's ability to initialize an unattended PDP-11 computer system.

As reference for the programmer, the bit assignments for the Unibus CSRs are shown in Figure 3-1. A detailed description of each register is shown in tabular form.



#### BA/CC I AND BA/CC O FORMATS

|         | BUS ADDRESS     | 4 |
|---------|-----------------|---|
| BA17,16 | CHARACTER COUNT | 6 |

#### BASE I FORMAT

|         | BUS ADDRESS | ₄ |
|---------|-------------|---|
| BA17,16 |             | 6 |

|         | CNTL I FORMAT           |                   |    |
|---------|-------------------------|-------------------|----|
|         | BUS ADDRESS             |                   | ]₄ |
| BA17,16 | DDCMP DDCMP DDCMP MAINT | SECONDARY ADDRESS | 6  |





LOST DATA = 4.

| Bit  | Name                | Description                                                                                         |                                                                    |                                                                                                                                                                                                                                              |
|------|---------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0, 1 | TYPE INPUT          | These bits define the type of i                                                                     |                                                                    | he type of input transfer as follows.                                                                                                                                                                                                        |
|      |                     | <b>Bit 1 B</b><br>0 0                                                                               | Bit O                                                              | Buffer Address/Character Count<br>In (BA/CC I)                                                                                                                                                                                               |
|      |                     | 0 1                                                                                                 |                                                                    | Control In (CNTL I)                                                                                                                                                                                                                          |
|      |                     | 1 0                                                                                                 |                                                                    | Reserved                                                                                                                                                                                                                                     |
|      |                     | 1 1                                                                                                 |                                                                    | Base In (BASE I)                                                                                                                                                                                                                             |
|      |                     | Each of the                                                                                         | se trans                                                           | sfers is explained in detail.                                                                                                                                                                                                                |
|      |                     | 00 = Buffe<br>REQUEST<br>processor b<br>for purpose<br>14-bit chara<br>binary num                   | r Addre<br>IN (R(<br>y the PI<br>s of tran<br>acter co<br>ber.     | ess/Character Count In utilized with<br>QI). This is a request to the micro-<br>DP-11 to use the data port (BSEL4-7)<br>nsferring an 18-bit bus address and a<br>sunt must be expressed as a positive                                        |
|      |                     | 01 = Contro<br>of the data j<br>the purpose<br>control info                                         | ol In – V<br>port ( <b>B</b> S<br>e of tra<br>prmation             | When used with RQI, requests the use<br>SEL4-7) from the microprocessor for<br>ansferring protocol and/or process<br>n.                                                                                                                      |
|      |                     | 10 Reserved                                                                                         | 1                                                                  |                                                                                                                                                                                                                                              |
|      |                     | 11 Base I –<br>used with H<br>use of data<br>ring up to a<br>fail) bit.                             | Base In<br>RQI, re<br>port ( <b>B</b><br>n 18-bit                  | provides a base address which, when<br>quests from the microprocessor the<br>SEL4-7) for the purpose of transfer-<br>Base Address and RESUME (power                                                                                          |
| 02   | IN I/O              | Defines the<br>output (tran<br>new BA/CC<br>whether this<br>fer for a me                            | flags (<br>nsmit). I<br>C, the n<br>s was a<br>cssage to           | BA/CC, etc.) for Input (receive) or<br>For example, if BSEL4-7 contained a<br>nicroprocessor would need to know<br>block to be transferred out, or a buf-<br>to be received.                                                                 |
| 3,4  | RESERVED            |                                                                                                     |                                                                    |                                                                                                                                                                                                                                              |
| 5    | REQUEST IN<br>(RQI) | Set by the F<br>by the PDP<br>serves as an<br>use of the da<br>40 bits of da<br>is accompan<br>2-0. | PDP-11<br>-11 whe<br>in interlo<br>ata port<br>ata fron<br>nied by | to request an input transfer. Cleared<br>on the data has been loaded. This bit<br>ock bit, which is used to request the<br>(BSEL4-7) in order to transfer up to<br>on the PDP-11 program. The RQI bit<br>type of transfer as defined by bits |

# 3.4.2.1 BSEL0 – Input Register – This register comprises the low byte of address 76XXX0 (Figure 3-1).

| Bit | Name                            | Description                                                                                                                                                                                                             |
|-----|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | INTERRUPT ENABLE<br>INPUT (IEI) | When set, allows the microprocessor to vector interrupts to XX0 having set RDY I.                                                                                                                                       |
| 7   | READY IN<br>(RDY I)             | This is a microprocessor response to RQI. When asserted, it indicates to the PDP-11 program to proceed with loading the data port (BSEL4-7). This bit is cleared by the microprocessor at the end of an input transfer. |

**3.4.2.2 BSEL1 Maintenance Register** – This CSR contains all maintenance functions other than MASTER CLEAR and is not intended for normal user communications between the PDP-11 program and the microprocessor. These functions override all other control functions. All bits are read/write; however, only MASTER CLEAR is functional if BSEL1 LOCK OUT is set. This register comprises the high byte of address 76XXX0 (Figure 3-1).

| Bit | Name                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | STEP MICRO-<br>PROCESSOR<br>(STEP MP) | This bit, when set, steps the microprocessor through one instruction cycle, composed of five 60-ns clock pulses. The RUN flip-flop should be cleared before executing this control function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9   | ROM INPUT<br>(ROM I)                  | When set, directs the contents of BSEL6-7 as the next microinstruction to be executed by the microprocessor when STEP MP is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10  | ROM OUTPUT<br>(ROM 0)                 | When set, modifies the source paths for BSEL4-7 to be<br>the contents of the addressed CROM or the next micro-<br>instruction executed when STEP MP is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11  | LINE UNIT LOOP<br>(LU LOOP)           | This control function, when asserted, connects the line<br>unit's serial line out back to its serial line in. This is done<br>at the TTL level, before level conversion. When the<br>LINE UNIT LOOP bit is set and RUN is cleared, the<br>STEP LU clock is the only clock available for shifting<br>data out or in. When LU LOOP is set and RUN is set<br>data is clocked at a 10K bps rate. If the H325 loop back<br>connector is installed at the end of the EIA cable with<br>RUN set and not in LU LOOP mode, data is shifted by<br>a free running clock of approximatly 10K bps.<br>The 1M bps and 56K bps line units require a 12-12528<br>coaxial adapter installed at the line unit pigtail cables to<br>provide the loop back. The line unit operates at the<br>clock rate of the integral modem in this case. |
| 12  | STEP LINE UNIT<br>(STEP LU)           | This control function is used in conjunction with LU LOOP. When asserted, the transmitter shifts, and when negated, the receiver shifts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13  | RESERVED                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Bit | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14  | MASTER CLEAR | When set, MASTER CLEAR initializes both the micro-<br>processor and the line unit. This bit is self-clearing. The<br>microprocessor clock is enabled and the RUN flip-flop<br>is asserted. The CROM's PC is also temporarily cleared<br>by MASTER CLEAR allowing the microcode to enter<br>the idle state.                                                                                                                         |
| 15  | RUN          | RUN controls the microprocessor clock. This bit is set<br>by BUS initialization or MASTER CLEAR, which<br>enables the microprocessor clock. RUN can be cleared<br>for maintenance states. A switch (BS1) is provided,<br>which prevents RUN from being cleared by a runaway<br>microcode program when the microprocessor malfunc-<br>tions. Refer to Chapter 2, Installation, for more infor-<br>mation concerning the BS1 switch. |

**3.4.2.3** BSEL2 Output Register – This register contains control information relative to output transfers from the microprocessor to the PDP-11 program. This register comprises the low byte of address 76XXX2 (Figure 3-1).

| Bit  | Name                             | Description                                                                                                                                                                                                                                                                                                                                        |
|------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0, 1 | TYPE OUTPUT<br>(TYPE O)          | These bits are encoded for the type of data transfer from the microprocessor to the PDP-11 program.                                                                                                                                                                                                                                                |
|      |                                  | 00 = Bus Address and Character Count Out<br>01 = Control Output<br>10 = Reserved<br>11 = Reserved                                                                                                                                                                                                                                                  |
| 2    | OUT I/O                          | OUT I/O defines the flags (BA/CC, etc.) for Input<br>(receive) or Output (transmit). For example, if BSEL4-7<br>contained a BA/CC, the PDP-11 program would want<br>to know whether this was a block completed on output<br>or a message received. An input is indicated when this<br>bit is set; an output is indicated when this bit is cleared. |
| 3-5  | RESERVED                         |                                                                                                                                                                                                                                                                                                                                                    |
| 6    | INTERRUPT ENABLE<br>OUTPUT (IEO) | When set, the microprocessor, upon asserting RDYO, vectors an interrupt to XX4.                                                                                                                                                                                                                                                                    |
| 7    | READY OUTPUT<br>(RDYO)           | This bit, when asserted, indicates that BSEL4-7 contain data as defined by bits 0-2. This bit must be cleared by the PDP-11 program after the port data has been sampled.                                                                                                                                                                          |

3.4.2.4 BSEL3 Line Number/Priority Register – If the DMC11 is used as a multiple line controller, this register is used to designate line numbers and to assign priority for block data transfers.

| Bit    | Name        | Description                                                                                                                                                                                                        |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8-13   | LINE NUMBER | These bits are designated for line numbers during for-<br>mat transfers. The line number bits are required when<br>the DMC11 microprocessor is used as a multiple line<br>controller.                              |
| 14, 15 | PRIORITY    | These bits assign priority to blocks of data for transfer<br>via the DMC11 microprocessor when it is used as a mul-<br>tiple line controller. This is especially useful when lines<br>of different speed are used. |

This register comprises the high byte of address 76XXX2 (Figure 3-1).

**3.4.2.5 Data Port Message Formats** – The data port is represented by addresses 76XXX4 and 76XXX6. The first half of the port is 76XXX4, which includes BSEL4 and BSEL5. The second half of the port is 76XXX6, which includes BSEL6 and BSEL7.

The port is loaded by the PDP-11 on input transfers and by the microprocessor on output transfers.

The format and contents of the data port depend on the transfer type (TYPE I or TYPE O).

In discussing the data port message formats, it is sometimes more convenient to use word designations (SEL4 and SEL6) rather than byte designations (BSEL4-7).

There are four formats:

- 1. Buffer address/character count input and output (BA/CC I and BA/CC O).
- 2. Base input (BASE I)
- 3. Control input (CNTL I)
- 4. Control output (CNTL O)
- BA/CC I and BA/CC O Format The formats for BA/CC I and BA/CC O are the same (Figure 3-1). SEL4 contains the least significant 16 bits (0-15) of the 18-bit buffer address. The two most significant bits (16 and 17) of this address are contained in bits 14 and 15 of SEL6. The remaining 14 bits (0-13) of SEL6 contain the character count in positive notation, not 2's complement notation.

The microprocessor can stack a maximum of seven BA/CCs each for input and output. This number is based on the size of the core tables (BASE) in the PDP-11 memory, which is limited to 256 bytes.

For input operations, BA/CC I supplies new message buffers to the microprocessor.

For output operations, BA/CC O returns the buffers to the PDP-11 that were successfully transferred to the microprocessor.

2. BASE I Format – SEL4 and bits 14 and 15 of SEL6 provide the first address of a reserved block of addresses in the PDP-11 memory (Figure 3-1). The block size is 256 bytes. Upon assigning the BASE address to the microprocessor, the PDP-11 program must not modify any locations within the assigned block.

Bit 13 of SEL6 is called RESUME. If this bit is cleared, the microprocessor initializes the base table and protocol. If set, the microprocessor resumes operation as specified by the contents of the base table.

3. CNTL I Format – The CNTL I format provides a means of implementing certain control functions (Figure 3-1).

| Bit    | Name                                  | Description                                                                                                                                                                                        |
|--------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0–7    | SECONDARY<br>ADDRESS<br>(SEC ADRS)    | These bits define the address of a station in the second-<br>ary mode under the discipline of DDCMP.                                                                                               |
| 8      | DDCMP<br>MAINTENANCE<br>(DDCMP MAINT) | With this bit set, the microprocessor enters the DDCMP maintenance mode, where it remains until it is subsequently initialized.                                                                    |
| 9      | RESERVED                              |                                                                                                                                                                                                    |
| 10     | D DCMP HALF<br>DUPLEX<br>(DDCMP HD)   | With this bit set, DDCMP half-duplex operation is selected. With this bit cleared, DDCMP full-duplex operation is selected. This bit must be used with bit 11.                                     |
| 11     | DDCMP<br>(SECONDARY<br>DDCMP SEC)     | With this bit set, DDCMP half-duplex secondary sta-<br>tion operation is selected. With this bit cleared,<br>DDCMP half-duplex primary station operation is<br>selected. Not used for full-duplex. |
| 12, 13 | RESERVED                              |                                                                                                                                                                                                    |

SEL4 and bits 14 and 15 of SEL6 contain the address for this format. The control bits are located in SEL6 as shown below.

4. CNTL O Format – The CNTL O format provides a means of informing the PDP-11 program of error conditions involving the DMC11 hardware, PDP-11 program, communications channel, or the remote station.

SEL4 and bits 14 and 15 of SEL6 contain the address of this format. The control bits are located in SEL6 as shown below (Figure 3-1).

| Bit | Name                    | Description                                                                                                                   |
|-----|-------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0   | DATA CHECK<br>(DATA CK) | When set, this bit indicates that a retransmission threshold has been exceeded.                                               |
| 1   | TIME OUT                | When set, this bit indicates that the microprocessor has received no response from the remote end of the link for 21 seconds. |

| Bit | Name                                                   | Description                                                                                                                                                      |
|-----|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | OVERRUN (ORUN)                                         | When set, this bit indicates that a message was received,<br>but no buffer is available to receive it.                                                           |
| 3   | DDCMP<br>MAINTENANCE<br>RECEIVED (DDCMP<br>MAINT RECD) | When set, this bit indicates that a message in the DDCMP maintenance format has been received and that the protocol operation has entered the maintenance state. |
| 4   | LOST DATA                                              | When set, this bit indicates that the received message is longer than the supplied buffer.                                                                       |
| 5   | RESERVED                                               |                                                                                                                                                                  |
| 6   | DISCONNECT                                             | When set, this bit indicates that an off to on transition of the modem Data Set Ready lead has been detected.                                                    |
| 7   | DDCMP START<br>RECEIVED (DDCMP<br>START RECD)          | When set, this bit indicates that a DDCMP Start mes-<br>sage was received when the protocol was in the running<br>or maintenance state.                          |
| 8   | NON EXISTENT<br>MEMORY (NON EX<br>MEM)                 | When set, this bit indicates that a Unibus address time out has occurred.                                                                                        |
| 9   | PROCESSOR ERROR<br>(PROC ERR)                          | When set, this bit indicates that the PDP-11 program has performed a procedural error.                                                                           |

#### 3.4.3 Input Transfers

Whenever the data port is not in use, it is subject to being seized by the microprocessor for use in an output transfer. Therefore, the PDP-11 program must request the microprocessor to assign it the port before proceeding with an input transfer. It must also specify the type of input transfer (a transmit buffer, a receive buffer, control information, etc.) so the microprocessor can make appropriate preparations.

The PDP-11 program should set bits 0-2 of BSEL0 to indicate the type of transfer and then set bit 5, Request In (RQI), to request the port. These bits may be set by a single instruction. The microprocessor responds by setting bit 7, Ready In (RDYI), when the port has been assigned to the PDP-11 program. When RDY1 has been set, the PDP-11 program should load the desired data into the data port (BSEL4-7). Then, it should clear RQI. The microprocessor takes the data and clears RDYI which completes the transfer.

Bit 6 of BSEL0, Interrupt Enable Input (IEI), controls whether the PDP-11 program receives an interrupt (to Vector XX0) when the microprocessor has set RDYI. The microprocessor responds to RQI immediately (within 10  $\mu$ s) when operating at speeds below 1 Mb or at 1 Mb when either the transmitter or receiver is idle. It is most efficient for the PDP-11 program to have interrupts disabled and simply scan RDYI one or more times until the microprocessor has set it. While the PDP-11 program is waiting, it must be prepared to accept an output transfer because the microprocessor may have seized the port in the meanwhile.

The microprocessor cannot service certain types of input transfers immediately. For example, the PDP-11 program may attempt to queue more than seven buffers for transmission. In these cases, it is convenient to use interrupts. If the PDP-11 program finds RDYI clear after several scans, it can enable interrupts by setting IEI with a BIS or MOV instruction. The DMC11 interrupts the PDP-11 (to Vector XX0) when the microprocessor has set RDYI. The PDP-11 program gets the interrupt in all cases, even if the microprocessor had already set RDYI at the time the program sets IEI. The program can bypass any scanning if IEI is set when the program sets RQI.

#### NOTE

The PDP-11 program should not begin a new input transfer until the previous transfer has been completed, as indicated by the microprocessor clearing RDYI. The microprocessor does this within 10 \_\_\_\_\_s after the program has cleared RQI. If the PDP-11 program wishes to begin a new transfer immediately, it should check that RDYI has been cleared before setting RQI. This can be done by scanning RDYI until it has been cleared.

#### 3.4.4 Output Transfers

The microprocessor initiates an output transfer when it has status or error information to transfer to the PDP-11 program or it wishes to return a full buffer on reception or an empty buffer on transmission. The microprocessor can initiate an output transfer at any time the data port is free; that is, not assigned to the PDP-11 program for an input transfer and not in use for a previous output transfer. However, if the PDP-11 has initialized the DMC11 by setting MASTER CLEAR or generating the INIT signal on the Unibus, the microprocessor does not generate any output transfer until it has been initialized by the PDP-11 program.

The microprocessor loads status or error information into the data port (BSEL4-7) and sets bits 0-2 of BSEL2 to indicate the format and significance of the data. It then sets bit 7 of BSEL2, Ready Out (RDYO), to indicate to the PDP-11 programs that data is available. In response to RDYO setting, the PDP-11 program should note the type of output transfer as specified in bits 0-2 of BSEL2 and read the data in the data port. When the PDP-11 program has sampled all the data, it must complete the output transfer by clearing RDYO. This frees the data port for a subsequent transaction.

If the PDP-11 program wishes, it can enable interrupts on output transfers by setting bit 6 of BSEL2, Interrupt Enable Output (IEO). If IEO is set, the DMC11 interrupts the PDP-11 (to Vector XX4) after the microprocessor has set RDYO. Since the PDP-11 program usually does not know when an output transfer will occur (for example, when a message will be received) an efficient PDP-11 program ordinarily enables interrupts on output transfers.

#### NOTE

The PDP-11 program must respond to RDYO being set by reading the data and clearing RDYO. Failure to do this prevents the data port from being freed. If the PDP-11 program has requested an input transfer by setting RQI, it must be prepared to respond to an output transfer prior to being given RDYI. If the PDP-11 program fails to respond to RDYO, it never gets RDYI. The PDP-11 program should not spin on RDYI in a loop that does not also test RDYO unless interrupts on output transfers are enabled, and the loop executes at a lower priority level than the DMC11 interrupts level.

#### 3.4.5 Initialization

The power-up sequence and UNIBUS INIT signal initialize the DMC11. The PDP-11 program can accomplish the same effect by setting MASTER CLEAR in BSEL1. Each of these procedures restarts the microprocessor to the beginning of its microprogram. In this state, the microprocessor does not send or receive messages on the serial line or generate output transfers.

When the PDP-11 program wants the DMC11 to function, it must perform an input transfer that specifies the base address of a 128 word table in PDP-11 memory, which is called the base table. The PDP-11 program requests the BASEI transfer by setting TYPEI to 11. In response to RDYI, the program loads the low-order 16 bits of the address into SEL4 and the high-order 2 bits of the address into bits 15 and 14 of SEL6. If the DDCMP protocol operation is to be initialized, the RESUME bit (bit 13 of SEL6) must be clear.

Once the PDP-11 has specified a base address, the 128 word base table belongs to the microprocessor until the DMC11 is master cleared by INIT or MASTER CLEAR. The PDP-11 program may examine the contents of the base table (for example, error counters relating to protocol operation) but must not alter its contents.

By supplying a base address with the RESUME bit clear, the microprocessor is conditioned to respond to the DDCMP start-up sequence received from the remote system. However, the microprocessor does not initiate the start-up sequence on its own accord unless the PDP-11 program supplies a buffer of data to be transmitted.

If the DMC11 is connected to a half-duplex channel, the PDP-11 program must now perform an input transfer using the Control In format and set the Half Duplex bit (HD) in SEL6 (bit 10). In addition, the program must specify whether the DMC11 is to operate as a half-duplex secondary station (3-second timer) or a half-duplex primary station (1-second timer) by setting or clearing the secondary bit (SEC) in SEL6 (bit 11). A half-duplex link must have one primary station and one secondary station. The only difference between the two is in the length of time spent before retransmitting in case of errors. Half-duplex operation may be specified at any time by a Control In transfer to accommodate switching to a half-duplex backup communications channel. The DMC11 options containing the integral modem must be specifically strapped for half-duplex operation, in addition to requiring the Control In transfer.

#### 3.4.6 DDCMP Start Up

Before data messages can be transmitted or received, the DDCMP start-up sequence must be completed to make certain both ends of the link are correctly initialized and to place the protocol in the running state. Either end may initiate the start sequence or both ends may do so simultaneously. If the PDP-11 program supplies a buffer of data to be transmitted, the local DMC11 initiates the start sequence.

The PDP-11 program may ignore the details of the start sequence. However, one important property of the sequence is significant. Once the local DMC11 has entered the running state, it detects and flags as an error the fact that the other end has initiated the start sequence. As a result, the PDP-11 program receives a Control Out transfer with SEL6 bit 7 (DDCMP START REC'D) set. If this happens, the PDP-11 program knows that the other end of the link has restarted. The PDP-11 program should initialize the DMC11 and begin again.

#### 3.4.7 Data Transmission

When the PDP-11 program wishes to transmit a buffer of data, it clears bits 1 and 0 of BSEL0 to indicate a Buffer Address/Character Count In transfer and clears bit 2 of BSEL0 (INI/O) to specify that this is a full buffer to be transmitted. It then requests an input transfer by setting RQI. In response to RDYI, it loads SEL4 with the low-oder 16 bits of the buffer address, bits 15 and 14 of SEL6 with the high-order bits of the address, and bits 13 to 0 of SEL6 with the 14-bit character count. Buffers from 1 to 16,383 bytes long can be used for local operation. For remote operation, buffers should be limited to a practical maximum of about 512 bytes, depending on the error rate of the communications facilities. Each buffer corresponds to a single DDCMP data message.

When the message has been successfully transmitted and an acknowledgement received, the microprocessor initiates an output transfer with bits 1 and 0 of BSEL2 clear to indicate the Buffer Address/Character Count Out (BA/CC O) format. Bit 2 (OUT I/O) is clear to indicate that a successfully transmitted buffer has been returned to the program.

The PDP-11 program may queue up to seven buffers for transmission by supplying buffers to the microprocessor faster than it returns them. An attempt to queue more than seven buffers forces the microprocessor to delay granting the request for the input transfer until a buffer has been returned.

#### NOTE

The PDP-11 program should not request an input transfer that supplies a transmit buffer if seven are already outstanding, unless it is certain that the other end of the link can supply enough buffers for reception. In particular, if two PDP-11s connected by DMC11s attempt to queue up to eight buffers, while no receive buffers are queued, they become deadlocked and must initialize their DMC11s.

#### 3.4.8 Data Reception

When the PDP-11 program has an empty buffer it wishes to fill with received data, it clears bits 1 and 0 of BSEL0 to indicate a BA/CC I transfer and sets bit 2 of BSEL0 (IN I/O) to specify that an empty buffer has been made available for reception. It then requests an input transfer by setting RQI. In response to RDYI, it loads SEL4 and SEL6 with the buffer address and character count in the same format as for transmission. The character count must be large enough to accommodate the longest measure expected.

When a message has been successfully received and stored in the buffer, the microprocessor initiates an output transfer with bits 1 and 0 of BSEL2 clear to indicate the BA/CC O format. Bit 2 (OUT I/O) is set to indicate a full buffer has been received. SEL4 and SEL6 contain the address of the buffer and the actual number of characters received.

If a message is received when no receive buffer is available, the microprocesor informs the PDP-11 by means of a Control Out transfer, with bit 2 of SEL6 (O'RUN ERR) set. The other end of the link is informed of the error and automatically retransmits the message. The PDP-11 program should supply a buffer as soon as possible.

The PDP-11 may queue up to seven empty buffers for reception by supplying them to the microprocessor faster than it returns buffers. An attempt to queue more than seven buffers forces the microprocessor to delay granting the request for input transfer until a full buffer has been returned.

#### NOTE

The PDP-11 program should not request an input transfer that supplies a buffer for reception if seven are already outstanding, unless it is certain that the other end of the link is supplying buffers for transmission.

#### 3.4.9 Control Out Transfers

The microprocessor informs the PDP-11 program of unusual or error conditions involving the communications channel, remote end of the link, DMC11 hardware, or PDP-11 program by means of an output transfer with bit 1 of BSEL2 clear and bit 0 set indicating a Control Out (CNTL O) transfer. SEL6 contains bits that indicate the error condition. Some errors are advisory in nature and normal operation may continue. Others are fatal and require the PDP-11 program to initialize the DMC11.

Bit 0 (DATA CK) indicates that a retransmission threshold has been exceeded. (More than seven consecutive retransmissions have occurred for transmission or reception.) This indicates a defective communications channel or that the other end of the link has failed to supply a buffer for reception. The PDP-11 can examine error counters in the base table for more details of the error. This is a non-fatal error. Should the cause of the error be corrected, normal operation continues with no messages lost in either direction. This error may appear repeatedly until the condition is corrected or until the DMC11 is initialized. Transient errors corrected before seven retransmissions are not reported to the PDP-11 program but are counted in the base table.

Bit 1 (TIME OUT) indicates that the microprocessor has received no response from the remote end of the link for a specified period (21 seconds). This indicates a broken communications channel or a failure at the other end of the link (possibly a power failure). Like DATA CK, this is a non-fatal error that can occur repeatedly.

Bit 2 (O'RUN ERR) indicates that a message was received but no buffer was available. This is a nonfatal error. The PDP-11 program can prevent this error from recurring repeatedly by supplying a buffer.

Bit 3 (DDCMP MAINT REC'D) indicates that a message in the DDCMP maintenance format was received and that the protocol operation has entered the maintenance state.

Bit 4 (LOST DATA) indicates that a message was received that is longer than the buffer supplied by the PDP-11 program. This is a fatal error.

Bit 6 (DISCONNECT) indicates than an on to off transition of the modem Data Set Ready lead has been detected (remote operation only). This is a non-fatal error. For dial-up operation, the PDP-11 program must consider the possibility that a new caller has connected to the DMC11, if this is required by security considerations.

Bit 7 (DDCMP START REC'D) indicates that a DDCMP Start message was received when the protocol was in the running or maintenance states. This indicates that the remote computer has initialized its end of the link. This is a fatal error. The PDP-11 program may initialize the DMC11 if it wishes to start over and complete the start-up sequence.

Bit 8 (NON EX MEM) indicates that a Unibus address time-out has occurred. This could have been caused by the PDP-11 program specifying an invalid base address, buffer address, or count, which was stored illegally in the base table or the PDP-11 memory, is defective. This is a fatal error.

Bit 9 (PROC ERR) indicates a procedure error on the part of the PDP-11 program. The requested input transfer cannot be honored due to a programming error. This error can be caused by requesting a BA/CC before supplying a base address, requesting a base address a second time, or specifying an invalid code in BSEL0 bits 1 and 0. This is a fatal error.

#### 3.4.10 Maintenance Messages

A special DDCMP message format, the Maintenance message, is used for down line loading, restarting, or otherwise maintaining satellite computer systems. Messages in this format are subject to error checking but are unsequenced, unacknowledged, and not retransmitted automatically by the DMC11. Transmission is always half-duplex.

Maintenance messages can only be sent and received while the microprocessor is in the DDCMP maintenance state. The PDP-11 program may cause the microprocessor to enter this state by a CNTL I transfer with bit 8 of SEL6 (DDCMP MAINT) set. The microprocessor enters the maintenance state if a maintenance message is received. In this case, the microprocessor performs a CNTL O transfer with DDCMP MAINT REC'D set in SEL6 to indicate the state change and availability of a maintenance message.

Once in DDCMP maintenance mode, maintenance messages can be sent and received similarly to data messages. On transmission, the data portion of the message is taken from the buffer with the DMC11 generating the header and CRCs. On reception only, the data portion is placed in the buffer. Messages not in DDCMP maintenance format or having incorrect CRCs are simply discarded.

The data portion of the maintenance message may contain any data that is desired, but ordinarily it conforms to the DIGITAL Maintenance Operation Protocol (MOP) formats. When a host computer wishes to restart a satellite computer system, it must send the appropriate MOP messages as described in the following paragraph.

In order to leave Maintenance mode, the PDP-11 program must initialize the DMC11 and supply a base address with the RESUME bit clear.

#### 3.4.11 Remote Load Detect and Down Line Load

Whenever the microprocessor is running, it is constantly scanning the serial line for a DDCMP maintenance message containing an ENTER MOP MODE data field. What happens when this particular message is received depends on the setting of two switch packs on the DMC11 line unit. Depending on the setting of these switches, the DMC11 will either commence down line loading in MOP mode, trigger the PDP-11 to begin executing a program in a read only memory (ROM) bootstrap (BM873, M9301, etc.), or simply pass the data to the PDP-11 as an ordinary maintenance message. In case a ROM bootstrap is triggered, switches on the line unit specify an 8-bit word offset to the bootstrap address space.

The data portion of the ENTER MOP MODE message is 5 bytes long. The first byte contains the decimal number 6. The remaining 4 bytes contain the same 8-bit value. This value is specified by a switch pack on the DMC11 line unit and serves as a password to protect against inadvertent recognition of the ENTER MOP MODE message.

If an ENTER MOP MODE message is recognized and the switches specify to commence down line loading, the DMC11 microprocessor takes over the PDP-11 computer system. All peripherals on the system are initialized by an INIT sequence and the processor is placed into a tight loop where it remains until control is transferred to a program loaded down the line.

In response to the ENTER MOP MODE message, the DMC11 sends a REQUEST MOP SECOND-ARY MODE message in DDCMP maintenance format containing a data field 3 bytes long that contains the decimal numbers 8.12.1. This informs the remote end that the ENTER MOP MODE message was received.

The remote end should now send a MEMORY LOAD WITH TRANSFER ADDRESS message in DDCMP maintenance format. The firt 2 bytes are zero, the next 4 bytes are an 18-bit memory address right justified, followed by a memory image to be loaded and 4 bytes of transfer address.

Once this message has been successfully received, the DMC11 starts the PDP-11 program at the specified transfer address. The DMC11 must be initialized before it does anything else except recognize a subsequent ENTER MOP MODE maintenance message.

#### 3.4.12 **Power Fail Recovery**

The DMC11 keeps all data necessary to recover from a power failure in its base table. When the PDP-11 program detects a power failure, it should cease requesting input transfers and not respond to output transfers. When power has been restored, the PDP-11 power recovery program can tell the DMC11 microprocessor to recover from the error by performing a BASE I transfer with the RESUME bit set. The original base address must be specified and the contents of the base table must be the same as they were when power was lost; otherwise, the program must start over (RESUME bit clear). As part of the power recovery, the PDP-11 program must repeat an uncompleted input transfer. It must set IEI and IEO as desired. The microprocessor repeats an uncompleted output transfer.

#### 3.4.13 Data Set Control

If the switches on the DMC11 line unit specify bootstrap ROM triggering or down-line loading, the microprocessor maintains Data Terminal Ready continuously, dropping it for a 1-second period following an on to off transition of Data Set Ready. Otherwise, the DMC11 does not turn Data Terminal Ready on until it has received a base address. It drops Data Terminal Ready when initialized by INIT or MASTER CLEAR and it drops it for 1 second following an on to off transition of Data Set Ready provides a CNTL O transfer as previously described, if the DMC11 has been given a base address.

#### 3.5 MICROPROCESSOR CONTROL AND STATUS REGISTERS

#### 3.5.1 Introduction

The Unibus CSRs described in Paragraph 3.4.2 are physically located in the multiport RAM. The RAM capacity is 128 bits arranged as 16 8-bit bytes, which is equivalent to eight 16-bit words. The RAM can be accessed simultaneously from two sources. One source is the Unibus and the other is the microprocessor. Therefore, when these Unibus CSRs (BSEL1-BSEL7) are viewed from the microprocessor, they are called Microprocessor CSRs. Specifically, they are identified as OUTBUS\*/INBUS\* registers 0-7 (octal).

The remaining multiport RAM capacity, which is 8 8-bit bytes, contains the NPR Data and BA registers. These registers are also called Microprocessor CSRs and are specified as OUT BUS/IN BUS registers 0-7 (octal).

There are two additional byte sized hardware registers that are listed in the OUT BUS\*/IN BUS\* category. They are the NPR Control register  $(10_8)$  and the Microprocessor Miscellaneous register  $(11_8)$ .

The microprocessor has the capability of addressing 32 byte sized registers. As a convention, it has been decided to show 16 assigned addresses under each category; that is, OUT BUS\*/IN BUS\* and OUT BUS/IN BUS. As a result, six undefined registers 12-17 (octal) are listed under OUT BUS\*/IN BUS\*. These registers do not exist physically. The line unit device registers,  $10_8-17_8$  have been added to the OUT BUS/IN BUS category. These registers are physically located in the line unit. Address  $10_8$  is listed twice because two line unit registers use the same address. The In Data Silo is read only and the Out Data Silo is write only. Therefore, there are nine registers in the line unit.

The arrangement of the Microprocessor CSRs is shown in Figure 3-2.



11 - 4370

Figure 3-2 Microprocessor Registers

The detailed discussion of the Line Unit CSRs is contained in Paragraph 3.6.

3.5.2 OUT BUS\*/IN BUS\* Registers 0-7 These eight registers are identical to those described in Paragraphs 3.4.2.1 through 3.4.2.5.

| Bit | Name                    | Description                                                                                                                                                         |                                                                                                                                                                                                                      |                                                                                                                                               |                                                                                                                                                                                                                                            |
|-----|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | NPR REQUEST<br>(NPR RQ) | This bit can<br>the hardwar<br>set, this bit r<br>11 memory.<br>ferred from<br>data is trans<br>XFER) cont                                                          | be set only. It<br>when the NPR<br>equests an NPR<br>If OUT NPR (be<br>the PDP-11 me<br>ferred to the PD<br>trols word/byte                                                                                          | is autom<br>has been<br>via the U<br>it 4) is cle<br>mory. If<br>P-11 men<br>selection.                                                       | atically cleared by<br>completed. When<br>Inibus to the PDP-<br>ared, data is trans-<br>OUT NPR is set,<br>nory. Bit 7 (BYTE                                                                                                               |
|     |                         | For an IN N<br>BUS/IN BU<br>address is in<br>data that is<br>OUT BUS/<br>and from O<br>DATA. OU<br>BYTE XFE<br>BYTE XFE<br>bit (0) is use<br>type of tran<br>below. | IPR, the PDP-11<br>JS registers 4 and<br>OUT BUS/IN<br>associated with<br>IN BUS register<br>UT BUS/IN BU<br>T NPR (bit 4) is<br>R (bit 7) is Unil<br>R is set, the state<br>ed to select the b<br>saction, as selec | memory<br>d 5. For a<br>BUS register<br>the transa<br>s 2 and 3<br>JS register<br>Unibus C<br>bus Cont<br>e of the B<br>yte. The<br>ted by th | address is in OUT<br>an OUT NPR, the<br>isters 6 and 7. The<br>action comes from<br>8 for OUT DATA<br>ers 0 and 1 for IN<br>Control line C1 and<br>rol line C0. When<br>bA least significant<br>truth table for the<br>nese bits, is shown |
|     |                         | OUT NPR<br>(C1)                                                                                                                                                     | BYTE XFER<br>(C0)                                                                                                                                                                                                    | BA0                                                                                                                                           | Unibus<br>Transaction                                                                                                                                                                                                                      |
|     |                         | 0                                                                                                                                                                   | 0                                                                                                                                                                                                                    | 0                                                                                                                                             | DATI                                                                                                                                                                                                                                       |
|     |                         | 0                                                                                                                                                                   | 0                                                                                                                                                                                                                    | 1                                                                                                                                             | DATI                                                                                                                                                                                                                                       |
|     |                         | 0                                                                                                                                                                   | 1                                                                                                                                                                                                                    | 0                                                                                                                                             | Illegal                                                                                                                                                                                                                                    |
|     |                         | 0                                                                                                                                                                   | 1                                                                                                                                                                                                                    | 1                                                                                                                                             | Illegal                                                                                                                                                                                                                                    |
|     |                         | 1                                                                                                                                                                   | 0                                                                                                                                                                                                                    | 0                                                                                                                                             | DATO                                                                                                                                                                                                                                       |
|     |                         | 1                                                                                                                                                                   | 0                                                                                                                                                                                                                    | 1                                                                                                                                             | DATO                                                                                                                                                                                                                                       |
|     |                         | 1                                                                                                                                                                   | 1                                                                                                                                                                                                                    | 0<br>Byte)                                                                                                                                    | DATOB (Low                                                                                                                                                                                                                                 |
|     |                         | 1                                                                                                                                                                   | 1                                                                                                                                                                                                                    | l<br>Byte)                                                                                                                                    | DATOB (High                                                                                                                                                                                                                                |
| 1   | READ/WRITE (R/W)        | This read/w<br>treated in th                                                                                                                                        | rite bit provides<br>e microcode as a                                                                                                                                                                                | s no func<br>a flag or                                                                                                                        | ction and may be<br>state indicator.                                                                                                                                                                                                       |

### 3.5.3 NPR Control Register (OUT BUS\*/IN BUS\* 10)

| Bit  | Name                     | Description                                                                                                                                                                                                                                                                                                                                      |
|------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2, 3 | IN BA 16 and<br>IN BA 17 | These are the PDP-11 memory extension bits used during an IN NPR ( $C1 = 0$ ) transaction.                                                                                                                                                                                                                                                       |
| 4    | OUT NPR                  | This bit is used in association with NPR RQ (bit 0). The details of the inter-relationship between these bits are covered in the description of NPR RQ (bit 0).                                                                                                                                                                                  |
| 5, 6 | RESERVED                 |                                                                                                                                                                                                                                                                                                                                                  |
| 7    | BYTE XFER                | This bit is used in association with OUT NPR to<br>indicate a byte transfer to the PDP-11 memory. When<br>this bit is set, the PDP-11 uses address bit A0 for byte<br>selection. If A0 is a 0, OUT DATA 7-0 is stored in the<br>low byte of the PDP-11 memory. If A0 is a 1, OUT<br>DATA 7-0 is stored in the high byte of the PDP-11<br>memory. |
|      |                          | If BYTE is cleared during an OUT NPR operation,<br>OUT DATA 15-0 is transferred to the PDP-11 memory<br>as a word.                                                                                                                                                                                                                               |

## 3.5.4 Microprocessor Miscellaneous Register (OUT BUS\*/IN BUS\* 11)

| Bit  | Name                                   | Description                                                                                                                                                                                                                                                                |
|------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | NON-EXISTENT<br>MEMORY<br>(NON-EX MEM) | During an NPR, this bit is set approximately 20 $\mu$ s after<br>a non-existent memory location is addressed by the<br>microprocessor. At this time, the NPR logic releases the<br>Unibus.                                                                                 |
| 1    | AC LOW                                 | This bit is a set only bit. When set, it triggers a 1-shot with a pulse duration of 0.5 second. This pulse goes to the Unibus and initiates a power fail recovery procedure in the PDP-11 processor.                                                                       |
| 2, 3 | OUT BA 16 and<br>OUT BA 17             | These are the PDP-11 memory extension bits used dur-<br>ing an OUT NPR transfer.                                                                                                                                                                                           |
| 4    | PROGRAM CLOCK<br>(PGM CLK)             | This bit acts as a timer for the microprocessor. It can be<br>read to determine lapse time for time-out, flag testing,<br>etc.                                                                                                                                             |
|      |                                        | This bit is the 0 output of a retriggerable 1-shot with a 1 second pulse duration. As long as the triggering pulses come along at less than 1 second intervals, the 1-shot remains asserted and this bit is read as a 0. If the 1-shot times out, this bit is read as a 1. |
| 5    | RESERVED                               |                                                                                                                                                                                                                                                                            |

| Bit | Name                  | Description                                                                                                                                                                                                                                                 |
|-----|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | VECTOR AT XX4         | If this bit is set when BR RQ (bit 7) is set, vector address XX4 is generated. If it is cleared when BR RQ is set, vector address XX0 is generated. Address XX0 is associated with RDYI and address XX4 is associated with RDYO.                            |
| 7   | BR REQUEST<br>(BR RQ) | When set, this bit initiates a Bus Request via the Unibus<br>at BR level 4, 5, 6, or 7. The microprocessor is shipped<br>with a BR5 priority card installed. This bit can be set<br>only and is cleared by the hardware after the BR has<br>been completed. |

| 3.5.5 NPR Bus Address and Data Registers (OUT BUS/IN H | BUS 0-7) |  |
|--------------------------------------------------------|----------|--|
|--------------------------------------------------------|----------|--|

| Register | Name     | Description                                                                                                                                              |
|----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0, 1     | IN DATA  | Low byte (register 0) and high byte (register 1) of data to be transferred from the PDP-11 memory.                                                       |
| 2, 3     | OUT DATA | Low byte (register 2) and high byte (register 3) of data to be transferred to the PDP-11 memory.                                                         |
| 4, 5     | IN BA    | Contains Bus Address (BA) bits 0-15 during an NPR transfer from the PDP-11 memory. Bit 0 of register 4 is BA bit 0 and bit 7 of register 5 is BA bit 15. |
| 6, 7     | OUT BA   | Contains Bus Address (BA) bits 0-15 during an NPR transfer to the PDP-11 memory. Bit 0 of register 6 is BA bit 0 and bit 7 of register 7 is BA bit 15.   |

#### **3.6 LINE UNIT REGISTERS**

#### 3.6.1 In/Out Data Silo Registers (10)

The In Data Silo is loaded with eight bits of received data from the Receiver Data register. When the microprocessor performs a read operation on this register, the data is presented to the IBUS.

Physically, the In Data Silo is in the form of a 64 word by 12 bit silo. The other four bits are considered to be part of the In Control register.

When the microprocessor performs a write operation on the In Data Silo, nothing happens to this register. However, the eight bits of data to be transmitted are taken from the OBUS and are presented to the input of the Out Data Silo, which is a 64 word by 12 bit silo. The other four bits are considered to be part of the Out Control register.

### 3.6.2 Out Control Register (11)

| Bit | Name                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | TSOM<br>(Transmit Start<br>of Message) | This bit is used to initiate the start of a new message.<br>DDCMP Mode: The Sync character must be loaded<br>into the Out Data Silo along with TSOM bit. This char-<br>acter is transmitted as the Sync character until TSOM is<br>cleared. Until it is cleared, the characters are not includ-<br>ed in the CRC accumulation. When TSOM is cleared,<br>the present Sync character is transmitted and is followed<br>by data. All data is included in the CRC accumulation,<br>if CRC is enabled. Once TSOM has been set, the CRC<br>accumulation cannot be inhibited unless the line unit is<br>initialized.                                                                                                                                                     |
|     |                                        | Bit Stuff Mode: When TSOM is set, a flag character is<br>automatically transmitted. The character that is loaded<br>with the TSOM bit is lost. Flag characters are automat-<br>ically transmitted as long as TSOM is set. When data is<br>to be transmitted, TSOM is cleared and data is loaded<br>into the Out Data Silo. At the completion of the current<br>flag character, the actual transmission of data begins.<br>All information to be transmitted is included in the<br>CRC accumulation, if the CRC function is enabled.<br>This bit is program write only. It is cleared by the<br>initialization logic and by the fact that data was loaded<br>into the Out Data Silo. It is loaded into the silo and<br>passed to the transmitter through the silo. |
| 1   | TEOM<br>(Transmit End<br>of Message)   | This bit is used to terminate the message in progress and<br>control the transmission of the CRC character, if the<br>CRC function is enabled.<br>DDCMP Mode: When TEOM is set, the CRC character<br>is transmitted. If no more messages are pending (TSOM)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |                                        | <ul> <li>bit Stuff Mode: When TEOM is set, the character loaded with it is lost. The CRC character is transmitted. If no more messages are pending, the transmitter is shut down by having a second TEOM in the silo. This generates a single closing or intermessage flag.</li> <li>This bit is program write only. It is cleared by the initialization logic and by the TSIP flip-flop, which is set whenever data is loaded into the Out Data Silo.</li> </ul>                                                                                                                                                                                                                                                                                                 |

| Bit              | Name                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2, 3             | Reserved               | These bits are program write only. They are cleared by<br>the initialization logic and by the TSIP flip-flop, which<br>is set whenever data is loaded into the Out Data Silo.<br>These bits and bits 0 and 1 are passed to the transmitter<br>through the silo every time register 10 is written into;<br>therefore, if the CONTROL IN format is to be sent,<br>these bits must be written before register 10 is written<br>into.                           |
| 4                | OUT RDY<br>(Out Ready) | When asserted, this bit informs the microprocessor that<br>the transmitter is ready to accept data. It indicates that<br>space is available in the Out Data Silo. The micro-<br>processor loads the Out Data Silo and then reads OUT<br>RDY. The speed of the microprocessor allows OUT<br>RDY to be read and interpreted as true before the silo<br>has loaded the data. Therefore, one cycle must elapse<br>between loading the silo and reading OUT RDY. |
|                  |                        | This bit is read only.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5                | Reserved               | Read only. Physically, this bit is a switch.                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6                | OUT ACTIVE             | OUT ACTIVE informs the microprocessor of the status<br>of the transmitter. When it is set, the transmitter is<br>active.                                                                                                                                                                                                                                                                                                                                    |
|                  |                        | This bit is read only. It is set by the hardware and cleared by the initialization logic.                                                                                                                                                                                                                                                                                                                                                                   |
| 7<br>(OUT CLEAR) | OCLRP                  | This bit is used to clear all the transmitted functions.<br>OCLRP is program write only.                                                                                                                                                                                                                                                                                                                                                                    |

#### 3.6.3 In Control Register (12)

.

| Bit | Name                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | BCC MATCH<br>(Block Check<br>Character Match) | BCC MATCH is the output of the receiver CRC error<br>logic that monitors the contents of the CRC register.<br>With the CRC function enabled, BCC MATCH is<br>asserted at the end of an errorless message. In the<br>DDCMP protocol, the contents of the Receiver CRC<br>register equal zero when an errorless message has been<br>received. In the SDLC protocol, the contents of the<br>Receiver CRC register equal 016417. |
|     |                                               | This bit is read only and is updated everytime register 10 is read.                                                                                                                                                                                                                                                                                                                                                          |

| Bit  | Name                                         | Description                                                                                                                                                                                                                                                                                                                                                                 |
|------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | BLOCK END                                    | BLOCK END is used to inform the microprocessor, in<br>SDLC mode, that a terminating flag has been received.<br>This flag may be the leading flag for the next message.<br>The BLOCK END bit is loaded with the high byte of the<br>CRC character; therefore, the BLOCK END bit, along<br>with the BCC MATCH bit, should be used to indicate<br>reception of a good message. |
|      |                                              | This bit is read only and is not used in the DDCMP mode. It is updated everytime register 10 is read.                                                                                                                                                                                                                                                                       |
| 2, 3 | Reserved                                     | When asserted, this bit informs the microprocessor that<br>received data is ready for processing. It indicates that<br>data is available at the output of the In Data Silo.                                                                                                                                                                                                 |
|      |                                              | This bit is read only.                                                                                                                                                                                                                                                                                                                                                      |
| 5    | ALT LU LOOP<br>(Alternate Line<br>Unit Loop) | During maintenance, this bit is set to loop the receiver<br>on the transmitter with no connection to the modem<br>control lines.                                                                                                                                                                                                                                            |
|      |                                              | This bit is program read/write.                                                                                                                                                                                                                                                                                                                                             |
| 6    | IN ACTIVE                                    | When asserted, this bit informs the microprocessor that<br>the receiver is in the data reception mode; that is, it is<br>receiving data or CRC characters.                                                                                                                                                                                                                  |
|      |                                              | DDCMP Mode: IN ACTIVE is asserted upon receipt of the first non-sync character.                                                                                                                                                                                                                                                                                             |
|      |                                              | SDLC Mode: IN ACTIVE is asserted upon receipt of the first data character.                                                                                                                                                                                                                                                                                                  |
| 7    |                                              | This bit is used to clear all the receiver functions.                                                                                                                                                                                                                                                                                                                       |
|      | (In Clear)                                   | ICLRP is program write only.                                                                                                                                                                                                                                                                                                                                                |

### 3.6.4 Modem Control Register (13)

| Bit | Name   | Description                                                                                                                                        |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | SECURE | The function of this bit is reserved for future use. This read only bit is selected by a switch. SECURE is asserted when the switch is OFF (open). |
| 1   | SW     | The function of this bit is reserved for future use. This read only bit is selected by a switch. SW is asserted when the switch is OFF (open).     |

| Bit | Name                            | Description                                                                                                                                                                                                                                                                |
|-----|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2   | CS<br>(Clear to Send)           | The CS bit informs the microprocessor of the state of<br>the modem Clear to Send line. This bit and MODEM<br>RDY (bit 3) must be asserted simultaneously to generate<br>SEND, which is the transmitter enabling signal.                                                    |
|     |                                 | This bit is read only.                                                                                                                                                                                                                                                     |
| 3   | MODEM RDY<br>(Modem Ready)      | The MODEM RDY bit informs the microprocessor of<br>the state of the Modem Ready line. On the M8201 L ine<br>Unit, this signal can be held asserted permanently<br>through the use of a jumper. On the M8202 Line Unit,<br>this signal is asserted when power is turned on. |
|     |                                 | This bit is read only.                                                                                                                                                                                                                                                     |
| 4   | HDX<br>(Half Duplex)            | The HDX bit is used to put the line unit in the half-<br>duplex mode. When this bit and the Request to Send bit<br>are asserted, the receiver clock is inhibited, which blinds<br>the receiver during operation in the half-duplex mode.                                   |
|     |                                 | This bit is program read/write and can be directly cleared by the clear signal from the microprocessor.                                                                                                                                                                    |
| 5   | RS<br>(Request to<br>Send)      | The RS bit informs the microprocessor of the state of<br>the modem Request to Send line. This bit is controlled<br>by the line unit logic and not by the microprocessor. It is<br>cleared by absence of data or by the initialization logic.                               |
|     |                                 | This bit is read only.                                                                                                                                                                                                                                                     |
| 6   | DTR<br>(Data Terminal<br>Ready) | The DTR bit enables the modem via the Data Terminal<br>Ready line. This bit is program read/write. It is directly<br>set by the initialization logic but it can be cleared only<br>by writing a 0 into it.                                                                 |
| 7   | RING                            | The RING bit informs the microprocessor of the state<br>of the modem Ring line. RING is inhibited on the<br>M8202 Line Unit.                                                                                                                                               |
|     |                                 | This bit is read only.                                                                                                                                                                                                                                                     |

#### 3.6.5 Sync Register (14)

The Sync register is an 8-bit program read/write register.

DDCMP Mode: The register is loaded with a program selectable sync character.

Bit Stuff: In the secondary mode, this register is loaded with secondary station address. This 8-bit character follows the initial flag in the SDLC message format.

3.6.6 Switch Selectable Registers (15 and 16) Both of these registers are DIPs containing eight switches each. The program determines the function of both registers.

| Bit | Name                                    | Description                                                                                                                                                         |
|-----|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | MODE                                    | The MODE bit selects the protocol (DDCMP or Bit<br>Stuff families). When set, DDCMP is selected; when<br>cleared, Bit Stuff is selected.                            |
|     |                                         | During initialization, the CLEAR signal from the microprocessor sets this bit to select DDCMP. This bit can be cleared (SDLC selected) only by writing a 0 into it. |
|     |                                         | This bit is read/write.                                                                                                                                             |
| 1   | ESC<br>(Internal Clock)                 | ECS is the output of the internal RC clock (approx-<br>imately 10 kHz). This bit is read only.                                                                      |
| 2   | Reserved                                | Read only.                                                                                                                                                          |
| 3   | ICIR<br>(In Composite                   | When asserted, this bit indicates that the In Data Silo is ready to accept data.                                                                                    |
|     | input Ready)                            | This bit is read only.                                                                                                                                              |
| 4   | OCOR<br>(Out Composite<br>Output Beady) | When asserted, this bit indicates that data is ready at the output of the Out Data Silo.                                                                            |
|     | Output Ready)                           | This bit is read only.                                                                                                                                              |
| 5   | SI                                      | SI is the serial input data from the modem.                                                                                                                         |
|     | (Serial Input)                          | This bit is read only.                                                                                                                                              |
| 6   | QI<br>(Quotient In)                     | QI is the least significant bit of the Receiver CRC register.                                                                                                       |
|     |                                         | This bit is read only.                                                                                                                                              |
| 7   | QO<br>(Outstight Out)                   | QO is the least significant bit of the CRC register.                                                                                                                |
|     | (Quotient Out)                          | This bit is read only.                                                                                                                                              |

#### 3.6.7 Maintenance Register (17)

### APPENDIX A PDP-11 MEMORY ORGANIZATION AND ADDRESSING CONVENTIONS

The PDP-11 memory is organized in 16-bit words consisting of two 8-bit bytes. Each byte is addressable and has its own address location; low bytes are even numbered and high bytes are odd numbered. Words are addressed at even numbered locations only and the high (odd) byte of the word is automatically included to provide a 16-bit word. Therefore, consecutive words are found in even numbered addresses. A byte operation addresses an odd or even location to select an 8-bit byte.

The Unibus address word contains 18 bits identified as A(17:00). Eighteen bits provide the capability of addressing 256K memory locations, each of which is an 8-bit byte. This also represents 128K 16-bit words. In this discussion, the multiplier K equals 1024, so that 256K represents 262,144 locations and 238K represents 131,072 locations. The maximum memory size can be used only by a PDP-11 processor with a memory management unit that utilizes all 18 address bits. Without this unit, the processor provides 16 address bits, which limits the maximum memory size to 64K (65,536) bytes or 32K (32,768) words.

Figure A-1 shows the organization for the maximum memory size of 256K bytes. In the binary system, 18 bits can specify 2<sup>18</sup> or 262,144 (256K) locations. The octal numbering system is used to designate the address. This provides convenience in converting the address to the binary system that the processor uses as shown below.

The highest 8K address locations (760000–77777) are reserved for internal general registers and peripheral devices. There is no physical memory for these addresses; only the numbers are reserved. As a result, programmable memory locations cannot be assigned in this area; therefore, the user has 248 bytes or 124K words to program.

A PDP-11 processor without the memory management unit provides 16 address bits that specify 2<sup>16</sup> or 65,536 (64K) locations (Figure A-2). The maximum memory size is 65,536 (64K) bytes or 32,768 (32K) words. Logic in the processor forces address bits A(17:16) to 1s if bits A(15:13) are all 1s when the processor is master to allow generation of addresses in the reserved area with only 16-bit control.

| 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ADDRESS BIT |
|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------|
| 0  | 0  | 1  | 0  | 0  | 1  | 1  | 1  | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | BINARY      |
|    | 1  |    |    | 1  |    |    | 7  |   |   | 6 |   |   | 0 |   |   | 1 | • | OCTAL       |

11 - 4401



Figure A-1 Memory Organization for Maximum Size Using 18 Address Bits



Figure A-2 Memory Organization for Maximum Size Using 16 Address Bits

Bit 13 becomes a 1 first at octal 160000, which is decimal 57,344 (56K). This is the beginning of the last 8K bytes of the 64K byte memory. The processor converts locations 160000-177777 to 760000-777777, which relocates these last 8K bytes (4K words) to the highest locations accessible by the bus. These are the locations that are reserved for internal general register and peripheral device addresses; therefore, the user has 57,344 (56K) bytes or 28,672 (28K) words to program.

Memory capacities of 56K bytes (28K words) or under do not have the problem of interference with the reserved area, because designations less than 160000 do not have a binary 1 in bit A13. No addresses are converted and there is no possibility of physical memory locations interfering with the reserved space.

PDP-11 core memories are available in 4K or 8K increments. The highest location of various size core memories is shown below.

| ry Size | Highest Location                                             |
|---------|--------------------------------------------------------------|
| K-Bytes | (Octal)                                                      |
| 8       | 017777                                                       |
| 16      | 037777                                                       |
| 24      | 057777                                                       |
| 32      | 077777                                                       |
| 40      | 117777                                                       |
| 48      | 137777                                                       |
| 56      | 157777                                                       |
|         | 8<br><b>K-Bytes</b><br>8<br>16<br>24<br>32<br>40<br>48<br>56 |

### **Reader's** Comments

Your comments and suggestions will help us in our continuous effort to improve the quality and usefulness of our publications.

What is your general reaction to this manual? In your judgment is it complete, accurate, well organized, well written, etc.? Is it easy to use?

What features are most useful?

CUT OUT ON DOTTED LINE

What faults do you find with the manual?

Does this manual satisfy the need you think it was intended to satisfy?

Would you please indicate any factual errors you have found.

|                                |       | · · ·          |  |
|--------------------------------|-------|----------------|--|
| Please describe your position. |       |                |  |
| Name                           |       | Organization   |  |
| Street                         |       | Department     |  |
| City                           | State | Zip or Country |  |

Does it satisfy your needs? \_\_\_\_\_ Why? \_\_\_\_\_

Fold Here

- Do Not Tear - Fold Here and Staple -

-

BUSINESS REPLY MAIL
NO POSTAGE STAMP NECESSARY IF MAILED IN THE UNITED STATES
Postage will be paid by:
Digital Equipment Corporation

Technical Documentation Department

Maynard, Massachusetts 01754

146 Main Street

FIRST CLASS PERMIT NO. 33 MAYNARD, MASS.

# d i g i t a l

### digital equipment corporation