## EDEDED

## 11 MAINFRAME PDP 11/40



11 MAINFRAME
PDP 11/40

## LEARNING ACTIVITY UNIT

## KDll-A INTRODUCTION AND OVERVIEW

## DECEMBER 18, 1973

## RATIONALE

Welcome to the wonderful world of the PDP-11/40. You have now completed your study of the PDP-11/05 and you should have a solid foundation of PDP-11 principles which you will use to develop your understanding of the $11 / 40$. Don't feel that you are going on to something completely different and that you can therefore forget about the 05. The 40 is really just an extension of the 05 in that many of the concepts are similar and many of the basic operations are done in almost an identical fashion. Following are some of the features of the 40 that you will find to be similar to what you already know about the 05 .

1. The operation of functions internal to the C.P. are controlled by a Read Only Memory (ROM).
2. The Bus Control is handled in a similar fashion, which must be so since all of the controlling signals on the PDP-11 Unibus are identical regardless of the C.P. being used.
3. The C.P. contains a set of 16 registers which are used by the programmer (RO - R7) and for handling some of the internal operations (R10-Rl7).
4. The instruction set is identical to that used on the 05 with the exception of a few additional instructions.
5. Console operations are identical with the addition of a few more indicators. So you can see that you already have a lot of information which is relevant to the 11/40.

During this unit you will be having what essentially amounts to a discussion period among you, your fellow students and your instructor. The instructor will attempt to point out all of the similarities and differences between the $11 / 05$ and the $11 / 40$. He will also discuss the specifications and applications of ll/40's. He will summarize the
the objectives of the $11 / 40$ course and outline for you what you will be doing for the next four days or so. Please feel free to debate points with your instructor and among yourselves under the guidance of the instructor.

In some ways this is the most important lesson on the 40 since it will help you to tie together facts which you have learned about the 05 with information you are finding out about the 40 . In addition this lesson should help you to make the transition from the 05 course to the 40 course and start you on your way to becoming PDP-11/40 giants.

## PREREQUISITES

Successful completion of the PDP-11/05 portion of the course.

## OBJECTIVES

To demonstrate knowledge of some of the major characteristics of the $11 / 40$ by correctly answering five out of the six questions given in the post test.

## LEARNING ACTIVITIES

## I. Attend the 90 minute discussion period. Please ask any questions you have concerning $11 / 40$ specifications, applications, systems concepts, configurations, etc. Be sure to take note of references made to figures, drawings, tables, etc. during the discussion.

II. Attempt the post test. You have 20 minutes.

## APPENDIX A

The following list is a point outline of the $11 / 40$course. Each point is a two hour LAU.

1. KD11A Introduction and Overview (this LAU).
2. Block Diagram: multiplexors and data paths.
3. Block Diagram: control section.
4. Block Diagram: clocking, Unibus control, branching.
5. Flow Diagram: introduction, overview, instruction format.
6. Flow Diagram: Jamupp to console, console.
7. Flow Diagram: single operand instructions.
8. Flow Diagram: double operand instructions, overlap.
9. Flow Diagram: traps/service.
10. Lab Project: maintenance module usage
11. Logic Diagrams: conventions, special circuits, layout
12. Logic Diagrams: data paths, $\mu$ word. IR decode.
13. Logic Diagrams: timing, Jamupp.
14. Logic Diagrams: status, bus control
15. Lab Project: scoping clock, Unibus.
16. Power System: block diagram, distribution.

## SYSTEM HIERARCHY



## APPENDIX C

THE MARK INSTRUCTION
The MARK is an instruction that facilitates stack cleanup procedures when returning from a subroutine. Stack cleanup simply means resetting Stack Pointer R6 to the value it contained just prior to jumping to the subroutine. It is unique in that the instruction itself is executed off the stack.

## PROGRAMMING OPERATION

The routine shown below illustrates the operation of the MARK and may be used by the technician to check for proper operation.

```
Given R5 = 1234, R6 = 2000
5000/MOV R5, - (6) ;(1776) 1234, old R5
        2/MOV #20, -(6) ;(1774) 20, P1
        4/#20
        6/MOV #30, -(6) ;(1772) 30, P2
    10/#30
    12/MOV #40, -(6) ;(1770) 40, P3
    14/#40
    16/MOV #MARK3, -(6) ;(1766) 006403, MARK3 instr.
    20/#MARK3
    22/MOV R6, R5 (; (5) 1766, content of R5 = adrs
    24/JSR PC, 6000 ; dst }->\mathrm{ R [TEMP], (TEMP) 6000
    26/index
5030/HALT
; (1776) 1234, old R5
; (1774) 20, Pl
; (1772) 30, P2
; (1770) 40, P3
;(1766) 006403, MARK3 instr.
; (5) 1766, content of \(\mathrm{R} 5=\) adrs of MARK 3 instr
; dst \(\rightarrow\) [TEMP] , (TEMP) 6000
\(; R[S P]-2 \rightarrow R[S P]\), (6) 1764
\(; R[S F] \rightarrow @ R[S P],(1764) 5030\)
\(; R[P C] \rightarrow R[S E]\), (7) 5030
\(; R[T E M P] \rightarrow R[P C]\), (7) 6000
```



APPENDIX C

Load address to 5000 and depress START. The instruction in 5000 saves the contents of R5 (325) on the stack in location 1776. The next three MOV instructions in 5002, 5006, and 5012 push three parameters onto the stack. Then the instruction in location 5016 pushes the MARK instruction (6403) onto the stack into location 1766. At this point, R6 contains 1766, which is transferred into R5 when the MOV instruction in location 5022 is executed.

Finally, the JSR is executed, which saves the return PC on the stack in location 1764 and causes program control to transfer to location 6000 where the machine halts.

After the machine halts, the registers and stack appear as shown below:


Normally at this point the subroutine would use the SP to retrieve the parameters for its execution.

Now press CONT. This will cause execution of the RTS instruction in 6002. The RTS will transfer the contents of $R 5$ (1766) into the PC and pop 5030 off the stack into

R5. Since the PC contains 1766, the next instruction executed will be the MARK instruction. After fetching the MARK, the PC gets updated to 1770 , then the SP gets the contents of the PC (1770) plus two times the number of arguments (6) which is 1776. The PC gets the contents of R5 (5030) therefore pointing to the next instruction after the JSR. Then 1234 is popped off the stack and put into R5 which restores the C.P. to the correct condition to continue on in the main program.


## APPENDIX D-2

## KDll-A MODULES

55-09701 KYll-D Console, hex, no module pins, two back side connectors to connect to K1 \& K5 modules via cables

M981

M7231

M7232

M7233

M7234

M7235
*M7236
*M7237
*M7238
*M7239
*M787
*W130, w131

Small
Peripheral

Unibus cable connection with terminator, double height

Kl, Data Path, hex, one back side connector to console

K2, U Word, quad. three back side connectors to M7238 (EIS)

K3, IR Decode, hex

K4, Timing, hex, clock adjustment
K5, Status, hex, one back side connector to console

KTll-D, Memory Management, hex
KJ1l-A, Stack Limit Register, single height

KEll-E, EIS option, hex, three back side connectors to M7232

KEll-F, FIS option, quad
KWll-L Line Clock option, single height KM11, Maintenance module set

1) Processor

2 slots reserved
2) Options

1) KLll: M105 single
2) DLll

M7820 single M7800 quad M780 double

[^0]

CONNECTORS ON BACK EDGE OF MODULE

* MAINT. MODULE SLOTS

EI EIS/FIS/KT11-D
FI BASIC PROCESSOR

APPENDIX E
LIST OF SOME 11/40 APPLICATIONS
Communications: Message Switching, Data Concentration, Remote Terminals, System "Front Ends"
Engineering: Calculation, Design and Drafting, Sim- ulation, Graphics
Computation: Scientific Calculation, In-house Time-sharing, Timesharing Utilities, HybridSystems (A/D)
Business: Inventory Control, General Accounting, Payroll, Reservations, Text Editing, Data Storage and Retrieval, Order Entry, Source Data Collection, Key-to-Tape
Education: Computer-aided Instruction, Programming Courses, Computer Science Courses, Problem Solving, Engineering Courses, Administrative Processing
Industry: Data Acquisition and Control, Data Monitoring and Logging, Machine Control, Numerical Control, Testing, Process Control, Typesetting, Traffic Control, Electric Utility Monitoring and Control
Research: Oceanographic Studies, Gas Chromat- ography/Mass Spectroscopy, Signal Processing

## APPENDIX F

## LIST OF $11 / 40$ INTERNAL OPTIONS

## KEll-E, Extended Instruction Set

KEll-F, Floating Instruction Set
KTll-D, Memory Management
KJll-A, Stack Limit Register
KWll-L, Line Frequency Clock

## APPENDIX G

## LIST OF THE BASIC 11/40 MAINDECS

CPU

| T1 | Branch |
| :--- | :--- |
| T2 | Conditional Branch |
| T3 | Unary |
| T4 | Binary |
| T5 | Rotate/Shift |
| T6 | CMP Equality |
| T7 | CMP Non-equality |
| T8 | Move |
| T9 | Bit Set Clear Test |
| T10 | ADD |
| T11 | Subtract |
| T12 | Jump |
| T13 | JSR, RTS, RTI |
| T14 | 40 Traps Test |
| T15 | ll Family Instruction Exerciser |
| T17 | System Exerciser |
|  | Power Fail |
|  | General Test Program |
|  | Basic Address Test Up |
|  | Basic Address Test Down |
|  | No Dual Address Test |
|  | Basic Test Patterns |
|  | Moving Ones and Zeros |
|  | One's Susceptibility |
|  | Worst Case Noise |
|  | Core Heating |
|  | Random Data |
|  | 8K Special |
|  | Up-Down Address Test |
|  | Memory I/O Exerciser |
|  | 0-l24K Exerciser |

## LEARNING ACTIVITY UNIT

## KDllA PROCESSOR

## BLOCK DIAGRAM

DATA PATHS

1/9/73

## RATIONALE

Previously, you have been introduced to the $11 / 40$ and have studied it from a physical point of view. You have seen the mechanics of the mounting box, the cabinet, module locations, etc. You have also studied the $11 / 05$ processor and have seen how a C.P. can be depicted in a block diagram format.

Now you are going to be introduced to the KDllA Block Diagram. You will observe how the C.P. can be broken into three basic sections of which, in this unit, we are primarily interested in the Data Path section. You will learn the name and function of each of the major components in this section and how data is manipulated for various operations.

The skills you learn in this unit will prove invaluable in future LAU's, since you will be doing similar analysis in studying the other portions of the block diagram. More importantly, you will find the block diagram to be indispensible as a trouble shooting aid. For example, once you have properly analyzed the symptoms of a problem, you will be able to narrow its location down to one of the major components within that section if you have a good understanding of the block diagram.

## PREREQUISITES

Satisfactory performance to this unit.

## OBJECTIVES

Using the list of Data Manipulation Functions in Appendix B and any other reference material, write the sets of functions required to implement a given instruction.

## LEARNING ACTIVITIES

I. LECTURE

Attend the twenty minute lecture. Pay close attention, and jot down notes on the block diagram itself. Hold questions until the end of the lecture.
II. PROJECTS AND PROBLEMS
A.

1. Do the problems and answer all the questions. You will find the correct answers in Appendix A.
2. Refer to the KD1lA Processor Maintenance Manual, Table 3-3 on p. 3-23 to p. 3-34.
3. All page references made in this LAU are to the above mentioned manual unless specifically stated otherwise.
4. As you go through the following projects, make pertinent notes on your block diagram. These should prove to be invaluable trouble shooting aids in the lab and in the field.
B. Locate the Arithmetic Logic Unit (ALU) approximately in the center of the page.
5. Observe that there are five control lines going into the ALU. These will cause the ALU to execute one of thirty-two functions which are shown in Table 3-2 on p. 3-17. Study this table and analyze the various functions.
6. Make special note of the function specified by the *. What two instructions would make use of this operation? Mark this on your block diagram since this is the only place in the machine where this operation occurs.
C. Locate the D Reg and the D Mux just below the ALU.
7. Specification of which input is to be gated through the D Mux is done by the and $\qquad$ signals.
8. Analyze the function of the box labeled D $(C)$.
9. Refer to Table 3-1 on p. 3-14. Which of the following combinations of signals would allow an instruction to be read in from core, gated through the D Mux and presented to the I Reg?
(a) SDM1 (0) * SDMO (0)
(b) SDM1 (0) * SDMO (1)
(c) SDM1 (1) * SDMO (0)
(d) SDM1 (1) * SDMO (1)

Check your answer. If you were correct, go on to section D. If not, read the following description.

We are fetching an instruction. We have done the bus cycle and the data (which is the instruction) is on the Unibus data lines. We now want to take this data and clock it into the IReg. The data comes from BUS D (15:00) through receivers and into the D MUX via the left-most input on our diagrams. We then must select this input by setting up the gating signals so that SDMO is a 1 and SDM1 is a 0. As you can see from Table 3-1 this is the combination which selects the Unibus data. The data (which you will remember is our instruction) will be on the D MUX Bus and all that is left is for us to generate the CLK IR signal to have the instruction clocked into the I Reg.

If you still do not understand this sequence, ask your instructor about it.
D. Locate the $B$ Reg, $B$ Constants and $B$ Mux which feed the BIN of the ALU.

1. Analyze the B Mux function in Table 3-1. To swap bytes the gating signals must have what values?

B Mux Low (07:00)
(a) SBMLO $=$ $\qquad$
(b) SBMLI = $\qquad$

B Mux High (15:08)
(c) $\mathrm{SBMHO}=$ $\qquad$
(d) SBMHI = $\qquad$
2. What would be the value of these signals to accomplish sign extension of the value in the B Reg?
(a) SBML0 $=$ $\qquad$
(b) SBML1 $=$ $\qquad$
(c) $\mathrm{SBMHO}=$ $\qquad$
(d) SBMHI = $\qquad$
OR
(e) SBMLO $=$ $\qquad$
(f) SBML1 = $\qquad$
(g) SBMHO $=$ $\qquad$
(h) SBMHI = $\qquad$
Indicate on your block diagram where byte manipulation takes place.

## 3. The CIN MUX feeds the input designated CIN with one of the following values:

(a)
(b)
(c)

Discuss some of the functions for which these inputs could be used.
4. The AIN input is fed from a 16 bit inverter labeled BUFFER which is fed from a wired -OR indicated by the dashed OR symbol. At this point, data comes from:
(a)
(b)
(c)
5. You will find the COUT MUX below and to the left of the ALU. Observe that this multiplexor has four inputs which are:
(a) $\qquad$
(b)
(c)

Analyze and discuss among yourselves the various functions of each of these inputs.

```
KDllA - 010.000
```

E. Locate the General Purpose Registers (GPR's), sometimes called Scratch Pad Registers; the Register Address Inputs; and the list of register names in the upper right hand corner of the block.

1. A brief description of the function of each of these registers is given in the first paragraph of section 3.3 .5 on p. 3-15. Read it.
2. What enabling signal will be brought up to allow us to get the address contained in $R$ [2] for the following instruction?

INC (2)
(a)

Which of the four groups of address lines will be used to select the register?
(b)
F. Locate the Processor Status Word (PSW) between the $B$ Mux and the GPR's.

1. Note how many bits are illustrated here. What are they?

2. Which bits can be affected implicitly?
(a)

Discuss the reasons for this.
G. Locate the BA Mux, the BA Reg, the Internal Data, and Address Decode and the Address Display which are found directly below the GPR's.

1. Note the BA Mux control in Table 3-1 on p. 3-14 and read section 3.3.2 on p. 3-15.
H. At this point you should be familiar with the Data Path section of the block diagram. You should understand the function and operation of every block within this section.
I. Refer to the list of Data Manipulation Functions in Appendix B. Write the set of functions required to implement the operations listed below. If more than one operation is required, group the functions into separate sets and complete each set with its required clocking signal.
2. Move the contents of the $P C$ into the $B A$.
3. Increment the contents of RO, as in INC \%O.
4. Add the contents of R3 to the contents of R2, as in ADD \%3, \%2.
5. Pop a word off the Processor Stack into the PC.
III. ADDITIONAL EXERCISES

If you feel that you need more practice before you attempt the tese, your instructor will be glad to provide you with more examples.

If you have been having trouble with the previous exercises, do not hesitate to ask your instructor for assistance.
IV. POST TEST

Attempt the post test. You have twenty minutes. Do the best you can.

```
APPENDIX A
B 3 a 0
    b l
    c PS (C)
    4 ~ a ~ P S W ~ A N D e d ~ w i t h ~ B U S ~ R D ~ F M ~ P S ~
    b GPR'S
    c BUS RD (15:00) (Internal Options)
5 a PS (c)
    b ALU 15
    c COUT 07
    d COUT 15
C 1 SDMO, SDM1
    3 b SDMl (0) * SDMO (1)
D l a SBML0 = 0
    b SBMLl = 1
    c SBMHO = 0
    d SBMHI = l
    2 a SBMLO = 0
    b SBML1 = 0
    c SBMH0 = 1
    d SBMHI = 0
    e SBMLO = J.
    f SBMLI = 0
    g SBMH0 = 1
    h SBMHI = 0
E 2 a SRD
    b IR (2:0)
```

F 1

2 a $N$, $Z, V, C, T,(7: 5)$

## APPENDIX A

## I 1 Operation $\quad \mathrm{BA} \leftarrow \mathrm{PC}$

```
RIF (3:0) = 07
RA (3:0) \leftarrowRIF (3:0)
BA (15:00)}\leftarrow\textrm{R}(15:00
CLK BA
```

2 Operation $\mathrm{D} \leftarrow \mathrm{R}[0]+1$
$R A(3: 0) \leftarrow \operatorname{IR}(2: 0)$
AIN (15:00) 4 (15:00)
CIN $\leftarrow 1$
ALUout $=A$ plus CIN CLK D

Operation $R$ [0]\&-D
RA (3:0) $\leftarrow$ IR (2:0) DMUX (15:00) $\leftarrow$ D (15:00) $\mathrm{R}(15: 08) \leftarrow \operatorname{DMUX}(15: 08)$ $R(07: 00) \leftarrow \operatorname{DMUX}(07: 00)$ WRH WRL

```
Alternate Method
```

Alternate Method
RA (3:0)\leftarrowIR (2:0)
RA (3:0)\leftarrowIR (2:0)
AIN (15:00) \leftarrowR(15:00)
AIN (15:00) \leftarrowR(15:00)
BCON (15:00)\leftarrow1
BCON (15:00)\leftarrow1
BIN (15:00)\leftarrowBCON(15:00)
BIN (15:00)\leftarrowBCON(15:00)
CIN}\leftarrow
CIN}\leftarrow
ALUout = A plus B plus CIN
ALUout = A plus B plus CIN
CLK D

```
CLK D
```


## APPENDIX A

```
I 3. Operation }\textrm{B}\leftarrow\textrm{R}[3
```

```
RA (3:0)\leftarrowIR(8:6)
DMUX(15:00)\leftarrowR(15:00)
BREG(15:00)\leftarrow DMUX(15:00)
CLK B
Operation D&B+R[2]
RA(3:0) \leftarrowIR(2:0)
AIN (15:00) < R(15:00)
BIN(15:08)\leftarrow BREG(15:0 8)
BIN(07:00)\leftarrow BREG(07:00)
CIN& 0
ALUout = A plus B plus CIN
CLK D
```

Operation $R[2] \leftarrow D$
RA (3:0) $\leftarrow \operatorname{IR}(2: 0)$
DMUX (15:00) $\leftarrow \mathrm{D}(15: 00)$
R(15:08) $\leftarrow$ DMUX (15:08)
R (07:00) $\leftarrow$ DMUX (07:00)
WRH
WRL

```
APPENDIX A
I. 4. Operation BA}\leftarrowR[SP
D}\leftarrow\textrm{R}[\textrm{SP}]+
RIF(3:0) = 06
RA(3:0)\leftarrowRIF(3:0)
BA (15:00)\leftarrowR(15:00)
AIN (15:00)\leftarrowR(15:00)
BCON(15:00) < 2
BIN (15:00)\leftarrowBCON(15:00)
CIN}\leftarrow
ALUout = A plus B plus CIN
CLK BA
CLK D
Operation R[SP]}\leftarrow
RIF (3:0) =06
RA (3:0)<<RIF (3:0)
DMUX(15:00)\leftarrowD(15:00)
R(15:08)\leftarrow DMUX (15:08)
R(07:00)\leftarrow DMUX(07:00)
WRH
WRL
```


## (DATI)

```
Operation \(R[P C] \leftarrow\) BUS Data
\(\operatorname{RIF}(3: 0)=07\)
RA (3:0) \(\leftarrow\) RIF (3:0)
DMUX(15:00)↔BUS D (15:00)
R(15:08) \(\leftarrow\) DMUX (15:08)
R(07:00) \(\leftarrow\) DMUX (07:00)
WRH
WRL
```

KDIIA DATA MANIPULATION FUNCTIONS
GENERAL PURPOSE
REGISTERS

```
RA(3:0)}\leftarrow\operatorname{RIF (3:0)
RA(3:0)<<IR(8:6)
RA(3:0)<<IR(2:0)
RA (3:0)}\leftarrow\textrm{BA}(3:0
R(15:08)\leftarrow\operatorname{DMUX (15:08)}
RIF (3:0) = 00
M! (3:0) =17
R(07:00)\leftarrow\operatorname{DMUX (07:00)}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|l|}{\(\operatorname{RIF}(3: 0)=00\)} \\
\hline & & 01 \\
\hline & & : \\
\hline & & 16 \\
\hline RIF & (3:0) & \(=17\) \\
\hline
\end{tabular}
```

ARITHMETIC LOGIC UNIT

```
AIN (15:00)}\leftarrow\textrm{R}(15:00
AIN(07:00)< PS (07:00)
BREG(15:00)}\leftarrow DMUX(15:00
BIN(15:00) \leftarrow BCON (15:00)
BIN (15:08) \leftarrow BREG(15:08)
BIN(07:00)\leftarrow BREG(07:00)
BIN (15:08) < BREG(07:00)
BIN (07:00)\leftarrow BREG(15:08)
BIN(15:08)< BREG (07)
```

CIN $\leftarrow 1 \quad$ CIN $\leftarrow 0 \quad$ COUT $\leftarrow P S(C) \quad$ COUT $\leftarrow A L U 15$
$\mathrm{D}(15: 00) \leftarrow$ ALUout $(15: 00) \quad \operatorname{PS}(7: 0) \leftarrow \operatorname{DMUX}(7: 0)$
$\operatorname{DMUX}(15: 00) \leftarrow \operatorname{D}(15: 00) \quad \operatorname{IR}(15: 00) \leftarrow \operatorname{DMUX}(15: 00)$
$\operatorname{DMUX}(15: 00) \leftarrow R(15: 00)$
$\operatorname{DMUX}(15: 00) \leftarrow \operatorname{BUS} \mathrm{D}(15: 00) \quad \mathrm{BA}(15: 00) \leftarrow \mathrm{R}(15: 00)$
$\operatorname{DMUX}(15: 00) \leftarrow \operatorname{COUT}_{,} \mathrm{D}(15: 01) \quad \mathrm{BA}(15: 00) \leftarrow \operatorname{ALUout}(15: 00)$

CLOCKING SIGNALS

| WRH | CLKB | CLK BA | CLK IR |
| :--- | :--- | :--- | :--- |
| WRL | CLKD | CLK PS |  |

# LEARNING ACTIVITY UNIT 

KDIIA BLOCK DIAGRAM
CONTROL SECTION
$1 / 15 / 74$

## RATIONALE

By now you have had a good overview of the KDllA Block Diagram. You have learned how data flows through and how it is manipulated within the CP. You have also learned how the 1l/05 Control Section operates and how it affects the manipulation of data in the 05.

Now, in studying the $11 / 40$ Control Section, you will first approach it from the point of view of how it is similar to the 11/05. After that, you will analyze the different concepts which the $11 / 40$ utilizes.

A complete understanding of the $11 / 40$ Control Section is imperitive if you are to troubleshoot the machine properly. If you do not realize what is actually happening in this section, it will be almost impossible to comprehend the flow diagrams or to predict what will happen when you are using the maintenance board.

## PREREQUISITES

Satisfactory completion of all units to date.

## OBJECTIVES

# A. Given a list of Control Section Facilities, you must be able to match these with five generalized functional descriptions. 

B. Given a list of microinstructions, show what will be contained in certain registers and what will be on certain lines in the Control Section during the execution of each microinstruction.

You will have thirty minutes to do this and will be allowed one error in $A$ and one in $B$.

## I. LECTURE

Attend the forty-five minute lecture. Make notes on your block diagram. Hold your questions until the end of the lecture.
II. PROJECTS/PROBLEMS (Answers in Appendix B)
A. Given the list of Control Section Facilities in Appendix A, choose one which is best described by each of the eight following functional statements.

1. It takes signals from the FLAG Control I REG and IR Decode to provide signals for the BUT MUX.

Ans. $\qquad$
2. It provides the controlling signals for the ALU

Ans.
3. It provides the controlling signals for the D MUX.

Ans.
4. Its output can be used to stop the processor at a particular micro instruction

Ans. $\qquad$
5. Its contents specify the address of the microword currently in the UREG.

Ans.
6. It contains the machine instruction currently being executed by the $11 / 40$.

Ans.
7. Its output forces the micro program to a particular address without regard to the microinstruction currently being executed.

Ans.
8. These lines indicate whether or not, and if so, what alterations of the base address will occur.

Ans.
B.

1. Which of the microinstructions drawn below would contain a BUT?

C. Take the POST TEST. Do the best you can.
III. ADDITIONAL READING

To enhance your understanding of this unit, it is recommended that you read and study pages 3-18 through 3-20 in the KDllA Processor Maintenance Manual.

## WHAT'S NEXT

In the next unit you will complete your study of the Block Diagram. You will also have a chance to review the entire block.
APPENDIX ..... A
LIST OF CONTROL SECTION FACILITIES

1. I REG
2. IR Decode
3. FLAG Control
4. UBC Branch Control
5. ALU Control ..... MUX
6. ALUM, ALUS ..... (3:0)
7. BUT MUX
8. JAMUPP
9. UPP
10. Main Control ..... ROM
11. PUPP
12. SR: BUPP Compare
13. UPF (7:0)
14. U REG
15. U (15:09)
16. UBF $(4: 0)$
17. BUT Decoder
APPENDIX ..... B
ANSWERS TO PROBLEMS
18. UBC Branch Control
19. ALU Control MUX
20. U REG
21. SR: BUPP Compare
22. PUPP
23. I REG
24. JAMUPP
25. UBF ..... (4:0)

APPENDIX B
Answers to problems
$B$.



CONTROL SECTION SIMPLLELED BLOCK DIAGRAM


Simplifieo Microbranch Control

APPENDIX $E$


Example of Microbranchins
LEARNING ACTIVITY UNIT
KD11A BLOCK DIAGRAM
CLOCK, UNIBUS, CONSOLEJANUARY 17, 1974

## RATIONALE

By now you are pretty familiar with the $11 / 40$ Block Diagram. You have seen how data is manipulated within the C.P. and also how the Control Section causes this manipulation to take place.

In this unit, you will cover the remaining parts of the Block Diagram. You will learn primarily how the $11 / 40$ Processor clock operates and how these clocking signals are utilized within the Control and Data Path sections. You will also learn about such miscellaneous portions of the block as the Unibus Interface, Console Interface, etc. This unit will also serve as a review of the entire KDllA Block Diagram.

Use this unit to make sure that you really understand the Block Diagram. You will find it immensly useful as you study the flows and the logic as well as when you are troubleshooting.

```
KD11A - 030.000
```


## PREREQUISITES

Successful completion of all units to date.

## OBJECTIVES

Given a list of blocks or signals, you must be able to indicate which one would be faulty to generate the symptoms described. You must successfully complete three of the four questions in the alloted thirty minutes.

```
KDllA - 030.000
```


## LEARNING ACTIVITIES

## I. LECTURE

Attend the thirty minute lecture. Make notes on your block diagram. Do not ask your questions until the end of the lecture.
II. PROJECTS AND PROBLEMS
A. Refer to Fig. 3-11 in your KDllA Processor Maintenance Manual. Write down which signal would be faulty to cause the following symptoms. Check your answers with those in Appendix B. Be sure to ask your instructor to clarify any point you do not fully understand.

1. The machine is hung doing nothing and you observe no clocking signals. However, you are able to do all operations successfully using the maintenance board.

Answer $\qquad$
2. Any microinstruction which specifies a CL2 results in the generation of both a P2 and a P3 pulse. Microinstructions specifying a CLI or CL3 operate properly.

Answer $\qquad$
B. Refer to the list of Data Manipulation Functions in the Appendix of LAU\# KDllA - 010.000 and to your KDllA Block Diagram. Write the set of facilities including the clock length which would execute the following operations most efficiently. The answers are in Appendix B.

1. $P C-P C+2$
2. $\mathrm{R} 5-\mathrm{R} 3+\mathrm{R} 5$
3. Push the contents of the PC onto the Processor Stack.
```
KD11A - 030.000
```

4. Depressing the LOAD ADRS keyC. Using the KDllA Block Diagram, find the signalwhich would be faulty to cause the followingsymptoms.
5. Whenever you do a LOAD ADRS operation, you observe on the ADDRESS DISPLAY that the upper Byte is always changed to contain garbage.

Answer $\qquad$
2. Whenever the D Mux is enabled such that you see the contents of the D Reg in the Data Display, you see garbage. The same garbage is seen every time the $D$ Mux is enabled in this way.

Answer $\qquad$
3. You are trying to execute a program. After pressing and releasing the Start switch, the machine Halts. The same thing happens when you subsequently press CONT. You observe that the PC is incrementing properly and that Rl3 contains the instruction it should have executed.

Answer $\qquad$
D. Take the Post Test. Do the best you can.
III. ADDITIONAL READING

To enhance your understanding of the clock section, read and study pages 3-21 to 3-22 of the KDllA Processor Maintenance Manual. You should, at this time, be able to read and understand all of Chapter 3 from page 3-12.

## WHAT'S NEXT?

You should now be well prepared to continue your study of the Flow Diagrams. If you have the Block well under your belt, you should have no problem with the flows.

## REGISTER CLOCKING PULSES

REGISTER ..... CLOCK
I REG ..... P1, P3
B REG ..... P1, P3
D REG ..... P2
GPR ..... P1, P3
BA REG ..... P1, P2

## ANSWERS TO PROBLEMS

A.

1. RECLK
2. CLKLO
B.
3. $\mathrm{PC} \longleftarrow \mathrm{PC}+2$ $\operatorname{RIF}(3: 0)=07$ RA (3:0) $\leftarrow$ RIF (3:0) BCON $(15: 00) \leftarrow 2$ BIN $(15: 00) \leftarrow \operatorname{BCON}(15: 00)$ AIN (15:00) - R (15:00) $C I N \longleftarrow 0$ ALUOut $=A$ PLUS $B$ PLUS $C$ D (15:00) ALUout (15:00) CLK D DMUX (15:00) \& D (15:00) R (15:08) -D MUX ( $15: 08$ ) $R(07: 00) \leftarrow D \operatorname{MUX}(07: 00)$ WRH WRL CLKL3
4. R5-R3 + R5
a. $B \Perp R 3$

RA $(3: 0) \backsim I R \quad(2: 0)$
D MUX (15:00) -R (15:00)
B $(15: 00) \leftarrow D \operatorname{MUX}(15: 00)$
CLK B
CLKL1
b. $\quad R 5-B+R 5$

RA (3:0) - IR (2:0)
AIN $(15: 00) \leftarrow \mathrm{R}(15: 00)$
BIN $(15: 08)-$ B $(15: 08)$
BIN (07:00) - B (07:00)

## APPENDIX B

ANSWERS TO PROBLEMS (CONT'D)
B.
2.
b. CIN-0

ALUout $=$ A PLUS B PLUS CIN
D (15:00) $\longleftarrow$ ALUout (15:00)
CLK D
D MUX (15:00) D (15:00)
R (15:08) - D MUX (15:08)
R (07:00) \& D MUX (07:00)
WRH
WRL
CLKL 3
3. $\quad(S P) \downarrow$ PC
a. $B A, S P \leftarrow S P-2$
$\operatorname{RIF}(3: 0)=(06)$
RA (3:0) $\leftarrow \operatorname{RIF}(3: 0)$
$\operatorname{AIN}(15: 00) \leftarrow R \quad(15: 00)$
BCON (15:00) $\leftarrow 2$
$\operatorname{BIN}(15: 00) \leftarrow \operatorname{BCON}(15: 00)$
ALUout $=A$ MINUS $B$
BA (15:00) - ALUout (15:00)
CLK BA
D (15:00) ALUout (15:00)
CLK D
D MUX (15:00) -D (15:00)
R (15:08) \& D MUX (15:08)
R (07:00) D MUX (07:00)
WRH
WRL
CLKL3
b. BUSD \& PC

```
RIF (3:0) = 07
RA (3:0) < RIF (3:0)
AIN (15:00)<R (15:00)
CIN&-0
ALUout = A PLUS CIN
D (15.00)& ALUout (15:00)
```

```
KD11A - 030.000
```


## APPENDIX B

## ANSWERS TO PROBLEMS (CONT'D)

B.
3.
b. CLK D

CLKL2
(DATO)

## 4. LOAD ADRS

```
        a. R(17)\longleftarrowSR
```

            \(\operatorname{RIF}(3: 0)=17\)
            RA (3:0) -RIF (3:0)
            BUS D (15:00) -SR (15:00)
            D MUX (15:00) BUS D (15:00)
            R (15:08) D MUX (15:00)
            R (07:00) \(\longleftarrow\) D MUX (07:00)
            WRH
            WRL
            CLKL1
            b. \(\quad B A-R(17)\)
            RIF \((3: 0)=17\)
            RA (3:0) - RIF (3:0)
            BA \((15: 00) \leftarrow R(15: 00)\)
            CLKBA
            CLKL1
    C. 1. WRH
2. CLKD
3. CLKIR
LEARNING ACTIVITY UNITFLOW DIAGRAMS I
INTRODUCTION OVERVIEW $\mu I N S T$ FORMAT

## RATIONALE

So far you have learned about the Block Diagram and can now identify those areas of the block known as Data Paths, Control Section, Clock, Unibus Timing and Control. You can visualize, for instance, how some of the elementary operations are accomplished via the block like updating the PC, IR gets Unibus Data, etc. Now it is time to go one step farther and move on to the flows.

Probably everyone's definition of flow diagrams include something about a step by step explanation of an operation. Flows are designed to make some operation easily understandable. It usually consists of a set of symbols which must be identified and learned. The flows that you learned in the $11 / 05$ were more like a listing and therefore, the ideas were there but not the symbology. This is not true, however, with the 11/40. Once we learn the "language of the flows" an attempt will be made to understand what the flows tell us concerning the ll/40's operation. Our primary objective in this unit then will be to learn how to "read" the flows.

The whole concept of the ROM control is captured in these flows. They identify and explain each micro instruction and show each possible sequence. Acquiring this reading the flows ability will provide you with the proper foundation to continue with the subsequent units concerning the flows.

## PREREQUISITES

Satisfactory completion to date of all previous units.

## OBJECTIVES

Given four flow machine state blocks with various amounts of information you must identify and define which micro instruction field is involved to select or make happen the questioned operation. To successfully complete this unit, you must correctly answer three of four of these questions. You will be allowed to use all available references and your notes but a twenty (20) minute time limit will be in effect.

## PRETEST

To be filled in when fully programmed environment is in progress.

LEARNING ACTIVITIES
I. LECTURE

Attend a 20 minute lecture where the instructor will give you an overview of the microprogram flows. He will point out to you the various places you will find information about the flows, and talk in general terms about the ideas and concepts behind them. The emphasis will be on how to use the flows in a maintenance and learning environment. Time will be allowed at the end of this lecture to answer questions prior to going on to your activities.
II. PROJECTS/QUESTIONS
A. Micro instruction format

As you already know, the $11 / 40$ is a "ROM" machine. This means that all controlling of the machine operations are accomplished by micro instructions. These micro instructions are 56 bits in length and there are 256 of them.

1. Identify, define, describe each of the 56 bits of a micro instruction. A complete detailed description appears in the appendix. A ready reference appears in the:
KDllA Processor Maintenance Manual DECll -HKDAA-A-D, Pg. 2-7 Fig, 2-4, Pg. 2-8, 2-9 Table 2-1
2. Note how the bits are grouped into the various fields, that is; the CLKL 1 , CLKLO and CLKOFF grouped together to become a field called CLK. Note all fields by referring to KDllA Processor Maintenance Manual DECII-HKDAA-A-D, pg 2-6 Fig. 2-3
3. Refer to the 6 th page in the PDPIl/40 System Engineering Drawings and look over the tables found there. Each of the major field's uses are given by these tables. For instance when the BUS code is equal to 5 , what type of bus transaction will be initialized; answer DATO.
4. Now familiarize yourself with the ROM (micro instruction) listing in the PDP1l/40 System Engineering Drawings found on about the 22 nd page just after the $K 2$ print set.
5. Refer to your block diagram, now and identify some of these fields as to where they feed and what they control
a. SRI and RIF to select some general purpose register
b. SBC to generate a constant
c. UPF to affect the UPP register
d. UBF to control the BUT multiplexer
6. The SBC code will be equal to when generating a constant of two (2).
7. When attempting to address $R[P C]$ using SRI and the RIF bits, SRI is on a 1 and RIF equals $\qquad$ -
8. When DAD says use the micro instruction to set up the ALU and we want the ALU to add, the ALU field equals

$\qquad$
-
9. The BUT decoder looks at the field to translate the BUT number.
10. A BUT 12 really asks this question is
B. Micro program Flow

1. Only three basic symbols are used in the PDP11/40 Flow diagrams, they are given here and on pg 4-1 of the KDllA Processor Maintenance Manual DECll-HKDAA-A-D.


Machine State


Exit Point
2. The most involved symbol of course is the machine state (one micro instruction) Refer now to the appendix and familiarize yourself with every aspect of this flow symbol.
3. Each machine state box reporesents one micro instruction, one elementary operation, one small step necessary for the overall accomplishment of a machine operation.
4. A machine operation could be;
a. To load an address
b. To examine a register
c. To execute a machine instruction
d. Etc.
5. Read pages 4-1 thru 4-4 in the KD11-A Processor Maintenance Manual DEC 11-HKDAA-A-D with special emphasis on the flow diagram example figure $4-2$ on page 4-2
6. Start (1) indicates to you that start is a (condition/flip flop)
7. The signal - HALT SW is read as
8. Referring to fig 4-2, page 4-2 in KDllA Processor Maintenance Manual DECll-HKDAA-A-D
a. What flow sheet do you go to if HALT switch is sensed
b. What address is Fetch ©
9. Check your answers to $A$ and $B$ in the appendix. Get help if you do not understand why you missed any of the one's you did.
III. SELF EVALUATION
A. Given the following Micro instruction flow example, answer the questions

| SRA 09 | 147 |  |
| :--- | :--- | :--- |
| GET | INDEX DATA; MODIFY | D |
| PR: | $\mathrm{D} \& \mathrm{R}[\mathrm{PC}]$ | Plus 2 |
| P3: | $\mathrm{R}[\mathrm{PC}]$ | $\mathrm{D} ;$ |

1. What is the clock code?
2. If $D=500$ and $R[P C]=500$ What is the Data Display?
3. The SBM field will equal
4. What method will be used to address R[PC].
5. The PC will be written with the updated value and the next micro instruction clocked into the Register at the trailing edge of the clock specified.

## IV. ADDITIONAL READING

To assist in you understanding, the flow diagrams reading chapter two (2) of the KDllA Processor Maintenance Manual DECl - HKDAA A-D will be of some value. You should consider this for a more detailed understanding.

## WHAT'S NEXT

After completing this unit, you will be prepared to continue on to the remaining units concerned with the $11 / 40$ flow diagrams armed with the necessary knowledge knowing how to "read the FLows".

ET 04

A. Name of Micro instruction (Mnemonic)
B. The ROM address of the $\mu$ instruction (9 bits-(PUPP))
C. What the $\mu$ instruction will do. I.E. modify the program counter and start BUS Cycle if overlap.
D. The Console Data Display. This is read $R$ of PC. Therefore, this Data Display is the contents of $R[P C]$.
E. What happens and when. This particular one means, at the trailing of the P2 pulse specified D Reg. and BA Reg., get the results of R[PC] plus 2, and start a DATI BUS Cycle if you meet the conditions for an overlap fetch. This is read as, at $P 2$ time $D$ and BA gets R[PC] plus 2 and start DATA IN if overlap.
F. Branch Micro test name. This one, but (instr 1), means this is first time you look at the machine instruction to make micro program branch decision.
G. But Number. Give you the octal $\mu \mathrm{BF}$ code, let you refer to this BUT by number.
H. This is the base address that the micro test will put in jeopardy. It is possible that any or all of BITS (5:0) will be modified due to conditions being sampled (tested).

| 16 |
| :---: |
| SRS |

Allows IR source field to address the GPR's


Allow IR destination field to address the GPR's.

| 14 |
| :---: | :---: |
| SRBA |

Allows bits Allows (3:0) of the RIF to be BA Reg. to used (select address the GPR's
the GPR using the RIF field)

| 12 | 11 | 10 | 9 |
| :---: | :---: | :---: | :---: |
| RIF3 | RIFZ | RIF1 | RIF0 |

When SPI is active these bits (register immediate field) are used to provide the address for the general purpose registers.

Functional representation of GPR addressing.

| 21 | 20 | 19 | 18 | 17 |
| :---: | :---: | :---: | :---: | :---: |
| UBF4 | UBF 3 | UBF2 | UBF1 | UBF0 |

Micro branch field - better known as BUT. It's this field that will select one of many inputs to be routed through the but mux, such that, that condition could modify the UPF bit depending on the fact if it's true or not.

BUT's asks question for instance, a but 10 called but (halt) says but is the halt switch on?
BUT 17, BUT IRO3, BUT is IR bit 3 on a 1?



Select the B MUX field. Bits $28 \& 27$ select the input to the high byte of the B MUX. Bits 26 \& 25 select the input to the LO byte of the B MUX.


Select the D MUX field. These bits select which of the 4 inputs to be routed through the D MUX.

Select the BA MUX This bit routes either the RD BUS or the ALU output to the BA Register.

See table 3-1 on page 3-14 in the KDIlA Processor Maintenance Manual DECII-HKDAA-A-D for a complete listing of multiplexer selections.
$\mathrm{A}, \mathrm{U}$

| 37 | 36 | 35 | 34 | 33 |
| :---: | :---: | :---: | :---: | :---: |
| SALUM | SALU3 | SALUZ | SALU1 | SALUO |

These bits select which mode the ALU should function in and what it should do. I.E. Add, etc. see table 3-2, page 3-17 in the KDll-A Processor Maintenance Manual for complete list of ALU selections.

Select Binary Constants field This bit generates necessary constants needed by the 11/40. See SBC table about 6th page in PDPIl/40 System Engineering Drawings for a complete list.

## MICRO INSTRUCTION FORMAT PDPIl/40

DAD

| 44 | 43 | 42 | 41 |
| :---: | :---: | :---: | :---: |
| DAD3 | DAD2 | DAD1 | DADO |

Discrete alteration of data. Does some special jobs in the logic for us. For instance, the micro program would go through the same sequence if the machine instruction was an Add or Sub. However, at that one micro instruction that the ALU actually operates on the two operands the DAD code allows the $A L U$ to be told what to do (Add or Sub) by the OP code in the IR Register.

| 40 | 39 | 38 |
| :---: | :---: | :---: |
| SPS2 | SPS1 | SPS0 |

Select the processor status code. These bits control the gating and clocking of the processor status flip flops.

[^1] the B Register


CD


Allows clocking
the ALU output into the D Register
either the ALU output or a general register ouput into the BA Register


BUS

| 47 | 46 | 45 |
| :---: | :---: | :---: |
| CI BUS | C0 BUS | BG BUS |

BUS Control bits. Bits 47 and 46 specify type of data transaction

| CIBUS | COBUS |  |
| :---: | :---: | :--- |
| 0 | 0 | DATI |
| 0 | 1 | DATIP |
| 1 | 0 | DATO |
| 1 | 1 | DATOB |

Bit says
to BEGIN a BUS Cycle


This is a three bit code given as one octal digit in the ROM listing.
This code has a supplementary use - explained with tables.


Clock Control bits Bit 56 and 55 select one of three clock lengths.

## MICRO INSTRUCTION FORMAT

| CIR |
| ---: |
| 53 |
| CLKIR |

Allows clocking the instruction register with Unibus Data the machine instruction.

PDP 11/40

| UR |  |
| :---: | :---: |
| 52 | 51 |
| WRH | URL |

Allows the writing of DMUX information into a selected general purpose register. Notice a control signal for upper byte and lower byte.

## CLKLI CLKLO

|  | 0 | 0 |  | ELK |
| :--- | :--- | :--- | :--- | :--- |
| 1 | 1 |  |  |  |
| $H$ | 0 | 0 | ELK | 2 |
| Z | 1 | 1 | ELK | 2 |



Bit 54 allows micro instruction to turn off processor clock


This is a three bit code given as one octal digit in the ROM listing.


## APPENDIX

Answers to $A$ and $B$

A

```
    6. 02
    7. 07
    8. 11
    9. UBF
10. Is D Reg equal to zero
```

7. Not HALT
8 a 10
b 016

## Answers to Self Evaluation

A

1. 7
2. 500
3. 17
4. $\mathrm{SRI}(1), \mathrm{RIF}=17$
5. P3

## REVISION

Your instructor is interested in improving this unit based on you answers to the following questions. Please answer them objectively and return this sheet to your instructor.

1. Relevance of this unit to your job as a Field Service Engineer.
a. Very relevant
c. Not relevant
b. Average relevance
d. Worthless
2. Did you have sufficient time?
a. Just right
c. Need a little more
b. Too much
d. Need a lot more
3. Degree of difficulty experienced
a. Average
c. A little tough
b. Too difficult
d. A snap
4. Quality of the LAU with reference to previous ones
a. Very good
c. Fair
b. Good
d. Poor
5. Did you feel you were given adequate directions either from the instructor of the LAU itself.
a. Adequate c. Need a lot more
b. Need a little more d. I was confused
6. Additional comments on the unit:

## IJEARNING ACTIVITY UNIT

## Flow Diagrams II

JAMUPP to Console and Console Flows

1/21/74

## RATIONALE

In the previous unit you started the flow diagram learning process by learning how to read the microprogram flow diagrams. You also realized that many of the ideas and concepts you mastered in the $11 / 05$ Flows could be applied with good results here in the $11 / 40$. In our quest to master these flows this was the first of several steps.

Perhaps the one underlying concept in all ROM machines and at least in the $11 / 40$ is that one small step at a time is accomplished. These small steps (micro instructions) when taken in the aggregate perform some major operation or job. For instance, execute a machine instruction, accomplish a console operation, etc. In this unit you will undertake the job of learning how the console operations in the 1l/40 are accomplished using micro instructions. You shall see how, if we take one small step at a time, you can do the entire job that is required.

All major concepts are found in these console flows. All of the ideas, branching, testing, bus transactions, etc. are here. If you can really understand how these flows work you will obtain an appreciation for how much of the processor must be operational to do these console operations. The remaining flow diagrams will become much easier to master once a thorough knowledge of the console flows is obtained.

## PREREQUISITES

Satisfactory completion to date of all previous units.

## OBJECTIVES

There will be five (5) questions concerning microinstructions and their operations and how they relate to the console operations. To demonstrate successful completion of this unit, you must answer at least four (4) of these correctly. Your notes and any reference material are at your complete disposal, however there will be a twenty minute time limit in effect.

PRE-TEST
To be filled in when full programmed environment is in progress.

LEARNING ACTIVITIES
I. LECTURE

Attend the short (20 minute) lecture where the instructor will give a summary of those events that get you to the Console Flows. Also during this lecture it will be pointed out to you that you should keep in mind what you already know about the console operations. You have been Depositing, Examining, Load Addressing, etc. for quite awhile; do not forget what the results were in each of these operations. The instructor will give you an overview of the two Flow Diagram pages concerned with the console operations (Sheets 11 and 12 of the Flow Diagrams, PDP $11 / 40$ System Engineering Drawings). Hold your questions until the lecture is over and at that time they will be answered and discussed.

TI. PROJECTS/QUESTIONS
A. Flow Diagram (Console Loop Sheet 11)

The purpose of this Flow is to provide the processor a place from which to start (after a power up or initialize) and/or a place to which he goes when a Halt instruction is executed or the Halt Switch is depressed. It is here the processor must be if you ever want to do a Load Address, Exam, Deposit, Continue, or Start.

Let us analyze and then summarize each of these micro instructions to verify that Page ll does do its job.

1. The entry at the top right brings us into this page and we start things off by executing CON 05, a NO-OP. You then go to CON 13 where some interesting things begin to happen.
(a) BUT SWITCH - is there a control switch depressed?
(b) CONSL -1 - Console F/F gets set.

This BUT is referred to as a Working BUT because it serves two purposes, Branch Testing and setting a F/F. Assuming no switch is activated at this point we now go on.
2. CON 06 then CON 04 , CON 06 etc. is known as the Console Loop and here is where we will stay (continually executing these two micro instructions) until such time that a control switch is depressed (activated) then we will go to CON 07.
3. Try to think of the BU'T 06 in address 026 as asking this question. BUT where should I go when I'm done executing CON 06 - to CON 07 or back to CON 04? If switch then to CON 07, if not switch then to CON 04.
4. Upon leaving the Console Loop ( 026,046 , 026, etc.) the next three micro instruction have to do with contact bounce. There are two situations which you must consider; doing this dynamically or with the maintenance module. First, let us do it dynamically:
(a) CON 07 - Put some number into the D reqister as a function of $S B C=14$. Determine this number by referring to your SBC table.
(b) CON 08 - Move that number to R [TEMPC] and ask this question; is D $=0$ ? The answer - no. What this means is after I am done with CON 09 go back to CON 08.
(c) CON 09 - Increment this count by adding 1 to the value in R [TEMPC] then restore $R$ [TEMPC] with this new value.
(d) Go back to CON 08 and continue to do this loop until $D$ register does $=0$, then go to CON 10. The time involved here is approximately 40 ms .

Now let us analyze these same micro instructions when using the maintenance module. (The maintenance module allows you to execute one micro instruction and stop, one micro instruction and stop, etc.).
(e) CON 07 - The number put into the D register is zero because we're using the maintenance module.
(f) CON 08-When I ask the question this time, D is = to 0 and when I am finished with CON 09, which is next, I go to CON 10 immediately.
(g) CON 09 - no meaningful operation this time.

Read the BUT Definitions on this sheet also, to substantiate your beliefs.
5. CON 10 provides for saying; BUT which of the various switches that you could have activated did you activate? In other words, the BUT 30 allows the activated switch to implement modifying the base address 030, such that we will go to the appropriate flow as we leave this page.
6. CON 11 - Puts the last Console Address in the D register as we leave this page.
B. Flow Diagram (Console Switches Sheet 12)

The purpose of this sheet is to set forth the action taken whenever a particular control switch has been activated. First we will summarize some of the operations then you will be given the opportunity to go through some on your own then some questions will be put to you to reinforce those things learned.

For purposes of discussion, let us assume that we are sitting in the Console Loop (026, 046) and the job we are required to do is (a) Load Address 500, and (b) Deposit a MOV \#10, \%R0, (c) Examine what you Deposited.

1. Set the number 500 into the switch register on the $11 / 40$ Console. Activate the Load Address switch by depressing it and the micro program will react as previously discussed and as you come off sheet 11 you go to LAD00, 037 Sheet 12 and this is where we will pick up the action.
(a) LAD00 - Get the information from the switch register. First, create the switch register address $(S B C=10)$ and put it into the Bus Address Register. Then do a Data In Bus transaction to get the (500) information. Shut off the clock waiting for the Slave Sync to inform you (by startind the clock)
that you can accept this data.
(b) LAD01 - Accept the 500 coming in from the switch register on the Unibus Data lines and put it into the General Purpose Register, R[ADRSC]. Notice the Exam and Deposit $F / F$ both get cleared at this time.
(c) LAD02 - Put the Loaded Address Information LAD03 - (500) into the Bus Address Register as you go back to Console Loop.
(d) Now that we are back in the Console Loop let us decide where the pertinent information is located:
(1) The Console Data Display $\qquad$ -
(2) The Console Address Display $\qquad$ -
(3) The contents of $R[$ ADRSC $]$ -
(4) The contents of $R[P C]$ $\qquad$ -

Refer to the appendix to verify your answers.
2. Now we are ready to deposit. First, set the MOV \#10 \%R0 (octal) into the switch register. Second, activate the deposit switch. We come off Sheet 11 in the same manner as before and proceed to DEP00, 034 this time due to the deposit switch. Let us pick up the action there.
(a) DEPO0 and 01 - Makes sure that the last loaded address gets put into $B A$ register and in DEP 01 asks the question - is this a Register Deposit? In other words, are we depositing into a GPR? The answer now is no. So when we leave DEP02 will go to DEP03 and not bypass it.
(b) DEP02 and 03 - Conditional plus 1 microinstructions As you know, after the first deposit you must be prepared to increment. Two words are used because the incrementation if a General Register is by l. The condition is whether the Deposit $F / F$ is set or not and as you recall we cleared it in the Load Address Operation, therefore, it is still clear. You read this micro instruction as $D$ and $B A$ get the contents of $R[A D R S C]$ plus something, that
something is as a function of $\mathrm{SBC}=7$ and depends on the state of the Deposit $\mathrm{F} / \mathrm{F}$. If set add 1 , if clear add 0 . It becomes obvious then that if the Deposit $\mathrm{F} / \mathrm{F}$ is set when I come through here incrementation will take place and when clear no incrementation.
(c) DEP04 - Get the information I want to Deposit. Do a Data In from the switch register (that is where it is at).
(d) DEP05 - Accept this data and put it into the B register.
(e) DEP06 - Put the address I want to deliver the data to into the BA register.
(f) DEP07 - Put the Data I want to deliver into the D register. The question is asked here again - is this a register I'm depositing - (no Data out would be required) the answer is still no, however. Notice the setting of the Deposit $F / F$ here.
(g) DEP08 - no-op needed because of the branch decision.
(h) DEP09 - Do the Data Out Transaction to deliver the data to the proper address. Shut off the processor clock, wait for SSYN to inform you that memory has received the data then start up and go back to the Console Loop.
(i) Again, let us analyze the pertinent data now that we are back in the Console Loop.
(1) The Console Data Display $\qquad$ .
(2) The Console Address Display $\qquad$ -
(3) The contents of $R$ [ADRSC] $\qquad$ .
(4) The contents of $R[P C]$ $\qquad$ .
3. Now you deposit the proper data at the next location and list the procedure you followed, the micro instructions executed, and answer the following questions.
(a) After executing DEP 02 the Data Display is $\qquad$ and the Address Display is
$\qquad$ -
(b) When PUPP is 066 what is the Data Display $\qquad$ ; the Address Display
$\qquad$ -
(c) If this deposit had been a General Purpose Register, what micro instruction would have put the data into the GPR?
(d) How would the GPR have been selected in the previous question?
4. Let us discuss the Examine micro flow. After you finished depositing the MOV \#l0, \%R0 you would have Loaded Address back to 500 (same manner as previously discussed) and now activate the Examine Switch. The Examine is pretty much the opposite of Deposit with the exception of a couple of micro instructions. I will discuss these and you check out the rest of the flow until you are satisfied you know how the Examine works.
(a) EXM 05 - If this were a General Purpose register you were Examining then the low order 4 bits of the BA register would be used to provide the address. All the GPR's 7777XX.
(b) EXM 06 - If it is not a register examine start your Data In Bus transaction at this time and shut off the CPU clock. Also start your NO DAT timer and put
the SW address into D register. Now, if you get a time out ( $15 \mu \mathrm{sec}$ and no SSYN response, typically, trying to examine non-existent memory) then the JAMUPP logic will move you directly from here to the Console Loop. You will display in the Data lights the switch register address number 177570. This will be your time out indication flag. Of course, if you do not get a time out, you complete the Examine flow properly and go back to the Console Loop.
(c) Some questions about the Examine Micro Routine.
(1) The BUT 04 in EXM 01 modifies 056 to $\qquad$ if not examining a general register.
(2) In which micro instruction does the Examine F/F get set?
(3) What route does the Data take to accomplish EXM 06?

Refer to the appendix to verify the correct answers.
5. After examining the contents of location 502 and Loading Address to 500 again let us take off the Halt Switch and depress Start. Analyze the sequence that would be taken and answer the following questions:
(a) What address do you go to when leaving Sheet 11 $\qquad$ ?
(b) What turns off the console light?
(c) As you leave Sheet 12 what is the contents of:
(1) $\mathrm{R}[\mathrm{p}]$
(2) D register
(d) As you leave Sheet 12 what sheet and address do you go to?
III. SELF EVALUATION

Answer the following questions as an overall evaluation of the knowledge obtained in this unit. When you are finished check to see if you agree with those given in the appendix.
A. In CON 07 what number will be put into the D register if not using the maintenance module?
B. If, after the bounce count delay, there is no switch depressed what micro instruction is executed after CON 11?
C. The Unibus Data that is being accepted in LAD 01 originated where?
D. After completion of a deposit of 10 into General Purpose Register RO give the Address Display and the Data Display.
E. An Examine of a memory location requires how many and what type of bus transactions?

## IV. ADDITIONAL READING

Operation Symbols, paragraph 4.2.5, Page 4-11 of the KDll-A Processor Maintenance Manual, DECll-HKDAA-A-D will provide some supplementary information which you may find useful at this time.

WHAT'S NEXT
After completing this unit you should have a good idea of what a flow operation looks like. In the susequent units you will be analyzing how the micro program accomplishes the execution of machine instructions.

## SUPPLEMENTARY INFORMATION

If you feel the need for more practice concerning these console operations ask the instructor for additional assignments.

3. THE JAMSTART PULSE IS INHIBITED FROM STARTING THE CLOCK BY PWRUP INIT STILL BEING ACTIVE.
4. SINCE THE UREG CONTAINS ALL ZEROES WE HAVE FORCED THE MACHINE TO A KNOWN STATE - ALL CONTROL SIGNALS INACTIVE LLOCATION 000 IN THE ROM IS BEING READ OUT, BUT THE SUBSEQUENT JAM SEQUENCE WILL ALTER THE UPP PRIOR TO CLOCKING THE UREG AGAIN
5. AT TD THE TRAILING EDGE OF PWR RESTART SETS THE JPUP FLOP
6. JPUP TRIGGERS THE JAMUPP ONE SHOT AND FROM TO TO TE WE JAM A NEW ADDRESS INTO THE UPP. (IF HAETT; UPP $=30$ (CONO5)
[IF - HALT; UPP $=337(T R P 47)$
7.. ASSUME THE HALT SWITCH WAS ON; AT T F THE TRAILING EDGE O JAM CLK GENERATES CLKU, CLKIUPP.PUPPI - THIS CLOCKS THE CONTENTS OF LOC 30 INTO THE UREG, 315 INTO THE UPP, AND 30 INTO THE PUPP - WE NOW HAVE THE MICROPROGRAM IN THE CONSOLE ROUTINES
8. THIS TIME, THE JAMSTART PULSE GENERATES THE SET CLK SIGNAL TO TURN ON THE PROCESSOR CLOCK - THE MICROPROGRAM SHOULD NOW SEQUENCE TO CONO6 AND START LOOPING, WAITING FOR A CONSOLE CONTROL SWITCH

## APPENDIX

I. ANSWERS TO PROJECTS/QUESTIONS
B. 1 . ..... (d)
(1) zero(2) 000500(3) 000500(4) unknown
2. (i)(1) 012700(2) 000500(3) 000500(4) unknown
3. (a) 000501, 000501
(b) 000010,177570
(c) DEP 10, 073
(d) SRBA (1), BA 03:00
4. (c) $\quad 1=57$
$2=\mathrm{EXM} \varnothing 4$ ..... $3=-$ REG.
II. $\mathrm{F}_{\mathrm{N}} \mathrm{SWERS}$ TO SELF EVALUATION
A. 000020
B. CON ..... 05
C. AT SWITCH REGISTER
D. ADRS (777700), DATA (000010).
E. I, DATA ..... IN.

## 1l/40 KDllA 060

## LEARNING ACTIVITY UNIT <br> FLOW DIAGRAMS III <br> MICROPROGRAM WORKSHEETS AND SINGLE OPERAND INSTRUCTIONS 1/21/74

## RATIONALE

In your first unit, you learned how to read the flow diagrams. Then you used that ability to go through the Console operations and interpret those flows. Now that you have accomplished that, you should have a firm understanding of the way the $11 / 40$ does things. Also, what the flows look like to accomplish these operations. Now, it is time to go on.

In this unit, you will discover how the $11 / 40$ executes machine instructions. Specifically single operand (simple) instructions. To assist you with this execution, you will be introduced to the microprogramming worksheets. Your understanding and use of these worksheets will be a valuable tool in the learning and the understanding of the $11 / 40$.

Once you understand how the $11 / 40$ accomplishes simple machine instructions, it becomes much easier to progress to the more difficult ones. Knowing how to implement the microprogram worksheet and then using that as a major learning tool will greatly enhance your knowledge and understanding of the 11/40.

PREREQUISITES

Satisfactory completion to date of all previous units.

## OBJECTIVES

Given a single operand machine instruction, you must fill out a microprogram worksheet. To demonstrate successful completion of this unit, you must correctly identify at least $80 \%$ of the required items. You are allowed to use any and all reference materials at your disposal, however, a twenty minute (20) time limit will be effect. You are required to complete within this time frame.

PRE-TEST

To be filled in when fully programmed environment in progress.

LEARNING ACTIVITIES

## I. LECTURE

Attend a short lecture where the instructor will introduce you to the microprogram worksheet. He will identify the format and point out to you some of the ways it can be beneficial to you as it applies to the $11 / 40$. He will also stress that first you must decide how a particular machine instruction works, then take it through the $11 / 40$ Block Diagram, and finally to the flows to verify and understand how the $11 / 40$ accomplishes it. Please hold your questions until the discussion period at the end of the lecture.
II. PROJECTS/QUESTIONS
A. The instructor will pass out microprogram worksheets to everyone and before filling in any information, will summarize the micro flow for the HALT instruction. Then together, the microprogram worksheet will be done.

1. Let us assume that we had deposited all zeros into memory location 500 (a HALT instruction). Then, after having depressed the START switch, we finally arrive at FETCH C, Flow Diagram Sheet C, PDP11/40 System Engineering Drawings.
2. At this point, $I$ think it might be a benefit to first decide what sequence we will be taking, then come back and attempt an explanation. The sequence is:
a. FET 02
b. FET 03
C. FET 04
d. FET 05
e. CON 00
f. CON 12
g. $\operatorname{CON~} 02$
h. CON 03
i. CONSOLE LOOP

Now list this sequence on your microprogram worksheet under the column - name.

## 3. FET 02

In this micro instruction, we are fetching the machine instruction. Notice we put the address from where we want the FETCH to occur in the BA Register and start a Data in BUS TRANSACTION
4. FET 03

Accept the incoming instruction and put it three places IR, $B, R[I R]$.
5. FET $04 \& 05$

In terms of the machine instruction, these two micro instructions look at it to see where to go after FET 05 (by doing the BUT 37). The additional accomplishment by FET $04 \& 05$ is updating the PC.
6. CON 00

Base address 100 gets modified to 122
because when the BUT 37 allowed the IR decode conditions to affect the base address, Bit 1 and Bit 4 were true. Refer to the appendix, and the instructor will put a visual via the overhead projector of the "Micro Branch Timing Simplified Overview for HALT" to assist in your understanding of the branching implementation.
7. CON 12

Move the Processor Status Word to the D Register. Set the Console $F / F$ (light comes on) and clears the examine \& Deposit F/F's. Do a BUT 24 - what brought me here a HALT Instruction or a HALT Switch - this time a HALT instruction therefore, when done with CONO2 go to CONO3 before dropping into the Console Loop. Allows the fact of HALT switch to modify Bit 1 of base address 024 if necessary.
8. CON 02
The main purpose of this micro instruction is to insure that the Processor has got control of the Unibus. The way it is accomplished is by turning off the CPU clock (IDLE (1)) then, setting the F/F await BUS Busy ( AWBY (1)) and when the Processors BUS Busy F/F becomes Set restart the clock and continue on. Now, if the Processor has the BUS; this will only be a slight hesitation but if not, he will stop here and wait until he does have it before continuing on.
9. CON 03

Take the contents of R0 and put it into the D Register, so that it will be displayed in the Console Loop.
10. $\mathrm{CON} 04>$

CON 06
Console Loop. Stay here displaying R0 looping between CON 04 and CON 06 until a Control Switch is sensed and you start some future action.

Now that you have finished this first project together, it is time for you to do one on your own.
B. Take a blank micro program worksheet and fill in the information as you just did. The instruction and pertinent information is given below. Start at FETCH C, Flow Diagram 8. Verify your answers with those given in the appendix.

GIVEN: $500 /$ INC (RI) $\quad$ Rl $=1000$ 502/HALT 1000/001234

GOOD LUCK
C. Take a few minutes now and investigate how a decrement would have worked as compared to the increment you just completed. Assume the same information given.

## III. SELF EVALUATION

Complete a micro program worksheet on the following instruction. When you finished, check your answers with those given in the appendix. Check with the instructor as necessary to clear up any misunderstanding. Start this worksheet at FET02, Flow Diagram 1, and go all the way through the sequence and back to FET 03.

$$
\begin{array}{ll}
\text { GIVEN } ; & 500 / \mathrm{BR} \text { SELF } \\
& 502 / \text { HALT }
\end{array}
$$

IV. ADDITIONAL READING

There is no specific reading associated with this unit, however, chapter 4 in the KDllA Processor Manitenance Manual DECll HKDAA-A-D provides information on the PDP1l/40 Flow Diagrams.

WHAT'S NEXT

After completing the unit, you should have a pretty goodfeel for the flows. In the next unit, you will continue with the flows tackling more difficult machine instructions. (double operand - type 1)

SUPPLEMENTARY INFORMATION
More practice worksheet assignments are available from the instructor if you feel the need.


| $\begin{aligned} & 500 / 000777 \\ & 502 / \mathrm{HALT} \\ & \hline \end{aligned}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NAME | PUPP | UPP | UPF | $\begin{gathered} \text { DATA } \\ \text { DISPLAY } \end{gathered}$ | $\begin{aligned} & \text { ADDRESS } \\ & \text { DISPLAY } \end{aligned}$ | COMMENTS |
| FET02 | 016 | 001 | 004 | 500 |  |  |
| FET03 | 001 | 004 | 005 | 000777 | 500 |  |
| FET04 | 004 | 005 | 100 | 500 | 500 |  |
| FET05 | 005 | 111 | 340 | 502 | 502 |  |
| BRA00 | 111 | 340 | 341 | 502 | 502 | Take the sign extend- |
|  |  |  |  |  |  | of B Register and add it to the |
| BRA01 | 340 | 341 | 016 | 501 | 502 | But where do I go |
| BRA0 2. | 341 | 016 | 001 | 501 | 502 | Same as BRAOO |
| FETO 2 | 016 | 001 | 004 | 500 | 502 |  |
| FET0 3 | 001 | 004 | 005 | 000777 | 500 |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |

## LEARNING ACTIVITY UNIT

FLOW DIAGRAMS ..... IV
DOUBLE OPERAND INSTRUCTIONS ANDOVERLAP$1 / 21 / 74$

## RATIONALE

In the previous units concerning the $11 / 40$ Flow Diagrams, you learned how to interpret and understand the Flows. and how they apply to simple operations. Hopefully, you have realized what the flows can do to help you understand the PDP $11 / 40$ operation. You have been introduced to the microprogramming. worksheet and realize how it can help you master the flows. It is time to go even deeper into the 11/40 Flow Diagrams and try more difficult operations.

This unit mainly deals with the flows handling Double Operand instructions and the concepts concerning Overlap. You will complete several worksheets using a couple of examples to assist you in understanding the unit; that is. the way the $11 / 40$ does these 'more difficult' operations.

Once you have mastered these Flows, the rest of the $11 / 40$ becomes very easy. This is the next to the last unit in the Flow sequence and incorporates most of the ideas learned in the first three. The Flows can answer almost any question concerning the $11 / 40$ operation - to know the Flows is to know the machine.

## PREREQUISITES

Satisfactory completion to date of all previous units.

## OBJECTIVES

Given a double operand machine instruction you must correctly complete a microprogram worksheet. To demonstrate successful completion of this unit you must correctly identify at least $80 \%$ of the required items. You can use any of your notes and/or reference material, however, a twenty (20) minute time interval will be in effect. You are required to complete within this time.

## PRETEST

To be filled in when full programmed environment is in progress.

```
11/40 - KDllA - 070
```


## LEARNING ACTIVITIES

## I. LECTURE

Attend a short (10-20) minute lecture where the instructor will define the conditions for Overlap. He will present the ideas, concepts and advantages of the Overlap situation. He will again stress that a knowledge of the machine instructions operation and its movement through the block is necessary before attempting a microprogram flow sequence. Please hold your questions until the end of this lecture when a question and discussion period will be held.
II. PROJECTS/QUESTIONS
A. The instructor will pass out a microprogram worksheet and everyone will work this first one together. The first example will incorporate the Double Operand instruction and the Overlap feature together.

GIVEN:

> 500/MOV \%RO, \%Rl 502/HALT

RO $=000050$
Rl $=000100$
This instruction will move the number 50 which is in RO to Rl. Now let us fill out a microprogram worksheet to see how this is accomplished.
B. Now turn to Page 4-12, Paragraph 4.3 in the KDllA Processor Maintenance Manual and read the example found there. Go through Flow Diagram Example I, Table 4-2, pages 4-13 through 4-16, throughly, step by step and answer the following questions when you are finished.

1. What UPF does the BUT (INSTR l) work on?
2. What Bits does the BUT 37 modify?
3. What General Purpose Register does the Source Operand get put into?
4. In what microinstruction is the $A D D$ really accomplished?
C. Now go through Flow Diagram Example 2, Table 4.3, Pages 4-17, 4-18 in the KDllA Processor Maintenance Manual using the same procedure as above. Answer the questions below when you complete this project.
5. Why is $\mathrm{R}(\mathrm{SF})$ incremented by 2 in SRC 01 ?
6. What ALU input does the Source Operand go into?
7. What is the 'C' Bit after this instruction is executed?
III. SELF EVALUATION

Complete a microprogram worksheet for the following instruction. Check your results with those in the Appendix.

GIVEN :
500/CMP (R1), (R2)

$$
1000 / 000050 \quad \mathrm{Rl}=1000
$$

$$
R 2=2000
$$

2000/000040
$777776 / 000017$
This instruction compares the contents of memory location 1000 to the contents of memory location 2000 and affects the condition codes in some manner. Remember the destination operand is not chenged - in other words, no results are delivered to the destination address.

When you complete this successfully, you should be ready for the Post Test which will be similar type project.

$$
11 / 40-\mathrm{KD11A}-070
$$

## IV. ADDITIONAL READING

The remaining pages of Chapter 4 in the KDllA Processor Maintenance Manual contain a listing of all the $11 / 40$ microinstructions; you may find this useful.

Any information about the instruction operation you find necessary to review can be found in the $11 / 40$ Processor Handbook, Chapter 4. Feel free to look at this any time.

## WHAT'S NEXT

After completing this unit, most of the major Flow Diagram operations are complete. In terms of the instruction operation, you are finished, therefore, the next unit will deal with the Traps and Service Flow Diagrams and that will complete the section dealing with the Flows.

## SUPPLEMENTARY INFORMATION

More practice instructions are available from your instructor should you want or need more practice.

## APPENDIX

ANSWERS TO ..... II:
B. 1. 100
2. BIT 5, BIT $\varnothing$
3. R11
4. DOP 03, ..... 225
C. 1. R(SF) equals 7, PC
2. B input
3. Cleared, there was a carry.

## APPENDIX

PDP $11 / 4 \varnothing$
MICROPROGRAM
$11 / 40$ - KD11A - 070
WORKSHEET


## LEARNING ACTIVITY UNIT

$1 / 21 / 74$

## RATIONALE

This is the last of the units concerning the PDP1l/40 Microprogram Flow Diagrams. To date, you have learned how to read, interpret, use and understand the Flows. You are prepared to take any unknown or unfamiliar instruction and determine how the $11 / 40$ accomplishes the execution of it by using your knowledge of the microprogram Flow Diagrams.

One of the most important aspects of any of these Processors: the $11 / 05,11 / 40$ and the $11 / 45$ is how they interface to the Unibus, specifically how they handle priority transactions (servicing) and the procedures taken when error conditions exist (trapping). This unit will be concerned mainly with these two groups of microprogram Flow Diagrams.

Once you understand how the $11 / 40$ handles these bus transactions, you can relate it to your knowledge of the $11 / 05$. You will also have a better understanding of the Unibus and this unit will also help you later on with the peripherals. Although this is the last unit of the Flows, it may very likely be the most important one of the sequence.

## PREREQUISITES

Satisfactory completion to date of all previous units.

OBJECTIVES
Given four multiple choice questions concerning the Service and the Trap Microprogram Flow Diagrams, you must choose an answer from four possibilities. To demonstrate successful completion, you must correctly answer three of four questions.

You will be able to use all available references but you must complete the test in 20 minutes.

PRETEST
To be filled in when fully programmed environment is in progress.

## I. LECTURE

Attend a 40 minute lecture where the instructor will give a brief review of the priority transactions on the Unibus, namely $B R^{\prime} s$ and NPR's. A summary of the $B R$ and $N P R$ timing will also be given. An overview of the Trap Micro routines will be given with particular emphasis on error handling, and a brief look at the Service Micro routines with the emphasis on priority transactions. Hold your questions until the lecture is over when there will be a short discussion period.

## II. PROJECTS/QUESTIONS

A. The entry to the Service Flows, sheet 10 , PDP ]l/40 System Engineering Drawings, when doinga WAIT instruction is Service A, which you can readily determine. Verify that the WAIT Loop, then, consists of the following group of micro instructions. (assume nothing of a higher priority is pending)
SEROO 114

SER05 015
SER06 012
SER07 020
SER08 021
SER02 017
SER05 015
etc
Notice the micro instructions across the top of this sheet. All have in them a BUT Request. Check note 2 on this sheet for a complete definition.

You will stay in this WAIT Loop until such time that you get a BR - at that time you will drop through to SER09. Refer to "Additional Readings" if you feel more review on priority transactions is needed.
B. Once a $B R$ is received, arbitrated and a BG is issued, you go to SER09 shut off clock and wait for the interrupt to arrive informing you that the vector information is on the "D" lines.
11/40 KD11A ..... 080
Trace the steps you now take - pushingonto the stack your current PC and PSW andobtaining a new PC and PSW having been giventhis vector address. The sequence shouldcorrespond with the following.
SER10 ..... 002
SERII ..... 023
TRP 08 ..... 007
TRP09 ..... 115
TRP 10 ..... 326
TRP11 ..... 327
TRP 12 ..... 113
TRP13 ..... 330
TRP 14 ..... 331
TRP 15 ..... 077
TRP 16 ..... 140
TRP20 ..... 332
TRP21 ..... 333
SER0 3 ..... 123
SER05 ..... 015
FET0 0 ..... 013
C. Verify that, under the condition of Red Zone overflow and Double Bus Error, the Trap sequence would be altered as such.
TRP0 0 ..... 336
TRP01 ..... 317
TRP02 ..... 215
TRP09 ..... 115
etc
III. SELF EVALUATION
Answer the following questions and check yourresults with the answers found in the appendix.
A. After arriving at the Service Flows anddoing a BUT 26 , you find two requests pend-ing.

1. BERR
2. $B R$
Which would be serviced first?
B. What is the next micro instruction executed after SER05 if you have a yellow zone overflow.
C. What is displayed in the Console Data lights when you have executed a WAIT insturction and you are in the WAIT Loop?
D. What location is the new Processor Status obtained from?
E. If this $B R$ and Interrupt Sequence had been set off due to a Teletype Key being depressed what would the Console Data lights read when PUPP equals 332?

ADDITIONAL READING
To reinforce your understanding of the priority transactions on the Unibus, you can read paragraphs 5.6 thru 5.10, pages 5-17 thru 5-34 in the PDPIl Peripherals Handbook and or paragraph 3.2 .2 and corresponding figures, pages 3-2 thru 3-12 in the KDllA Processor Maintenance Manual. General Unibus theory and operation explanations are found in chapter 5, pages 5-1 thru 5-17 of the PDPll Peripherals Handbook.

## WHAT'S NEXT

After completing this unit, you are finished with the microprogram Flow Diagrams. You now have the ability (given some machine instruction) to take it through the Flows intelligently describing the events that ta'e place along the way. After a Lab period to reinforce the flows and the Maintenance Module usage, you will be ready to go into the Engineering Drawings.

## SUPPLEMENTARY INFORMATION

If you feel the need for more practice with the flows or more information concerning the operation of PDP11/40 consult with your instructor for additional assignments.
APPENDIX
Answers to self evaluation
A. BERR
B. TRPO3
C. The WAIT instruction inclusively ORed with the updated PC
D. The vector address plus 2
E. ..... 060

## APPENDIX



Notes:
b. PCLR MSYN just finishing a Data XFER Bus Cycle clock is on but will go off when micro Cycle clock is on but will go off when micro Service needed. NPG occurs
a. BGBUS (1) - microword specifies a data transfer
. ENPR CLK from EIS/FIS option
BUT26•P3 orogram .
. BUT26 P3 -- microprogram fust entered SE RVICE
a. - AWBY'SET CLK - clock restarting after bus cycle
f. PMSYN - A device has asserted BUS MSYN
2. Microprogram either just starting or finishing a data XFER

SERVICE give up the bus to do NPRs on BUT26 and on AWBBY
3. SACK timeouts will not cause a trap but will generate CLR TR which cleans up the NPR Priority XFER control flip flops, and will restart Processor Clock. Bus Cycle or in Service when processor gives up the bus to the NPR device
a. CLK BUS - just starting processor Data XFER clock will be turned off in this $U$ word or succeeding word

KD11-A Priority Transfer Timing and Control for NPRs


KD11-A Priority Transfer Timing and Control for BRs (Sheet 1 of 2)


KD11-A Priority Transfer Timing and Control for BRs (Sheet 2 of 2)


Figure 3-3 NPR Priority Transfer Timing Sequence


KD11-A Bus Data XFER Timing and Control


BR Priority Transfer Timing Sequence


11-1677

KD11-A DATI(P) Bus Transaction Timing Diagram


NOTES: 1. EFFECTS OF GATÉ DELAYS AND F.F. RESPONSE NOT SHOWN 2. ASSUMES KD 11 A HAS CONTROL OF THE UNIBUŚ |BBSY(1)।
3. CLOCK NPR REQUESTS. IF NPR (1) THEN BBSY - 0
4. .. TRIGGERING DELAY TO CLOCK MSYN CONDITIONAL

UPON MACHINE STATE: - (PROC RELEASE + SSYN) • BBSY (1)
5. † MSYN BEING SET TRIGGERS 15 USEC BUS TIMEOUT DELAY
6. INHIBIT SETIING MSYNIF BUS STOP IS ACTIVE

IRED ZONE OVFL + ODA ERR| TRAP
7. SCALE: 1 INCH = 100 NSEC

## LEARNING ACTIVITY UNIT

## PDP $11 / 40$ LABORATORY PROJECT I <br> MAINTENANCE MODULE USAGE <br> 1/21/74

## RATIONALE

In the previous units you have analyzed the $11 / 40$ Block Diagram and then the Flow Diagrams to understand how the processor accomplished the execution of machine instructions. With your general knowledge, the Block Diagram and the microprogram worksheets you were able to determine what exact steps the processor went through and what happens at each of these.

In this unit, then, you will verify that your previous determinations were in fact correct. You can do this by using the KM1lA Maintenance Module. This maintenance aid allows you to execute one microinstruction at a time and then stop, one microinstruction and stop, etc.

The only way to determine if the sequence of microinstructions is correct and the data is correct is through proper use of the KMIlA. To trouble shoot the PDP $11 / 40$ effectively you must be able to correctly operate the Maintenance Module and analyze the information it provides for you.

## PREREQUISITES

Successful completion to date of all previous units.

## OBJECTIVES

Given one of the various console functions you must verify that the sequence taken and the data displayed is correct. After a console function do a typical machine instruction to verify its operation. To demonstrate successful completion of this unit you must correctly determine the sequence and the Data of a machine instruction given to you by the instructor, and record it on a microprogram worksheet.

## PRETEST

To be filled in when a fully programmed environment is in effect.

```
1l/40 - KDl1A - 090
```


## LEARNING ACTIVITIES

I. LECTURE

Attend a short lecture where the instructor will define the indicators and switches of the KMllA as it applies to the PDP 1l/40. Then a brief overview of its usage in the KDllA. All procedures concerning its use and purpose will be outlined. Questions will be answered and discussion permitted during this lecture.
II. PROJECTS/QUESTIONS
A. Before going to Lab

1. Review the procedure taken to check out equipment.
2. The instructor will make team and machine as signments as necessary.
3. Take the necessary material, to include:
(a) Picture of overlay.
(b) Processor Clock Block Diagram.
(c) Several Micorprogram Worksheets.
(d) Paper and pencil.
(e) Processor Engineering Drawings.
(f) KMll Maintenance Module Set.
B. After arriving in Lab
4. Go to your assigned machine and make sure the power is off.
5. Assemble and install the KMll in Slot Fl of the KDllA backplane.

$$
11 / 40-K D 11 A-090
$$

3. Turn the Mclk Enab switch to the OFF position and put the HALT switch on the console to the Halt position and power up.
4. Once in the console mode dynamically Load Address to 500 and deposit a MOV \%0, \%l.
5. Now activate the KM1l and single clock through an Examine of the instruction you just deposited.
6. When back in the Console Mode depress start and execute the previously deposited instruction to verify its operation.
7. Continue to practice using the Maintenance Module until such time that the instructor gives you your Post Test. Use your examples that you took through the Flows previously for additional practice.
C. Before leaving the Lab
8. Power down your systems and remove the Maintenance Module.
9. Replace panels, close doors, etc. to properly secure the system you were working with.
10. Straighten chairs, tables, etc. as necessary.
III. SELF EVALUATION
A. Dynamically deposit the following information then single clock this instruction through. Check your results with those in the Appendix.

5000/BICB \#377, - (3)
R3 $=3000$
2776/177777
Start at FET 05 and give final results.

```
1l/40 - KDllA - 090
```


## IV. ADDITIONAL READING

Paragraph 7.3 and corresponding figures and tables on pages 7-4 - 7-8 in the KDllA Processor Maintenance Manual contain a detailed description of the KMllA.

## WHAT'S NEXT

After completing this unit, you have completed the second major portion of the $11 / 40$. (First the Block Diagram, then the Flow Diagrams, and finally the Engineering Drawings which will be started next.) You are well on your way to obtaining the necessary knowledge and understanding to do an acceptable maintenance job with the PDP ll/40. In the next four (4) units you will identify and analyze the $11 / 40$ Engineering Drawings so that you obtain a working knowledge of major circuits and the prints in general.

## SUPPLEMENTARY INFORMATION

If you want more practice with the Maintenance Module, arrange some extra Lab time with your instructor.

| $\begin{gathered} \text { PUPP } \\ 6 \end{gathered}$ | $\begin{gathered} \text { PUPP } \\ 3 \end{gathered}$ | PUPP | $\underset{6}{\text { BUPP }}$ | $\underset{3}{\text { BUPP }}$ | $\begin{gathered} \text { BUPP } \\ 0 \end{gathered}$ | C | © |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\underset{7}{\text { PUPP }}$ | $\begin{gathered} \text { PUPP } \\ 4 \end{gathered}$ | PUPP | ${ }_{7}^{\text {BUPP }}$ | $\begin{gathered} \text { BUPP } \\ 4 \end{gathered}$ | $\begin{gathered} \text { BUPP } \\ \hline \end{gathered}$ | V |  |  |
| $\begin{gathered} \text { PUPP } \\ 8 \end{gathered}$ | $\begin{aligned} & \text { PUPP } \\ & 5 \end{aligned}$ | $\begin{gathered} \text { PUPP } \\ 2 \end{gathered}$ | $\begin{gathered} \text { BUPP } \\ 8 \end{gathered}$ | $\begin{gathered} \text { BUPP } \\ 5 \end{gathered}$ | $\begin{gathered} \text { BUPP } \\ 2 \end{gathered}$ | Z | ©MCLK |  |
|  |  | TRAP | SSYN | MSYN | T | $N$ |  | MCLK <br> ENAB |

NOTE:
Maintenance module set plugs into slot F 1 of the KD11-A
PUPP = Address of the microinstruction stored in the Ureg.BUPP $=$ Address of the next microinstruction beingread out.1. MSTOP - Allows stopping the processor clock whenBUPP $=$ SR (8:0)2. MCLK ENAB - disables processor clock and allows singleclocking the microprogram with MCLK
3. MCLK - single clock switch
KD11-A Maintenance Module Overlay

$$
-5-
$$

SYNCHRONOUS REGENERATION


KD11-A Processor Clock, Block Diagram

EXAMPLE:


DEC 9-(673)-1022-N273

## LEARNING ACTIVITY UNIT

PDP 11/40 LOGIC DIAGRAMS I FORMAT - SPECIAL CIRCUITS - DATA PATHS<br>1/21/74

```
11/40 - KD11A - 100
```

RATIONALE

In the Learning Activity Units up to this point, you have learned the operation of the $11 / 40$ utilizing the Block Diagram and the Flow Diagrams. Along with your general knowledge and these two things it became possible to determine how the $11 / 40$ executed the 11 instruction set.

Now that you know how the CPU does its' thing, the last several units will deal with the Logic Diagrams (Engineering Drawings). You will be given an overview of the prints and shown the major circuits and key signals. An attempt will be made to provide you with the 'ability to gate chase' should it become necessary in the future. Identification. location, description and understanding will be our main goals during the next five units.

If at some time you find it necessary to trouble shoot the Processor down to chip level, these units will prove invaluable to you. A basic understanding of the prints will reinforce those concepts and ideas that you may have had difficulty with to date in the course.

## PREREQUISITES

Satisfactory completion to date of all previous units.

## OBJECTIVES

Given ten signals and/or circuits concerning the Data Paths, you must locate them in the Print set and state the coordinate and page number. To demonstrate successful completion of this unit you must correctly locate and state eight (8) of these signals/circuits. A time limit of 20 minutes will be allowed.

## PRETEST

To be filled in when fully programmed environment is in progress.

$$
11 / 40-K D 11 A-100
$$

## LEARNING ACTIVITIES

I. LECTURE

Attend a forty-five (45) minute lecture where the instructor will introduce the Engineering Drawings. He will discuss the format of each print, identify the conventions and present a brief overview of the Data Paths, module M7231.

Some special circuit chips will be analyzed and pointed out to you in the logic diagrams. Make notes on your prints and jot down any questions you may have and ask them after the lecture.
II. PROJECTS/QUESTIONS

With your Block Diagram as an aid:
A. Analyze the D mux on the Kl-2 print and identify the four possible inputs. List the binary configuration of the SDM bits and the corresponding inputs below and on your block diagram.

|  | SDMI, 0 | INPUT TO D MUX |
| :---: | :---: | :---: |
|  | FROM |  |
| 1. |  |  |
| 2. |  |  |
| 3. |  |  |
| 4. |  |  |

i3. Determine the output of BMUX BIT0 on the Kl-2 print when the SBML BITS are equal to two (10)
C. At coordinate $B \delta$ on Print Kl-4 there are some 74H04 inverters at component location E29. What is the DEC part number?
D. Locate the ALU (07:04), determine the inputs to $A$ and $B$ and the origin of the control bits to the ALU.
E. The BA MUX is contained on
integrated circuit chips and is found at coor-
dinate
F. The D register is a $\qquad$ type chip and gets its input from the $\qquad$
G. On Kl-6, Bl you find FO4P2 state all you know about this.
H. The D(C) Flip Flop is on Kl-5 at what time is it clocked?
I. The BA register is located on Kl-6. Analyze the AND Gate at D6 (E5) and describe its purpose.
J. On the Kl-7 Print determine the first decoded address to give you the signal BOVFL stop H.
K. The GPRs on Kl-8 are type 3101A chips. What does it take to:

1. Address a GPR
2. Read a GPR
3. Write a GPR
L. On the Kl-9 Print a comparison of the SR and BUPP takes place. What two (2) outputs does this circuit provide?

Check your answers to the preceeding questions in the Appendix. Get help from your instructor if you do not understand any of the above or if you want a more detailed explanation of any of the circuits.
III. ADDITIONAL READING

Chapter 5 in the KDllA Processor Maintenance Manual contains the Logic Diagram Description. Pages 5-1, 5-2, 5-3 are concerned with the general format and pages 5-3 through 5-19 with a more detailed description of the M7231 Data Paths Module. All of this reading will be of a benefit to you now and in the future.

## WHAT'S NEXT

After completing this unit you will continue with your analysis of the logic diagrams and go on to the rest of the Engineering Drawings. This group of LAU's consists of four (4) units.

$$
11 / 40-K D 11 A-100
$$

## SUPPLEMENTARY INFORMATION

Consult your instructor if you want more practice or additional projects with this first unit of the logic diagrams.

APPENDIX


EXPANDED ADD/NOR. ALL "AND GATES" MAKE OUTPUT REACT IN SAME MANNER.

## APPENDIX



ALL LOWS TO ADRS R17



$$
11 / 40-\mathrm{KD} 11 \mathrm{~A}-100
$$

## APPENDIX



## APPENDIX




## APPENDIX

ANSWERS TO PROJECTS AND QUESTIONS
II. A. 1. 00, RD BUS
2. 01, UNIBUS DATA
3. 10, D REGISTER
4. 11. D REGISTER RIGHT SHIFTED
B. B08 (swapping or duplicating bytes)
C. 1909931 (KI-1)
D. 1. A input $=$ RD BUS
2. $\quad$ B input $=B M U X$
3. Control bits from K3-8
E. 1. four (4)
2. B2
F. 1. 74174
2. ALU
G. 1. Level F (bottom) of a HEX height module
2. Slot 4 of the 9 slot KDllA Backplane
3. Pin $P$
4. Row 2
H. When the D register is clocked (CLKD \& P2 pulse)
I. It is this And Gate that monitors BITS 13, 14, 15 of the BA register so that Bit 16,17 become active low on the address lines whenever the attempted address is $\geq 160000$.
J. 336
K. 1. One of the four (4) select signals, SRI, SRBA, SRS, SRD, and their associated bits.
2. Same as above
3. Same as above plus a write signal.
L. 1. UPP Match
2. P Match
LEARNING ACTIVITY ..... UNIT
LOGIC DIAGRAMS II
UWORD AND IR DECODE$1 / 21 / 74$

## RATIONALE

In the previous unit, you were introduced to the format of the logic diagrams and you took a relatively close look at the Data Paths module (M7231). You were able to identify and locate major circuits and key signals. You then applied that knowledge to your previous knowledge of the Block Diagram so that you could make a meaningful correlation between the two.

Prehaps this unit contains the two most important modules in the PDPIl/40, UWord (M7232) and IR Decode (M7233). The ROM of course, being the heart of the Processor and the BUT providing the streamlining of the Microprogram. Our major goal in this unit will also be to identify and locate major circuits and key signals so that we recognize them in the future if the need arises. You will be able to discuss and illustrate the major areas of these two modules when you have completed this unit.

The knowledge and skills that you acquire in this unit will enable you to effectively identify problems within these modules. In a subsequent unit, you will be required to troubleshoot some live problems concerning these two modules and successful completion of this unit should enable you to properly isolate them.

## PREREQUISITES

Satisfactory completion to date of all previous units.

## OBJECTIVES

Given five multiple choice questions regarding circuit operations/failure symptoms, you must choose the most correct answer from those distractors given. To demonstrate succéssful completion, you must correctly answer four of the five questions. You will be allowed to use all available references but a time limit of 20 minutes will be in effect.

## PRETEST

To be filled in when fully programmed environment is in progress.

## LEARNING ACTIVITIES

## I. LECTURE

Attend a short lecture where the instructor will give a brief overview of the UWord M7232 and IR Decode (M7233) Logic Diagrams. Pay close attention and take any notes you feel are pertinent. Jot down your questions to ask after the lecture. Correlate your prints to the Block Diagram whenever possible to provide for a better and more thorough understanding.
II. PROJECTS/QUESTIONS
A. K2-2 Print

1. Analyze the UPP Flip Flops down the center of the print. Note how their state can be affected. Let us look at UPP3.
a. Direct set or clear by JAMUPP Logic
b. Clocked at (CLK (UPP * PUPP))
c. Data Input qualified
(1) Output of ROM El5
(2) BUS U03 - from expantion ROM
(3) BUBC - Basic Micro branch Control
2. Locate the PUPP register and identify what the inputs are and when the clocking takes place
B. K2-3 Print
3. Locate the address imput to the ROM chip at the left side of the print \& define this. (the UPP register output supplies the address to the ROM, verify on your Block Diagram)
4. Completely describe the clocking and data qualifications for the UPP8 Flip Flop. Compare your results with those given in the Appendix.
5. Note that this print completes the UPP and PUPP registers and that postion of the ROM that contains the UPF.
C. K2-4 through K2-8 Prints
6. These diagrams contain the remainder of the UWord. Analyze these and identify the ROM chips and the corresponding register Flip Flops.
7. On the $\mathrm{K} 2-8$, note the three (3) Berg connectors. These connectors carry the expansion ROM bits if the EIS option is installed. They are left blank on ma- chines without the KEll-E
D. The ROM (Micro instruction) listings are the final
two sheets before the IR Decode, it gives thecontents of each location in the KDll-A's ROM.Review your knowledge of these fields andformat with the simplified description anddiagram in the appendix.
E. K3-2 Prints
Analyze each of the six (6) multiplexer chips
found here and determine the following:
8. Which BUT's activate each chip
9. Which Bits can each control
10. Where do the outputs from these multiplexers go
11. If a particular butted condition is true - what level leaves this page
When you have made your determinations verifyyour findings with those in the appendix
F. K3-3 Print IR \& Decode
12. Analyze the four (4) IR register chips found on this print and note the inputs, outputs and clocking. Correlate this print with your Block Diagram.
13. Inspect the IR decoders to insure your comprehension. These should not be new to you. Check the truth table on this print and the appendix to verify your thoughts. Note the type outputs you get from these decoders.

## G. K3-4 Print IRD \& Overlap

> 1. More IR decoding found at the top of this print. Note what it takes to enable decoder E34.

> 2. Overlap combinational decoder. Decodes those various conditions under which we start a Fetch in micro instruction FET04. Cross reference the Boolean Expression of the overlap conditions found in note 3, Flow Diagram 1, to this logic. Verify as many conditions as you feel necessary.
H. K3-5 Print to modify Base Address 100 during a BUT 37. In other words, the logic that facilitates getting off Flow Diagram 1.

1. Let us analyze how the WAIT instruction would condition the appropriate bits such that Base Address 100 when doing a BUT 37 would become modified to a ll4. BITS 2 \& 3 are the ones we will concern ourselves with. Start at coordinate C5 with the translation WAIT 6.
a. Immediately fires two gates; E70 pin 8 and E 69 pin 8
b. From E70 pin, 8 through E29 pin 10 through E 35 pin 03 to become BUBC3 H.
c. From E69 pin 8 through E54 pins 1 \& 2 to become BUBC2 H
d. These two signals feed to sheet K3-2 E98 and E90. When a BUT 37 is active these two multiplexer chips invert and send a low to K2-2, E5 pin 5 and E7 pin 11 such that the UPP Flops can and will become set.
2. Now you do the same as above for the Halt instruction. When you are finished, check your results with the sketch in the appendix
I. K3-6 PrintMore IR decoding just note general layoutand the culmination of the decoding downthe right hand side of print
J. K3-7 Print
Decoding for most of the other BUTS. Forexample, byte instructions, odd byte, SUBetc. There is an important piece of logicacross the top of the page the Service Logic.When you arrive at the end of any machineinstruction, as you recall, you BUT Serviceand if Service is high then you go to theService Micro Flow. Investigate thoseconditions that will result in Service andlist them below including a brief explanationCheck your list against the appendix when youhave completed
3. 
4. 
5. 
6. 
7. 
8. 
9. 

K. K3-8 Print
ALU control. Locate and identify the following
circuits.

1. The CIN multiplexer
2. The Cout multiplexer control
3. The ALU control multiplexer
L. K3-9 Print
Data conditioning inputs for the two processorstatus flip flops V and C
4. Analyze E26 at cooridinate B 2 (lower) note that during rotates and shifts to the right this gate enables PS(c) to accept D00.
5. Identify which gate is used when doing a SET condition code instruction.

## III. ADDITIONAL READING

To broaden and reinforce your understanging of the logic just covered, it is recommended that you read and study the detailed logic descriptions in the KDllA Processor Maintenance Manual, pages 5-21 through 5-57

WHAT'S NEXT

After completing this unit, you should have developed the logic/technique necessary to master these prints. You will get more practice with the remaining prints of the processor.

SUPPLEMENTARY INFORMATION

If you want more practice, consult your instructor for additional assignments.



The Binary value of $\mathrm{D} 2, \mathrm{D} 1, \mathrm{D} 0$ activates one of eight possible outputs. D3 must be low to enable chip. Note example.


## APPENDIX



E97
Can modify
Bito for
all BUTS
between 00
\& 178
Disabled
when UBF 4 is high

UWORD LISITNG FORMAT


UWORD LISTING FORMAT

| FLOWS | STATE | ARD | CLK | CIR | WR | CB | CD | CBA | BUS | DAD | SPS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |
| Flow | Mnemonil | 8 Bit | 3 Bit | $\mid 1$ Bit $\mid$ | 2 Bit | 1 Bit | 1 Bit | 1 Bit | Bit | 4 Bit | 3 Bit |
| Page | name of | Octal | lock | the IR\| | Write | Clock | Clock | Clock | bus | Dis- | \|select ${ }^{\text {' }}$ |
|  | micro | Add- | Code | Regis- | the | the B | the D | the BA | rans- | crete | Pro- |
|  |  | ress |  | $1 \text { ter }$ | GPR's | Regis- | Regis-, |  | ction | alter- | $\int_{\text {cessor }}^{\text {Pro- }}$ |
|  |  |  |  | 11 |  | ter | ter | ter | ode | ation | \|status |
|  |  |  |  |  |  |  |  |  |  | of ${ }_{\text {data. }}$ | $\left.\right\|^{\text {code }}$ |
|  |  |  |  | 1 |  |  |  |  |  | code |  |


APPENDIX

SERVICE CONDITIONS

## 1. $\mathrm{DM}=0$ * PS ADRS

2. CBR (I) L
3. $\operatorname{PS}(\mathrm{T}) *-\mathrm{RTT}$
4. BERR
5. BOUFLW
6. PWRDN
7. BRP

DESCRIPTION

> You have just done something with the PS, you may have changed priority go back through Service just in case.

Console Bus Request. Halt switch is depressed.

Go through Service on way to trap flows.

Go through Service on way to trap flows.

Go through Service on way to trap flows.

Go through Service on way to trap flows.

Go through Service on way to trap flows.

## LEARNING ACTIVITY UNIT

## KDllA LOGIC DIAGRAMS CLOCK, JAM CLK, BUS DETAYS, MISC. 1/23/74

## RATIONALE

By this time, you should be pretty good at finding your way around the prints. You have studied the major portions of the $11 / 40$ which are represented on the Block Diagram. You have also seen how the prints are laid out and the types of circuits and nomenclature used.

Now you will study the logic that is used to control the KDIlA. You will see the timing and clock pulse generation, the JAM CLK function and the power fail control. Then you will pick up some of the miscellaneous but essential circuitry, such as: the status bits, BUT Decoder, flags and the B Constant generator.

This unit is important in that this circuitry is usually the place where you have got to start when the machine is completely dead. Often the trouble is the JAM CLK logic not operating properly or the clock not generating the right pulses, etc.

Successful completion of all units to date.

## OBJECTIVES

Given some failure symptoms and a list of components, to demonstrate successful completion of this unit you will be required to pick the component which, if faulty, would most likely generate each of the symptoms.

LEARNING ACTIVITIES

## I. LECTURE

Attend the lecture in which the instructor will give an overview of the following prints:

K4-2, K4-3, K5-8, K5-2, K5-3, K5-4, K5-5
The LAU will be your study guide for the first three of these. The lecture will cover all you need to know about the other four. So, pay close attention and take careful notes of all key signals and components.
II. PROJECTS/PROBLEMS
A. K4-2 CLOCK

1. Analyze how and when P1, P2 and P3 pulses are generated. Fill in the table below indicating all the possible combinations of clock length bits for each pulse.

P1 P2 P3
CLKL0
CLKLI
2. Analyze gate E62 output pin 06 at $\mathrm{C}-3$. When is a RECLK generated? Which timing pulse does not generate a RECLK?

Observe how RECLK clocks the CLK flop at C-5, 6
3. Gate E88 output pin 08 at C, D-6 turns the clock on (This is the input called ASYNCHRONOUS on the block diagram). Inputs pins $01,02,03,04$ are for restarting the clock after a normal bus cycle. What are the conditions which qualify this gate.
4. E87 output pin 08 and E 82 output pin 08 at $D-6,7$ are for the other cases the clock is started asynchronously. Note on your prints the following functions:
a. E87 pin 09 - from EIS Option
b. E87 pin 10 - to restart clock at the end of a RESET instruction.
c. E82 pins 09, 10 - after a BR in which data is being transferred - not used by any DEC equipment.
d. E82 pins 02, 03 - after a $B R$ in which a vector address has been transferrred - this is the normal BR use
e. E82 pins 01, 13 - for starting after all JAMs except the first JAM of a power up.
f. E82 pins 04, 05, 06 - for starting after an NPR cycle.

Make note of these on your prints. We will see them again and discuss them further as we study JAMUPP later in this unit
5. Find the IDLE flop at $C-6$. This is set to indicate that the clock is turned off. Analyze how the gate which enables the data input to set the IDLE flop also causes the CLK flop not to set. The conditions which set the IDLE flop are as follows:
a. E77 pins 09, 10 - for the beginning of a JAM sequence
b. E77 pins 02, 03 - for a normal bus cycle

- ALLOW CLK L tells us we are doing the last DATI to get the destination operand for a BIT, CMP or TST instruction
- why is that signal here?
c. E77 pins 13, 01 - for a Match Stop - remember, this is when the contents of the UPP is the same as the contents of the switch register and the Match Stop switch is enabled on the maintenance board.
d. E77 pins $04,06,05$ - for a FETCH OVLAP - note this will stop the clock if we are in an OVLAP situation and the clock length bits are 0,0 .

6. Observe how the MCLK flop can simulate the clock when doing maintenance functions.
a. Does the maintenance board inhibit the operation of the IDLE flop?
b. Does the maintenance board inhibit the operation of the CLK flop?
7. Observe the enabling gates down the page underneath the number 2 .
a. Which four timing pulses generate CLK $U$ and CLK (UPP * PUPP)?
(i)
(ii)
(iii)
(iv)
b. Notice the clocking signals for the various register. Analyze to find out what pulses clock each of the following:

$$
\text { (c) } \quad \mathrm{B}
$$

(ii) GPR
(ii) IR
(iv) BA
( $v$ ) D

Do these match what you previously noted on your Block Diagram?
B. K4-3 CLK JAM

1. The $2 \mu \mathrm{sec}$ JAMUPP one-shot is really the heart of this circuitry. It is fired by qualifying gate E80 output pin 06 at D-5. The conditions which will do this are:
a. E80 pin 01 - JBERR flop which is set on an odd address error or a red zone stack overflow
b. E80 pin 02 - JPUP flop which is set for START switch activation in the HALT mode or for Power Up Restart
c. E80 pin 05 - NODAT flag is for SSYN time out for non-existant bus address errors
d. E80 pin 04 - PWRUP INIT is for a special JAM used during the power up sequence
2. Study the following sequence using an Odd Address Error as an example.
a. ODA ERR will generate BUS STOP and then CLK MSYN will set the JBERR flop.
b. This fires off the JAMUPP one shot
c. JAMUPP sets the IDLE flop on K4-2 and stops the processors clock.
d. JAMUPP anded with ODA ERR L directs sets and clears the UPP flops to put 002 in the UPP on $K 2-2,3$
e. A 100 nsec delay is allowed for 002 to be addressed in the ROM and have its contents sitting at the input to the U REG and its UPF bits on the inputs to the UPP.
```
f. After the delay, JAM CLK is true generating CLK \(U\) and \(C L K\) (UPP * PUPP) on K4-2
What will now be contained in the following registers? Use your flows to help you
```

(i) PUPP
(ii) UPP $\qquad$
(iii) U REG $\qquad$
g. JAM CLK also fires the 100 nsec oneshot called JAMSTART. This will restart the processors clock a K4-2 and the processor continues on its sequence in Service to service the error.

All the other conditions which cause JAMs work in the same way, each causing a unique address to be jammed into the UPP. The only one which is slightly different is a power up JAM, and we will study this next.
C. K5-8 BUS Delays

1. Study the following power up sequence
a. Power comes on ie, $+5 v$. is true
b. BUS DC LO L goes high dropping the direct clear on the PWRUP INIT one shot at $B-3$ causing it to fire. This generates several INIT signals which clear various registers throughout the $C P$ and also out on the Unibus
c. PWRUP INIT also fires off the JAMUPP one shot on K4-3. This forces a 377 into the UPP which, if you look at the ROM bit map, you will see reads all zeroes out of the ROM and these are clocked into the U REG and UPP.
d. The processor's clock is not started on K4-2 because PWRUPP INIT is still active ( 20 msec ). Therefore, so far what has been accomplished is:

The CP has been initialized
The Unibus has been initialized

The UPP and UREG have been zeroed out
e. Sometime during the 20 msec . BUS AC LO L went high. Therefore, when PWRUP INIT times out it will fire the 70 msec. POWER RESTART one shot at C, D-3.
f. When this times out it will set the JPUP flop a K4-3 initiating another JAM sequence. This time it will jam either 337 or 030 depending upon the HALT switch and will start the clock (remember PWRUP INIT is gone) and the CP is off and running again.
g. JPUP will fire off the DELAY POWER DOWN one shot on K5-8 which will prevent the powe down sequence from occuring for 3 nsec . This allows the programmer time to set up everything properly before he has to power down again. Further information can be found in the JAMUPP timing sequence in Appendix A and in Fig. 3-8 on page 3-11 of the KDllA Maintenance Manual.
2. Read and study the power down sequence on the last paragraph of page 3-6 and figure 3-9 on page 3-11 of the KDllA Processor Maintenance Manual
a. Answer True or False. On the power down sequence, BUS AC LO sets the LOWAC flop, generating CLK PWR ON on a P1 or P3 which jams a 337 into the UPP.
b. How much time does the program have to same the volatile information and to prepare itself for the power going off?

15 msec
7 msec
22 msec
2 msec
9 msec
D.

1. Analyze the RESET and RESET RESTART one shot.
a. During which microinstruction do they both get fired?
2. Note during this microinstruction that we have a CLKOFF. What signal will restart the clock?
a. K5-8 P ENDRESET L
b. K5-8 RESET RESTART L
c. K5-8 INIT * RESET H
3. How long will this be after the clock was stopped?
a. 70 msec
b. 20 msec
C. 90 msec

Match the symptom listed below with the component that would most likely cause the symptom. The problem could be on any of the seven prints studied in this unit. Check you answers with the correct answers in Appendix $B$.

1. You deposit 177777 into location 777776 , but when you examine the same location the data displayed is 000353.
2. You observe that every microinstruction which specifies a CL3 generates only a P3 and no P2. Microinstructions specifying CL2 operate properly.
3. Whenever a RESET instruction is executed, the clock stops and never gets restarted. The Unibus is not initialized.
4. When doing sequential examines or deposits, the contents of the BA never increments. Everything else works properly. (ie all Maindecs run)

## LIST OF POSSIBLE FAULTY COMPONENTS

a. E66 pin 02 failed high
b. E26 pin 09 failed high
C. E. 74 pin 11 failed high
d. E56 pin 09 failed low
e. E92 pin 08 failed low
f. E30 pin 08 failed high
g. E72 pin 11 failed high
h. E66 pin 01 failed high
i. E69 pin 06 failed high
j. E60 pin 06 failed low
 BY PWRUP INIT STILL BEING ACTIVE.
4. SINCE THE UREG CONTAINS ALL ZEROES WE HAVE FORCED THE MACHINE TO A KNOWN STATE - ALL CONTROL SIGNALS INACTIVE ILOCATION OOO IN THE ROM IS BEING READ OUT, but the subsequent jam sequence will alter the upp PRIOR TO CLOCKING THE UREG AGAIN)
5. AT TD THE TRAILING EDGE OF PWR RESTART SETS THE JPUP FLOP
6. JPUP TRIGGERS THE JAMUPP ONE SHOT AND FROM. TD TO TE WE JAM A NEW ADDRESS INTO THE UPP. [IF HALT; UPP $=30$ (CONO5)]
[.I. - - HALT; UPP $=337($ TRP17) ]
KD11-A JAMUPP Timing Sequence
APPENDIX ..... B
A.7
b
(6) $\mathrm{B}, \mathrm{Pl}$ or ..... P3
(c) GPR, Pl or P3
(ii4) IR, Pl or P3
(iv) BA, P1 or P2
(v) $\mathrm{D}, \mathrm{P} 2$
B. 2
f (c) PUPP ..... 002
(ii) UPP ..... 015
(iii) U REG - SERO1
c.2
a FALSEb
(ic) 7 msec
D.1
a On P3 of RSTOl on Flow Diagram page ..... 6
2
a K5-8 P ENDRESET L
3
a 70 msec
APPENDIX B
ANSWERS TO PROBLEMS
A

1

|  | P1 | P2 | P3 |  |
| :--- | :---: | :---: | :---: | ---: |
| CLKLO | 0,1 | 0, | 1 | 1 |
| CLKL1 | 0 | 1 | 1 |  |

$2 \quad \mathrm{P} 2$ when CLKLO (1) * CLKLI (1)
i.e. CL3
3 B SSYN H * IDLE (1) H * no clock pulse *
NO MCLK ENABLE H * MSYN (1) H
5
b Inhibits stopping the clock since we do
not want to do a bus cycle for these
situations.
6
a No
b Yes
7 a
(i) Pl
(ii) P2 on a CL2
(iii) P3
(2V) JAM CLKKD11A 120000
APPENDIX ..... B
ANSWERS TO SELF EVALUATION

1. E56 pin 09 failed low ..... (K5-2)
2. E66 pin 01 failed high ..... (K4-2)
3. E30 pin 08 failed high ..... (K5-8)
4. E74 pin 11 failed high ..... (K5-5)

## LEARNING ACTIVITY UNIT

EXTENDED INSTRUCTION SET OPTION ..... I
INTRO - INSTRUCTIONS - BLOCK DIAGRAM$1 / 21 / 74$

## RATIONALE

In the previous units you have accomplished the objectives of learning the operation and maintenance of the PDP 11/40. A thorough knowledge of the $11 / 40$ Block Diagram, you will find, will be a big advantage to you as you progress through these units concerning the Extended Instruction Set Option.

During this and the subsequent units of this group you will undertake the task of learning the KEllE. The degree to which we will address ourselves will be such that when completed, we can effectively and efficiently maintain the EIS option. This first unit will deal with introducing you to the option, learning and using the four (4) new instructions, and an overview of the Block Diagram.

This unit will provide a knowledge foundation so that you can see the 'big picture' as you go through the remaining units. An understanding of how this option fits into the overall system is probably the most important aspect of this unit.

```
11/40 - KE1lE - 160
```


## PREREQUISITES

Successful completion of all previous units to date.

## OBJECTIVES

Given six (6) questions concerning the Extended Instructions and the Block Diagram, you must be able to choose the most correct answer from those given or determine if the statement is true or false. To demonstrate successful completion you must answer five of the six correctly. Open book of course, however, a twenty minute time limit must be observed:

## PRETEST

To be filled in when a completely programmed environment is in progress.

## LEARNING ACTIVITIES

## I. LECTURE

Attend a short lecture where the instructor will introduce the Extended Instruction Option. He will discuss the whys and hows. He will also format for you and briefly discuss the four (4) new instructions and give you an overview of the Block Diagram of the KEllE. Take notes and jot down questions you have during the lecture so that you can ask them when the lecture has been completed.
II. PROJECTS/QUESTIONS
A. Answer the following questions with the aid of your KElle Block Diagram.

1. The DR register is part of which section of the EIS option?
2. Two (2) control signals feed the DR register because of the type register it is. What type is it?
3. The data route from the BP register to the CPU is via the $R D$ Mux and into the processor on the
$\qquad$ -
4. The Expansion BUT MUX is controlled by $\qquad$ -
5. What is the technique utilized to make 44 bits become 56 bits so that the expansion ROM can be used to control the processors operation?
6. What key signal controls which ROM is being used when this option is installed?
7. The counter can count up or down - True or False.

Refer to the Appendix to verify your answers to these questions concerning the EIS Block Diagram.
B. Complete the following instruction examples to reinforce your knowledge of their operation. When you have completed all of the examples, check your results with those given in the Appendix.

1. GIVEN: $500 /$ ASH (1), $3 \quad \mathrm{Rl}=5000$

R3 $=001234$
5000/1263

AFTER EXECUTION: R3 =
CBIT $=$
$\qquad$
cBIT
$\qquad$
2. GIVEN: $500 /$ ASHC $50(2) ; 0$

$$
\begin{aligned}
& \mathrm{R} 0=001267 \\
& \mathrm{R} 1=117200 \\
& \mathrm{R} 2=000430
\end{aligned}
$$

AFTER EXECUTION:
RO = $\qquad$ -
R1 $=$
CBIT $=$ $\qquad$
$\longrightarrow$
3. GIVEN: 500/MUL (1), 2
$R 1=003000$
$\mathrm{R} 2=000024$
$R 3=000032$
3000/000016
AFTER EXECUTION: R2 = $\qquad$ R3 = $\qquad$
4. GIVEN: 500/DIV (5), 0
$R 0=000000$
R1 $=000124$
$R 5=005000$
5000/000017
AFTER EXECUTION: RO =
R1 = $\qquad$

## III. ADDITIONAL READING

The Introduction, General Description, and Programming in the KEllE Instruction Set Options Manual should prove very useful. There are examples of the instructions and a good general description of the option. Be careful to only concern yourself with the EIS explanation at this time.

## WHAT'S NEXT

After completing this unit, you should understand how the option ties into the KDllA and the basic job it has to perform. You will need this knowledge as you progress to the subsequent units to discover how the KElle does its thing.

## SUPPLEMENTARY INFORMATION

Your instructor will assign additional practice problems if you feel the need for more exercise and examples.

## ASH

ASSEMBLER SYNTAX ASH $S$, $R$ WHERE R IS THE REGISTER TO BE SHIFTED MACHINE OR OCTAL 072RSS NOTE REVERSAL THE SHIFT COUNT IS TAKEN AS LOW ORDER 6 BITS OF SOURCE OPERAND WHERE BIT 5 DETERMINES DIRECTION AND 4-0 AMOUNT. TOTAL + 31, -32 .

BIT $5=1$


[^2]BIT $5=1$


31
16


BIT $5=0$


## MUL

ASSEMBLER SYNTAX MUL $S, R$ WHERE $R$ IS MULTIPLIED BY THE SOURCE MACHINE OR OCTAL O70RSS NOTE REVERSAL THE CONTENTS OF R AND THE SOURCE ARE MULTIPLIED TOGETHER AND STORE IN R AND Rvl.

MUL
MULIPLICAND - R 16 BITS
$x$ MULTIPLIER - - SS
PRODUCT -R AND RvI $\quad 32$ BITS

EX. 1

```
MOV #400, RI
MUL #lO, RI
                                    MULTIPLICAND (R)
MULTIPLIER (SS)
```

RESULT RI $=4000$

EX. 2
$\mathrm{Rl}=1000$


1000/MULTIPLIER


AFTER
HI PRODUCT
LO PRODUCT

## APPENDIX

## DIV

ASSEMBLER SYNTAX DIV S,R WHERE R AND Rvl GET DIVIDED BY SOME SOURCE MACHINE OR OCTAL 071RSS NOTE REVERSAL THE DOUBLE REGISTER R AND RvI GETS DIVIDED BY SOURCE ANSWER TO R AND REMAINDER TO Rvl.


EX. 1
CLR RO
MOV \#20001, Rl
DIV \#2, RO RWITH R1, DIVIDEND RESULT - QUOTIENT (RO) $=010000$

EX. 2

| $\mathrm{Rl}=1000$ |  | R2 | R3 |
| :---: | :---: | :---: | :---: |
|  | BEFORE | Hi Dividend | LO DIVIDEND |
| DIV (I), \%2 |  |  |  |
|  | AFTER | QUOTIENT | REMAINDER |
| DIVIDEND |  |  |  |

R1 (1000)
1000/DIVISOR


BASIC IDEA - INSERTS NEW ROM.

## APPENDIX

## ANSWERS TO PROJECTS/QUESTIONS

A. Relative to the Block Diagram

1. Data Paths
2. Shift Register
3. RD Bus
4. $\operatorname{EUBF}(3: 0)$
5. Encoding
6. EUPP 8 (1)
7. True
B. Relative to the Execution of the EIS Instructions 1. $0,0 \quad{ }^{15} 8$ Shifts Right of R3
8. $0,5336,0{ }^{16} 8$ Shifts Right of RO, R1
9. $R 2=0, R 3=430$
10. $\mathrm{RO}=5$ (Quotient), $\mathrm{Rl}=11$ (Remainder)

## LEARNING ACTIVITY UNIT

## EXTENDED INSTRUCTION SET OPTION III

## TO AND FROM AND SHIFT FLOW SUMMARY

$1 / 21 / 74$

## RATIONALE

The first two units of this section were concerned with getting to know the EIS. You discussed the instructions and the Block Diagram and then analyzed to some extent how the option could execute the instructions assigned.

This unit will provide you with the information and the capability of getting from the Processor Flows to the EIS Flows and then back again. In other words, the routes taken when cutting in and cutting out the option. This unit will also serve as an introduction to the EIS Flows and a summary of the Shift Flows will be made. A brief analysis of those "extra" control bits will also be made.

To effectively trouble shoot this option, there are some techniques that can be employed by merely knowing how to activate and deactivate this option; you will discuss these during this unit. The analysis of the Shift Flows will give you the proper foundation to effectively relate the multiply and divide to those Algorithms discussed.

$$
11 / 40-K E 11 E-180
$$

## PREREQUISITES

Successful completion to date of all previous units

## OBJECTIVES

At the end of this unit you will be asked to answer five (5) questions. To demonstrate successful completion of this unit, you will be required to correctly answer four of the five. You will be allowed to use your reference material, however, a 20 minute time limit will be in effect.

## PRETEST

To be filled in when a fully programmed environment is in progress.

## LEARNING ACTIVITIES

I. LECTURE

Attend a 30 minute lecture where the instructor will very briefly overview four aspects of the EIS pertinent to this unit. First, how to get to EIS; secondly, how to get from EIS back to CPU; thirdly, the expansion ROM Format (80:57), and finally, a summary of the Shift Micro Flows. He will attempt to, proceed as rapidly as possible, so jot down any questions you may have and ask them at the conclusion of the lecture.
II. PROJECTS/QUESTIONS
A. Analyze more throughly those steps taken to activate the EIS option, include:

1. Translating a ASH with and without option 2. The Clocking and Data qualifications for UPP8 3. The BUT EIS INSTR.

Summarizing: the activation of the EIS option is caused by Fetching and Translating an EIS instruction thereby clocking and setting UPP8.
B. Analyze more thoroughly those steps taken to deactivate the EIS option; include:

1. Translating a Floating Instruction with only EIS installed
2. The clocking and clearing of UPP8
3. The exit to Service

Summarizing: the deactivation of EIS is caused by clocking and clearing the UPP8 Flip Flop which a direct function of the EIS ROM.
C. Examine the Expansion ROM and tables on Sheet 2 of 2 in the EIS Engineering Drawings and on pages 4-15 -$4-17$ of the EIS Options Manual and demonstrate your understanding by answering the following questions:

1. A GPC of 3 does what job?
2. An Expansion BUT 7 checks for?
3. BIT 62 does what job?
4. The SRD Field is used to?
5. An Expansion BUT 17 asks what question?

When you have completed the above questions, turn to the Appendix to verify your answers.
D. Now turn to Flow Diagram I EIS Engineering Drawings.

1. Verify that Entry to EIS and any necessary Source calculations are made before a determination is made as to the exact EIS Instruction.
2. As you leave this page and go to the appropriate Flow, determine the contents of $B R, B, R(D E S T)$ for each of the four possible exits.
3. Note at coordinate B1 the path to FIS or back to CPU if required.
E. In the summary of the Shift flows, let us use the following instructions and we will pick up the action at the entry point Sheet 2 of EIS Flows.

500/ASH \%1, 0
500/ASHC \%0, 2
R0 $=000075$
$\mathrm{R} 1=000003$
$\mathrm{R} 2=100000$
$R 3=000005$

$$
11 / 40-\mathrm{KEllE}-180
$$

Summary for ASH:

1. ASH 0

Puts the shift count of 3 into the counter and checks to see if it is a left or right shift.
2. ASH 1

Puts number to be shifted (75) into the BR register and in our case decrements the counter by 1.
3. ASH 5

Checks to see if the count is zero. If the shift count had been one, it would be zero now and only one pass thru ASH 6 would be made. When count $=$ zero, it is inhibited from being decremented any more, otherwise, the count is decremented once more in this micro instruction.
4. ASH 6

The shifting takes place here. Note where it is accomplished and that it complies with your general knowledge of the ASH operation.
5. ASH $15 \& 21$

Takes care of status and routes you to SERVICE.

Summary for ASHC:

1. ASH 7

Puts the shift count in the counter, moves the low operand (R3) to $B R$ and checks if right or left shift.
2. ASH 8

Moves the low operand to $D R$ and puts the hi into $B R$ and increments the counter. (Shift is right). Operand position shown here and in the Flows.

| BR | DR |
| :---: | :---: |
| HI OPERAND | LOW OPERAND |

$$
11 / 40-K E 11 E-180
$$

3. ASH 10

Serves the same function as ASH 5 in the previous example. Relate if required.
4. ASH 11

Shifting taking place. Note where the operands are shifted. The low operand gets shifted _. and the hi operand gets shifted
$\qquad$ -
5. ASH 12

Moves the low answer from $D R$ to the $D$ reg in preparation for storing.
6. ASH 13

Stores the low answer in Rvl.
7. ASH 19

Or's the high and low answer together on the RD Bus to test for zeroness in preparation for setting the condition codes.
8. ASH 15 \& 21

Moves Expansion Processor Status Bits to Processor Status and Exit back to the CPU.
III. ADDITIONAL READING

Paragraph 4.7.3, p. 4-26-4-30 of the EIS Options Manual provide an extremely fine explanation and description of the work we covered so far in the EIS Flows; it would be to your advantage to read this.

WHAT'S NEXT
After completing this unit you have the necessary basis to go on to the Multiply and Divide Flow which will be handled in a similar manner; summarizing the flows. As you will see, the time spent on flow diagrams to date can and will be put to good use in the remaining EIS Flows.

If you feel you need more practice with the topics covered in this unit, arrange with your instructor for additional assignments or projects.

## APPENDIX

ANSWERS TO PROJECTS/QUESTIONS
II. C.

1. Routes DR 15 to carry in of ALU
2. Divide Quit (Divide Fault)
3. Enables to counter to count
4. Control the ..... RD MUX
5. Is this an EIS instruction
D. 2 .
a. ASH - shift count
b. ASHC - shift count
c. MUL - multiplier
d. DIV - divisor
E. 4.
a. in DR (EIS Option)
b. in Processor (D Mux facility)

## LEARNING ACTIVITY UNIT

## EXTENDED INSTRUCTION SET OPTION IV MULTIPLY FLOW SUMMARY

$1 / 21 / 74$

$$
\text { 1l/40 - KElle - } 190
$$

## RATIONALE

In the previous units, you have determined what is EIS, why EIS, and how it fits into the system. You have examined the Expansion Control Bits and analyzed the basic data manipulation capabilities of this option.

This unit will use those fundamental things we have observed to date to perform the Multiply Instruction. Let us keep in mind, as we proceed with this unit, that the important thing to learn will be what steps EIS takes to accomplish a successful multiply, not the proof of; if we take these steps, will the answer be correct. The difference, of course, is between learning the Algorithm (a recursive computational procedure) and proving that the Algorithm is in fact correct. Take my word for it, the Algorithm works. This unit, therefore, will deal with a Summary of the Multiply Flow Diagram.

The knowledge and ideas you obtain in this unit will enable you to effectively troubleshoot the Multiply Instruction, if necessary, and provide you a firm foundation from which you can analyze the next unit (the Divide Instruction).

$$
11 / 40-\mathrm{KEllE}-190
$$

## PREREQUISITES

Successful completion to date of all previous units.

## OBJECTIVES

There are five (5) simple questions relating to the operation of the Multiply Instruction at the conclusion of this unit; to demonstrate successful completion, you must correctly answer four of the five. Your notes, flows, and any other material may be used, however, a twenty (20) minute time limit will be in effect.

PRETEST
To be filled in when a fully programmed environment is in progress.

$$
11 / 40-\mathrm{KE} 11 \mathrm{E}-190
$$

## LEARNING ACTIVITIES

## I. LECTURE

Attend a short lecture where the instructor will review the ideas and concepts of how multiplication in the $11 / 40$ is accomplished. He will then give you a brief overview of the Multipy Flow Diagrams in the EIS Engineering Drawings. He will discuss some troubleshooting techniques similar to those concerning the ASH and ASHC. Pay close attention and question the instructor if you are having difficulty understanding the basic ideas.
II. PROJECTS/QUESTIONS

Let us go through and describe and summarize each microinstruction or group of microinstructions as they would relate to any multiply. We will not work with any particular instruction, but rather with the operands.


This is the condition as we enter Flow Diagram 3.
A. A summary of the Multiply microinstructions follows:

1. MUL 0

MUL 1 - Set up count, test multiplier for negative number, 2 's compliment multiplier in case it is the most negative number. 1000008 .
2. MUL 7

MUL 8- If multiplier is postive, move multiplicand to $D R$ and zero to $B R$.
3. MUL 2

MUL 3 - If multiplier is negative, move multiplicand to DR, test multiplier for most negative number.

$$
11 / 40-\mathrm{KEllE}-190
$$

4. MUL 19 - If multiplier is $\neq 100000$, then the operands are in position. Decrement count before going into loop (because PUPP $=$ UPP $=U P F$ ) and go to loop.
5. MUL 4

MUL 5 - If multiplier $=100000_{8}$, then make it the multiplicand by putting it in the $D R$ and zero the BR. Test the original multiplicand for a negative number.
6. MUL 6 - If the original multiplicand is positive, put it in the $B$ reg (it is now the multiplier) decrement the count and go to the Loop.
7. MUL 21

MUL 22
MUL 23 - If the original multiplicand is negative, test it for the most negative number. Prepare to generate the answer "special case."
8. MUL 24

MUL 25
MUL 26 - If the original multiplicand is also 100000 8, generate the answer, set CC's and store.
9. MUL 27 - If the original multiplicand $\neq$ the most negative number, clock it into the $B$ reg; it is now the multiplier. The original multiplier, now the multiplicand, is in DR with O's in BR (MUL 5). Decrement count and go to the Loop.
Now, before analyzing the Multiply Ioop, let us see if I can summarize the operation so that there is no doubt as to what has happened to this point.

There are six (6) possible combinations of the multiplier - multiplicand as I see it. Let us list them in a table to simplify things.

10. MUL 9 - The operands are shown on the Flow and in the Appendix. The SHIFT will be RIGHT and the TECHNIQUE is the STRING OF ONES.

The Loop: As you ENTER a string of ones, subtract the least significant power of two of the string from the partial product. As you LEAVE a string of ones, $A D D$ the most significant power-plus-one to the partial product. WITHIN a string of ones or zeroes, just shift the partial product right without adding or subtracting the multiplier. Whan count $=0$, pass through the Loop once more, then out.
11. MUL 10

MUL 20
MUL 11 - Store the hi product and test the low product for sign. Also test the hi product for future setting of the EPS (C) bit.
12. MUL 16

MUL 17
MUL 18 - Store the low product. If the low product is positive and the hi product $=0$, s , clear EPS (C) indicating single word precision. If low product is positive and the hi product $\neq 0$ 's, set EPS (C) indicating double word precision.

$$
11 / 40-K E 11 E-190
$$

```
13. MUL l2
        MUL 13
        MUL 14
        MUL 15 - Store the low product. If the low pro-
        duct is negative and the hi product = l's,
        clear EPS (C) indicating single word precision.
        If the low product is negative and the hi pro-
        duct }\not=1's, set EPS (C) indicating double word
        precision.
    Once the Multiply loop is left, these remaining
    micro instructions store the product. In ad-
    dition, so that the programmer can meaningfully
    us the condition codes, the microprogram goes thru
    some manipulations to determine the sign of the
    answer.
```

Now you move those condition codes to the Processor's Status Register and go to service.
B. Now that you know what it takes to accomplish the Execution of a Multiply Instruction, list some troubleshooting techniques that you would use having been given the following symptom: The Multiply doesn't work.
1.
2.
3.
4.

Check the Appendix to see how your ideas compare with those given.
III. ADDITIONAL READING

To further enhance your understanding of the Multiply operation, it is suggested that you read the Multiply write-up, pages 4-30-4-33 in the EIS Options Manual.

## WHAT'S NEXT

After completing this unit, you should have very little trouble with the next one. Basically, only the names will be changed as we tackle the Divide. All of the ideas,

# $11 / 40-K E 11 E-190$ <br> concepts, and techniques learned to date will be able to be put to use.in the next unit. 

## SUPPLEMENTARY INFORMATION

If you want more practice or you want to take a bit by bit example through to prove the Algorithm is correct, check with the instructor - there may be some simplified example already worked out.

$$
11 / 40-\text { KEllE - } 190
$$

APPENDIX
ANSWERS TO PROJECTS/QUESTIONS
B. Troubleshooting tips

1. Insure EIS activation
2. Operands $=100000$
3. Multiplier small positive
Multiplicand $=0$
4. Two small positive operands
-7-

## MULTIPLY LOOP KE1I-E

ALU CONTROL $f(D R O O$ \& EPS (C) )

| DRO0 | EPS (C) | ALUF |
| :---: | :---: | :--- |
| 0 | 0 | BR |
| 0 | 1 | BR PLUS B |
| 1 | 0 | BR MINUS B |
| 1 | 1 | BR |
|  |  |  |



# LEARNING ACTIVITY UNIT 

## EXTENDED INSTRUCTION SET OPTION V DIVIDE FLOW SUMMARY <br> $1 / 21 / 74$

## RATIONALE

The previous units of this EIS group dealt with the introduction to EIS and the Flow Diagrams of the ASH, ASHC and MUL. The reasons for EIS and the implementation of the option was discussed, also.

In this unit, you will want to gather all of your previous knowledge and skills so that you can effectively use then while analyzing the Divide Flow Diagram. Again in this unit an attempt will be made to understand an Algorithm; not prove its correctness. This time, of course, its the Divide. The main thrust of the unit will be directed toward a summary of the microprogram flows. Very similar to the way we tackled the multiply flow.

The information obtained during this and the other units to date will provide the necessary background to effectively analyze the Engineering Drawings which will be the next and the last unit in this section. You will realize that a thorough understanding of the flows is what is necessary to be effective in the maintenance of this option.

## PREREQUISITES

Successful completion to date of all previous units.

## OBJECTIVES

At the end of this unit, there will be five (5) simple questions relating to the operation of the Divide instruction; to demonstrate successful completion, you must correctly answer four of the five. As is the standard case, all notes, flows, reference manuals, etc. can be used, However, you will be limited to 20 minutes for completion.

## PRETEST

To be filled in when a fully programmed environment is in progress.

## LEARNING ACTIVITIES

I. LECTURE

Attend a short lecture where the instructor will review the method the $11 / 40$ uses to accomplish the Divide instruction. He will again identify the Divide operands and the limitations of the operation (Divide Quit Conditions). A brief overview of the Divide Flow Diagrams will be given and typical troubleshooting techniques discussed. Pay close attention during the lecture and question the instructor if you are having difficulty with the basic ideas.
II. PROJECTS/QUESTIONS

Let us go through the Divide Flow Diagrams summarizing micro instructions or groups of micro instructions. We will deal with the Divide in general terms and with the operands instead of some specific values or members. Keep in mind the technique here is left shift and subtract, subtract, subtract until you over subtract, then add the divisor back in. The first subtract must fail and the sign of the remainder follows the sign of the dividend.
(16 bits)
Quotient

A. Our entry is to DIV 0 top left of Flow Diagram 4. The operands are located:

Divisor - $B R$, $B$ R (DEJT)
HI Dividend - R
LO Dividend - RV 1
Now, let us summarize the flow

1. DIV 0

DIV 1
DIV 2
DIV 3 - Load count, get high order dividend test for the divisor $=0$.
2. DIV 4 - If the divisor $=0$, let local CC's go to MOVE EPS.
3. DIV 5

DIV 6 - If divisor $\neq 0$, load low dividend, test sign of high dividend, complement low dividend in case dividend is negative. The Algorithm requires a positive dividend.
4. DIV 7

DIV 8
DIV 9
DIV 10 - If the dividend is negative complement it and test for most negative \# (100000). Set local CC's just in case.
5. DIV ll - If dividend = most regative \#, quit.
6. DIV 13

DIV 14
DIV 15-If the dividend is positive, set up high and low dividends and divisor for lst (trial) division step
7. DIV 16

DIV 17
DIV 18 - lst division step is a trial subtract (it must fail); if the divisor goes into the high order dividend its overflow, therefore
8. DIV 12 - Set local CC's, go to move EPS
9. DIV 19

DIV 20 - If the trial subtract resulted in a carry out (successful), shift the dividend left and subtract the divisor again. Continue in this manner until either count $=0$ or the sign of the dividend changes (no carry out)
9. DIV 20 "Cont"Shift the dividend left and addthe divisor back in. Continuein this manner until count $=0$ ororiginal sign of dividend is re-stored.
10. DIV 21DIV 22 -When count $=0$, get ready tocorrect and store the remainderand test the last add/sub operation.
11. DIV 23DIV 24 -A positive divisor and last sub-tract operation resulted in a carryout (good); complement remainder incase original sign of dividend wasnegative. Test original sign ofdividend.
12. DIV 25 -If original sign of the dividend was positive, every thing is OK as is. Move the quotient into the D Reg and BR. Get ready to set condition codes and leave.
13. DIV 27DIV 28 -A positive divisor and the lastsubtract operation did not re-sult in a carry out (bad), addthe divisor back in to compen-sate for having over subtracted.Then store this corrected remainderand go to DIV 23.
14. DIV ..... 33DIV 34 -A negative diviscr and the lastaddition operation resulted ina carry out (good); complement theremainder in case original sign ofdividend was negative. Test originalsign of dividend.
15. DIV 35
DIV 36 -If the original sign of the dividend was negative, the quotient is OK but the remainder must be complemented. Go to DIV 25.
16 DIV 31DIV 32 -A negative divisor and thelast addition operation did notresult in a carry out (bad),subtract, the divisor from theremainder to compensate forhaving over added. Then store thecorrected remainder and go toDIV 33.
17. DIV ..... 37
DIV 38DIV 39 -The original sign of the dividendwas negative and now the quotientmust be complemented to compen-sate. Test the quotient formost negative \# (100000).
18. DIV 40
DIV 41DIV 42 -Set local condition codes. Ifquotient $=$ most negative \#, quit,otherwise:
19. DIV 26 -Store the quotient, set codes and go to service.
B. The Divide Quit expression describes the Fault monitering with the Boolean equation. Make a meaningful explanation of each member here and check your analysis with that in the appendix to see if you concur.

1. $\mathrm{D} \neq 0$ * DROO
2. Bl5 * EPS (N) * DR00
3. -Bl5 * -EPS (N)* DR00
C. If time permits at this point construct a simple divide instruction, and verify its operation and sequence through the flows.
III. ADDITIONAL READING

A very good description of the Divide operation exists in the reference manual, EIS option manualpages 4-33 thru 4-36. It certainly would be a benefit to you to read this especially if you desire more detailed information on the Divide. It is not very lengthy, and we recommend it.

## WHAT'S NEXT

After completing this unit, you have finished the EIS option with the exception of analyzing the Logic Diagrams. One more unit will be required to accomplish that and that is what follows. Your knowledge gained in the previous units will be extremely useful in the identification of the logic circuits, and you should be able to easily relate the circuits and key signals to the Block Diagram and the Flows.

SUPPLEMENTARY INFORMATION

If you want more practice or possibly some bit by bit examples, check with your instructor. There may be some lengthy examples already worked out that you could analyze.

APPENDIX

DIVIDE CAPSULE SUMMARY

XXX/DIV (1), R(SF) ${ }^{\leftarrow}$ must be even
$\zeta R 1=A \quad A / D i v i s o r$

R (SF)
HI DIVIDEND
QUOTIENT
REMAINDER

1. Get Divisor (load $S C=178$ )

- $\longleftarrow$ 2. Test Divisor for all zeroes

3. Get Dividend, test for negative
< 4. If the Dividend negative, test for most negative
<-5. Is Dividend $=$ to 0
4. Make Dividend positive prior to coop
< 7. Test if quotient will be $>16$ bits
○. Divide Loop count $=0$
5. Correct answers,
6. Store Answers
<11. Complement $=100000$
7. Store Flags
8. Exit

APPENDIX
ANSWERS TO PROJECTS/QUESTIONS
B 1. $\mathrm{D}=0$ * DR00
This takes care of a situation where you attempta divide of a large positive number into arelatively small negative number. And a largenegative number into a small positive number.It is conceivable that maintaining the propersign could be impossible. Divide quit.
9. Bl5 * EPS (N) *DR00
This makes sure that a positive divided by apositive yields a positive, if not, Divide Quit
10. -B15 * -EPS ..... (N) * DR00
This makes sure that a negative divided bya negative yields a positive, if not, DivideQuit.

## LEARNING ACTIVITY UNIT

EXTENDED INSTRUCTION SET OPTION ..... VI
LOGIC OVERVIEW
1/21/74

$$
11 / 40-\mathrm{KE} 11 \mathrm{E}-210
$$

## RATIONALE

All of the previous units you learned in this set had to do mainly with the Block Diagram and the Flow Diagrams of EIS. Most of the understanding and knowledge was obtained with those facilities. As you may remember from the KDll-A, the logic diagrams just show how the Block and Flows are implemented.

In this unit, we will investigate the EIS Logic Diagrams. As you will very rapidly see, there is not much to them. Our analysis will focus upon the location and identification of the key signals and important circuits. Some of the Flow and Block Diagram techniques will now become more apparent to you when you analyze these diagrams.

This is the last unit in the PDP $11 / 40$ section of this course. Knowing the $11 / 40$, as you will find, will be a tremendous asset in your quest to master the ll/45, which is next. Some areas of the processor will require only the names to be changed, other areas will be changed however slightly. In all cases, you will be able to apply those ideas and concepts you have learned to date to good advantage as you progress through the course.

Good Luck.

$$
11 / 40-K E 11 E-210
$$

## PREREQUISITES

Successful completion to date of all previous units.

## OBJECTIVES

Five (5) simple questions concerning the EIS Logic will be given at the end of this unit. To successfully complete this unit, you will be required to answer four of the five correctly. You can use any notes or reference material but must complete within a twenty (20) minute time limit. PRETEST

To be filled in when a fully programmed environment in progress.

## LEARNING ACTIVITIES

## I. LECTURE

Attend a short lecture where the instructor will give you a brief overview of the EIS Logic Diagrams. He will stress the major signals and key circuits. Pay close attention and jot down questions that you have so that you can ask them when the lecture has been completed.
II. PROJECTS/QUESTIONS
A. KE-2 Print. This print has the $B R$ and $D R$ registers on it which are the major items in the Data Paths portion of the EIS, analyze, identify, or verify the following:

1. $B R$ input
2. DR input
3. Data Shift input to DROO
4. Data Shift input to DR15
5. DR's truth table

Check your findings with those in the Appendix.
B. KE-3 Print. This Print contains the RD Mux. The path (DATA) between the EIS option and the processor's RD Bus. Analyze and verify the following:

1. Signal to allow RDMUX to RDBUS.
2. Information through the RDMUX on
(a) A input
(b) B input
(c) $C$ input
(d) D input

Check your answers with those in the Appendix.

$$
11 / 40-K E 11 E-210
$$

C. KE-4 Print. Expansion BUT MUX, EUBC4-1 are able to be activated under various conditions. Identify when multiplexer chips are active and verify the Divide Quit conditions.

1. E20
2. El4
3. E24
4. E37

Check your answers with those in the Appendix.
D. KE-5 Print. Control page implements EIS activation/ deactivation by controlling UPP8. Also on this page, counter control and ALU control.

1. Note the three possible ALU control function by analyzing the table in the upper right corner of this print.
2. E26 pin 3 at coordinate B3 goes to data input of UPP8 - state the boolean translation.
3. E46 pin 6 coordinate C 6 , provides the clocking to UPP8 - state the boolean expression for this.
4. Analyze the gates that provide for the loading and clocking of the counter at coordinates C7 and $B 7$ and give boolean expression.
5. Note the circuit across the bottom of the sheetprovides for Expansion NPR clocking give analysis.

Check your answers with those given in the Appendix.
E. KE-6 Print. Expansion Processor Status Flops and the counter. Analyze the two (2) Status Multiplexers truth tables at the top of this page and verify their selections. Analyze the counter and answer the following questions.

1. Counter inputs
2. Determines direction
3. Counter counts up when
4. A monitering circuit (E57 pin $12, \mathrm{~B} 5$ ) is provided to inhibit any more counting when count = $\qquad$ -

Check the Appendix to verify your answers.
F. KE-7, 8, 9 Prints. The Expansion ROM, first the 24 extra bits on KE7 then the remaining 44 bits that get encoded to 56 for expanded controliing of the processor on $\mathrm{KE}-7$ \& 8. Analyze these three prints and answer the following questions.

1. The clock for Expansion $U$ Word Register
2. Expansion ROM Bit 39 becomes as it goes to the CPU.
3. When EIS is activated what are bits $14,17,18$ a function of?

Check the Appendix to verify your answers.
G. KE-10 - 17 Print. Expansion ROM Listing. The listing and the end of the Logic Diagrams is of course, very similar to the ROM listing in the CPU. I would like to point out the differences and have you note them.

1. To get address 000 (all 80 bits) on one page, they had to split up the listing.
(a) CPU top half of each page
(b) EIS ( 24 bits) the bottom half of page

## 2. All addresses, to be correct, must have 400 added to them.

III. ADDITIONAL READING

A complete detailed logic description exists in the EIS options manual starting on page 4-48 and continues through 4-57. It would be to your advantage to read this to reinforce those learning activities experienced during this unit.

## WHAT'S NEXT

After completing this unit, other than some lab projects, you have completed the $11 / 40$ portion of the 11 Processor course. The next processor you tackle will be the $11 / 45$. The units you have covered to date concerning the $11 / 05$ and the $11 / 40$ will become your foundation as you go on. All of the concepts and ideas you have will be put to good use in the future. Good Luck as you continue on.

## SUPPLEMENTARY INFORMATION

The areas we did not specifically look at in the options manual contain some very good information. This information will be useful to you should you desire more knowledge about the EIS.

APPENDIX

## ANSWERS TO PROJECTS/QUESTIONS

A. KE-2 Print

1. DMUX
2. $B R$ REG
3. (a) 0 when doing a ASHC
(b) COUTI5 when doing a DIV
4. (a) when not MUL, BROO
(b) when MUL, ALUOO
5. (a) 00 - no op
(b) Ol - right shift
(c) 10-left shift
(d) 11 - load
B. KE-3 Print
6. STRDM(1), Strobe the RD MUX
7. (a) 00 - EIS Status
(b) $01-D R(15: 00)$
(c) $10-\operatorname{BR}(14: 01), \operatorname{DR} 15$
(d) $11-B R$ (15:00)
C. KE-4 Print
8. Expansion BUT 14-17, for Bits 3 \& 4
9. Expansion BUT 10-17, for Bit 2
10. Expansion BUT 10-17, for Bit 1
11. Expansion BUT $0-7$, for Bit 1

$$
11 / 40-K E 11 E-210
$$

## APPENDIX

ANSWERS TO PROJECTS/QUESTIONS (CONT'D)
D. KE-5 Print

1. (a) $f=A$
(b) $\mathrm{f}=\mathrm{A}$ plus B
(c) $f=A$ minus $B$ minus 1
2. Reserved instruction * UPP8 clear
3. (a) Part $P$ end * BUT 37 (activating EIS)
(b) Expansion clock * CLK UPP8 (ROM Bit) (deactivating EIS)
4. (a) P2 * LCNT (ROM Bit) to load counter
(b) PEND * count $\neq 0$ * ECNT (ROM Bit) to count counter.
5. PEND * BUT 10
E. KE-6 Print
6. $B R$ Register
7. BRO5
8. $\operatorname{BRO5}=1$, shift direction right
9. 0
F. KE-7, 8, 9 Print
10. CLK EU (88:57)
11. 40 and 39
12. B EUPP8 (is EIS activated)


## LEARNING ACITVITY UNIT

Title: Unibus Interfacing; M1 $\varnothing 5$ and M 7821
Date: $\varnothing 1 / 23 / 74$

## Rationale

In the previous units you have leanred the functions and operations of the 11 processors. You learned the operations of the memories, both 8 K and l6K and memory management. Now you have a solid background in the 11 processors.

Of course, the processors can't function very well without inp input/output devices - the peripherals.

In this unit you will learn how the peripherals are interfaced on to the Unibus. To do this, you will be going over the operations of the M1 $\varnothing 5$ address select module and the MF821 interrupt control. These are standard interface modules. You will learn the function and operations of these two modules. You will also learn how to isolate malfunctions in this area.

The knowledge and skills that you acquire in this unit will prove invaluable to you in isolating Unibus interfacing problems dealing with the M1 $\varnothing 5$ and M7821.

## Prerequisites

Before entering this unit, you must have demonstrated successful completion to this point.

## Objectives

Given a list of four failure systems, you must determine the signal most likely to cause that system. To demonstrate successful completion you must answer, three out of the four correctly. You will be allowed to use all available references, but must complete the test in $2 \varnothing$ minutes.

## LEARNING ACTIVITIES

## I. Lecture

Attend the lecture on Unibus Interfacing where the Instructor will give an overview on Unibus interfacing modules, M1ø5 and MF821. Pay close attention and take careful notes to highlight key points. Take down any questions you may have and ask them after the lecture.
II. Projects/Questions
A. Mlø5 address Selector. Refer to the KLll-A Teletype control Eng. Drawings, C-CS-M1ø5- $\varnothing$-1.

1. Analyze the inputs along the bottom of the M1め5 print. Note the decoding of lines A(12:ø3) is determined by jumpers. When a given line contains a jumper, the address selector looks for a zero on that line. If there is no jumper, the address selector looks for one.
2. What jumpers would be installed if this M1ø5 were the address selector for the TTY?
3. Line $A \varnothing \varnothing$ is used for byte control.
4. Line Aø1 and Aø2 are decoded to select one of the four addressable device registers.
a. If input lines A ( $\varnothing 2: \varnothing 1$ ) are $\varnothing 1$ what select line is asserted?
b. If $A(02: 01)=11$, what select line is asserted?
5. Inputs $A \varnothing \varnothing$ and $B U S C 1$ and BUS $C \varnothing$ are used to bring up the gating signals. Analyze the logic.
a. If $C(1: \varnothing)=\varnothing \varnothing$, and $A \varnothing \varnothing=\varnothing$ what gating control signal comes true?
b. If $C(2: \varnothing)=1 \varnothing$, and $A \varnothing \varnothing=1$, what gating signals come up?
6. These gating signals along with the Select signals generate the functions dealing with the device registers.
a. If you were doing DATO to the address of the TKS (77756ø). You would bring up Select $\varnothing$ and out low and out high. This would load the TKS with the data.
b. What signals would be up for a DATOB at Address 777566 (TPB)?
7. Analyze the SSYN logic. Note that SSYN is returned to the master $1 \varnothing \varnothing$ ns ec. after the Select line becomes true.
B. M7821 Interrupt Control Logic. Refer to Drawing D-CS-M7821- $\varnothing-1$, sheet 2 of 2 in the KLllA teletype control Eng. Drawings.
8. Analyze the logic on this print. This logic has the facilities to make bus requests and to become bus master.
9. Note that the module contains two independent request and grant circuits ( $A$ and $B$ )
10. Locate the signal BUS A BRL at co-ordinate 5D. What signals are used to enable the request?
11. When the master device (Arbitration logic) recognizes the request and issues a $B G$, it is input at co-ord 8D. Note how the Grant is proagated through if this is not the requesting device.
12. Analyze the SACK logic. Note how SACK is asserted when a grant is received.
13. Analyze the BBSY logic. Notice how the BBSY F/F clocking input is controlled by BUS BBSYL. When the BBSY F/F sets it enables the vector address on the bus and also the BUS INTR signal.
14. Note the vector address logic in the lower right of the print. You can assign the vector address generated by the uses of jumpers. Install for a 1 , remove for a $\varnothing$.
15. Notice the jumper at co-ord 3D. This jumper should only be installed if the system is experiencing NPR latency problems.
16. Analyze the logic and answer the following questions:
a. What jumpers would be installed to generate vector address $6 \varnothing$ ?
b. What state does the BBSY F/F have to be to generate the vector address?
C. Does the GRANT F/F set or clear to propagate the $B G$ to the next device if this logic is not the requesting device?
d. What signal clocks the BBSY F/F?
17. Check your answers in this unit with the correct answers in the appendix. If you don't understand why you got any questions wrong, consult your instructor. If you feel confident with the material ask your instructor for the POST TEST.

## III Additional Reading

You will find supplementary information regarding this unit in the Peripherals handbook, Chapter 6.

## What's Next

Now that you are familar with the basic Unibus interface modules and their concepts of operation; you are ready to investigate the same concepts in an actually interface device, the DLII-A for the TTY. The concepts you learned in this unit will provide the foundation for the next unit.

## Supplementary Information

If you feel you need more practice, or a better understanding of the M1ø5 or the M7821, ask your instructor. He will assist you.
APPENDIX
ANSWERS TO PROJECTS/QUESTIONS
II. A 2 Jumper bit $F$ and
4a Select ..... 2
b Select 6
5a IN H
b Out low, out high
6b Select 6
Out Low
B 3 A Request 1H
A Request ..... 2 H
9a Jumper 4 and 5
b Set
c Set
d BUS BBSY L going High

# LEARNING ACTIVITY UNIT 

DLIIA THEORY OF OPERATION
1/24/74

## PREREQUISITES

Before entering this unit you must have successfully completed the previous units.

## OBJECTIVES

Given five statements describing a signal or function of the DLIIA, you must be able to match the statement with the answer (signal, register etc) that it best describes. To demonstrate successful completion, you must match four of the five statements correctly. You will be allowed to use all available references, but must complete the test in 20 minutes.

## I. LECTURE

Attend the short lecture where the instructor will give you an introduction to the theory of operation of the DLIlA asynchronous line interface. Pay close attention and take careful notes to emphasize key points. Write down any questions you may have and ask they at the end of the lecture.
II. PROJECTS/QUESTIONS
A. DLllA Teletype Control Block Diagram (Refer to fig. 2-3, page 2-8, in DLll Asynchronous Line Interface Manual)

1. Locate the address selection logic block.

What are the inputs to this block?
$\qquad$
$\qquad$
$\qquad$
2. What register can be selected by this block?
$\qquad$
$\qquad$
$\qquad$
$\qquad$
3. This block's function is similar to what modules that you covered in the previous unit?
4. Locate the interrupt control logic block. What are the Unibus inputs and outputs of this block?
$\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$
5. This block's function is similar to what module covered in the previous unit?
6. Locate the receiver Status Register and the Receiver Buffer blocks. These blocks would be used when the processor is (sending, receiving) information from the TTY.
7. What format is the data sent to the Receiver Buffer from the TTY?
8. This is converted to data for transmission to the Unibus.
9. Locate the transmitter status register and the transmitter buffer. These blocks control the transfer of $\qquad$ (parallel, serial) Bus Data to (parallel, serial) data for transmission to the TTY.
B. Address Selection - Simplified Diagram (Refer to fig. 5-1, page 5-5 in the DLll Manual)

1. Analyze the simplified diagram for the address selection logic.

Notice that this logic function is similar to the M105 logic operation.
2. The address selection output signals are used to select one of the four registers and determine whether data is to be gated into or out of master device. Refer to table 5-3, page 5-6 in the DLIIA Manual for a list of these signals.
3. What function is selected when the processor does a DATI on the RCSR address (777560)?
4. What function is selected when the processor does a DATO to the XBUF address (777566)?
5. What function is selected when the processor does a DATOB to the high byte of the XBUF?
C. Interrupt Control - Simplified Diagram.

1. Analyze the simplified diagram for the Interrupt control, refer to fig. 5-3, page 5-8 in the DLll Manual.
2. The interrupt control logic permits the DLllA to gain control of the bus and perform an interrupt operation. The Vector Address for the DLIlA is 060 and 064. The BR level is 4.
3. What signals are used to enable a transmitter interrupt?
4. What signals are used to enable a Receiver Interrupt?
$\qquad$
$\qquad$
5. Once the interrupt sequence is started, it is the same as in the M7821 module.
D. Device Register Functions
(Refer to table 5-5, page 5-11 in the DIll Manual)
6. What register holds the data received from the processor for transfer to the TTY?
7. What register holds the data received from the TTY for transfer to the processor?
8. What register provides information on the status of the receiver logic?
E. Device Register Bit Assignments
9. Receiver Status Register (RCSR)
(Refer to fig. 4-1, page 4-2 in DLll Manual)
NOTE:
Bits 15-12, 10-8, 5-1 are not used in the DLllA
10. Receiver Buffer Register (RBUF) (Refer to fig. 4-2, page 4-4 in DLll Manual)

NOTE:
Bits 15-8 are not used in the DLIlA
3. Transmitter Status Register (XCSR) (Refer to fig. 4-3, page 4-6 in DLll Manual)

NOTE:
Bits 15-8, 5-3, and 1-0 are not used in DLllA

## 4. Transmitter Buffer Register (XBUF)

 (Refer to fig. 4-4, page $4-6$ in DLll Manual)NOTE:
Bits 15-8 are not used
F. Universal Asynchronous Receiver/Transmitter (UART)

1. The UART is a full duplex receiver/transmitter. The receiver section accepts serial binary characters and converts them to a parallel format for transmission to the Unibus. The transmitter section accepts parallel binary character from the bus and converts them to a serial output with starts and stop bits added.
2. The data format for the DLllA consists of a START bit, eight DATA bits, and two STOP bits. (Refer to fig. 2-1, page 2-4 in the DLll Manual) Parity is not used in the DLIlA. Refer to table $2-3$, page $2-5$ in DLll Manual
3. Complete the table below for jumpering the DLIlA for a START bit, 8 DATA bits, 2 STOP bits, and no parity. Indicate IN or OUT.

G. UART Receiver - Block Diagram
(Refer to fig. 5-5, page 5-23 in DLll Manual)
4. Read paragraph 5. 7. l on Receiver operation and analyze the block diagram
5. Note that on the DLllA, the overrun, parity, and frame error are not used.
6. How: does the UART Receiver know when the entire data character has been shifted into the register?
7. After the character is in the shift register it is then transferred in (parallel, serial) form to the holding register and the flag set.
H. UART Transmitter - Block Diagram

Refer to fig. 5-6, page 5-24 in DLll Manual

1. Read paragraph 5.7.2 on Transmitter operation in DLll manual and analyze the block diagram.
2. What signal loads the parallel data bits in to the data buffer?
3. What block determines the format of the serial data?
4. What signal prevents the timing generator from loading another character into the shift register while the present character is being shifted into the TTY?
5. What flip flop indicates when the transmitter is ready for a character?
I. Clock Logic fig. 5-7, page 5-26 in DLll Manual
6. Analyze the frequency divider logic simplified diagram.

NOTE:
The DLllA uses an 8.44 .8 KH crystal oscillator, so turn to page 2-3 and substitute the correct baud rates for this crystal and the appropriate switch positions in the fig. 5-7. The standard baud rate for the teletype is 110 for both receiver and transmitter so the correct switch position is no. 3.
2. The frequency selected by the transmitter switch is signal which is used to generate the transmitter clock input.
3. The frequency selected by the receiver switch is clock input.
4. For a detailed description of the clock logic, read paragraph 5.8 , page $5-25$ in the DLll Manual.
5. Check your answers in this unit with the correct answers in the appendix. If you do not understand why you got any questions wrong, consult your instructor. If you feel confident with the material, ask your instructor for the POST TEST.
III. ADDITIONAL READING

You will find supplementary information regarding this unit in the DLll Asynchronous line interface manual.

## WHAT'S NEXT

Now that you have the theory of operation of the DKIIA under your belt, you are ready to investigate the detailed logic prints. The theory you learned in this unit will provide the background for detailed analysis of the DLllA logic.

## SUPPLEMENTARY INFORMATION

If you feel you need more practice, or a better understanding of the material covered in this unit, see your instructor. He will help you to enhance your understanding of the material.

## APPENDIX

## ANSWERS

```
II A l A A 17:00\rangle,C〈1:0\rangle, MSYN
```

Receiver Status Register

```Receiver Buffer RegisterTransmitter Status RegisterTransmitter Buffer Register
M105
BBSY, SSYN, SACK, BR, BG, INTR
M7821
Receiving
Serial
Parallel
Parallel, Serial
Receiver status to the bus
Bus Data to transmitter buffer
No function, must be a DATOB to low byte only
XMIT INT ENB (1) H XMIT DONE H
RCVR INT ENB (1) H RCVR DONE H
XBUF
RBUF
RCSR
```

| NP | EPS | 2SB | J9 | J11 | J10 | NB1 | NB2 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| OUT | *(IN <br> OR OUT1 | OUT | OUT | OUT | IN | OUT | OUT |

[^3]
## APPENDIX

## ANSWERS

G. 3. Occurance for a STOP bit
4. Parallel, Data available
H. 2. DATA STROBE
3. Control Logic block
4. END OF CHARACTER
5. TBMT F/F
I. 2. XMIT CLK H
3. RCVR CLK H
LEARNING ACTIVITY UNITDLII-A LOGIC PRINTSø1/25/74

## RATIONALE

In the previous unit you learned the theory of operation of the DLIl-A asynchronous line interface. You saw how the interface handled data conversion from parallel to serial and from serial to parallel for input to and output from the Teletype.

In this unit you will learn how the logic was designed and set-up to implement the operation. You will learn the names and locations of key signals into and out of these logic areas. You will also learn how to isolate problems in these areas.

The knowledge and skills that you acquire in this unit will prove invaluable in isolating and solving problems in the DLll-A and related interfaces.

## 11/40-DLll-A-25ø

## PREREQUISITES

Before entering this unit you must have demonstrated successful completion to this point.

OBJECTIVES
Given a list of four failure symptoms, you must be able to determine the correct malfunction that would cause the symptom. To demonstrate successful completion of this unit you must get three of the four questions correct.

## LEARNING ACTIVITIES

I. LECTURE

Attend the $2 \emptyset$ minute lecture where the instructor will give an overview of the DLll-A prints. Pay close attention and take careful notes to highlight the key signals in the logic. Take down any questions you have and ask them after the lecture.
II. PROJECT/QUESTIONS
A. DL-2 Print

1. Analyze the Base Data Receivers at co-ord FCD. These gates gate the bus data D 7: $\varnothing \varnothing$ into the DLll. Note that there is no gating signal.
2. Analyze the Bus Drivers at co-ord 5CD. These gates gate the contents of the Read Buffer to the Bus. What is the gating signal that performs this function?
3. Analyze the Bus Drivers at co-ord 3CD. These gates applied the Transmitter Status Register to the Bus. What is the gating signal that performs this function?
4. Analyze the Bus Drivers at co-ord 2CD and 2B. These gates applied the Receiver Status Register to the Bus. What is the gating signal to do this?
5. Analyze the logic at co-ord 5-6B. This logic is used to gate the Receiver Buffer to the bus. However, in the DLll-A jumper J8 is out, so this logic is disabled.
6. Also, note jumper JF at co-ord 4C. This jumper is out for the DLll-A.
B. DL-3 Prints
7. Analyze the crystal oscillator logic at co-ord 7C. In the DLll-A the crystal is 844.8 KHz . Note that the output of the crystal Yl is applied to four IC chips that function as frequency dividers to provide the eight different frequencies fed to the rotary switch.
8. Refer to Fig. 5-7 in the DLll manual, page 5-26 for the simplified diagram of the frequency dividers.
9. The DLll-A function with the rotary switch in Position 3 for both XMIT CLK and RCVR CLK. This gives you a band rate of
10. Note the signal BERG SERIAL IN L at co-ord 8B. This is the serial input from the TTY.
11. Note the signal SERIAL OUT H at co-ord 8A. This is applied to a circuit (2-3B) that converts the line to a bipolar level required by the TTY. This sends the serial data to the TTY.
12. Note the priority plug at co-ord 2D. This plug assigns the BR4 level to the interrupt logic.
C. DL-4 Print
13. Locate chip E44 co-ord 8B. This is a four bit shift register that checks for a legal start pulse during receiver operation. A legal start pulse would be low and that low shifted in at one-half the 567 user rate, until all the register bits are $\varnothing$ 's then the RCVR ACT F/F (co-ord 7c) sets.
14. Analyze the UART at co-ord 5C: Note the serial in, pin $2 \emptyset$, this is the serial data input.
15. What are the inputs to the XBUF?
16. What are the output of the RBUF?
17. Locate chip E62, co-ord 3C. This is the RDONE bit.
D. $\mathrm{DL}-5$
18. The logic on this print functions similar to the M105 logic.
19. What jumpers would be installed to assign address 77756ø thru 777566?
20. What signal is used to load bus data into the XBUF?

## E. DL-6 Prints

1. The logic on this print is the interrupt logic. It's function is similar to the M7821.
2. Note that the vector addresses are jumpered for A "1".
3. Check your answers in this unit with the correct answers in the appendix. If you have any questions, consult your instructor. If you feel confident with the material take the POST TEST.
III. ADDITIONAL READING

You will find supplementary information regarding this unit in the DLll-A manual.

## WHAT'S NEXT

Now you should have a good background in the DLll-A interface. The concepts you learned in this unit will prove invaluable in isolating interface malfunctions. In the next unit you will be covering the KWll Real-Time clock.

## SUPPLEMENTARY INFORMATION

If you feel you need more help on anything covered in this unit, consult your instructor.
APPENDIX
Answers to Project/Questions
II.
A. 2. RBUF to BUS H
3. XCSR to BUS H 4. RCSR to BUS HB. 3. 11ø
C. 3. BD 7:ø
4. RD ..... $7: \varnothing$
D. 2. A3, A73. BUS to XBUF H

## Gegita

DIGITAL EQUIPMENT CORPORATION, Maynard. Massachusetts, Telephone: (617) 897-5111 - ARIZONA, Phoenix • CALIFORNIA, Sunnyvale. Santa Ana. Los Angeles. San Diego and San Francisco (Mountain View) - COLORADO, Engelwood •CONNECTICUT. Meriden - DISTRICT OF COLUMBIA. Washington (Riverdale. Md.) • FLORIDA. Orlando • GEORGIA. Atlanta • ILLINOIS, Northbrook - INDIANA, Indianapolis - LOUISIANA, Metairie • MARYLAND. Riverdale - MASSACHUSETTS, Cambridge and Waltham • MICHIGAN, Ann Arbor and Detroit (Southfield) - MINNESOTA. Minneapolis • MISSOURI. Kansas City and Maryland Heights • NEW JERSEY, Fairfield. Metuchen and Princeton - NEW MEXICO, Albuquerque - NEW YORK, Huntington Station. Manhattan. New York. Syracuse and Rochester - NORTH CAROLINA, Durham/Chapel Hill - OHIO. Cleveland. Dayton and Euclid • OKLAHOMA, Tulsa • OREGON, Portland - PENNSYLVANIA, Bluebell, Paoli and Pittsburgh - TENNESSEE, Knoxville - TEXAS, Dallas and Houston • UTAH, Salt Lake City • WASHINGTON, Bellevue • WISCONSIN, Milwaukee • ARGENTINA, Buenos Aires • AUSTRALIA, Adelaide, Brisbane. Crows Nest. Melbourne. Norwood. Perth and Sydney - AUSTRIA. Vienna - BELGIUM, Brussels - BRAZIL, Rio de Janeiro. Sao Paulo and Porto Alegre - CANADA. Alberta. Vancouver. British Columbia; Hamilton. Mississauga and Ottawa. Ontario; and Quebec - CHILE, Santiago - DENMARK. Copenhagen and Hellerup - FINLAND. Helsinki - FRANCE, Grenoble and Rungis • GERMANY. Cologne. Hannover. Frankfurt. Munich and Stuttgart • INDIA. Bombay • ISRAEL. Tel Aviv • ITALY, Milano • JAPAN. Osaka and Tokyo - MEXICO. Mexico City - NETHERLANDS. The Hague • NEW ZEALAND. Auckland • NORWAY, Oslo • PHILIPPINES, Manila - PUERTO RICO. Miramar and Santurce - REPUBLIC OF CHINA, Taiwan - SCOTLAND, West Lothian • SPAIN, Barcelona and Madrid • SWEDEN. Solna and Stockholm • SWITZERLAND. Geneva and Zurich • UNITED KINGDOM, Birmingham, Bristol, Edinburgh, London. Manchester, Reading and Warwickshire • VENEZUELA, Caracas


[^0]:    *Pre-wired processor options-not included as part of the basic processor.

[^1]:    A complete table of "DAD" and "SPS" is found about the 6th page of the PDPIl/40 System Engineering Drawings.

[^2]:    ASSEMBLER SYNTAX ASHC $S, R$ WHERE $R \& R V I$ ARE THE REGS TO BE SHIFTED MACHINE OR OCTAL 073RSS NOTE REVERSAL
    THE SHIFT COUNT IS SAME AS ABOVE, HOWEVER; TWO REGISTERS ARE AFFECTED

[^3]:    * DOES NOT MATTER SINCE NP IS OUT

