# **Build a Microcomputer** Chapter II Microprogrammed Design Advanced Micro Devices Copyright © 1978 by Advanced Micro Devices, Inc. Advanced Micro Devices cannot assume responsibility for use of any circuitry described other than circuitry entirely embodied in an Advanced Micro Devices' product. ### CHAPTER II MICROPROGRAMMED DESIGN INTRODUCTION A microprogrammed machine is one in which a coherent sequence of microinstructions is used to execute various commands required by the machine. If the machine is a computer, each sequence of microinstructions can be made to execute a machine instruction. All of the little elemental tasks performed by the machine in executing the machine instruction are called microinstructions. The storage area for these microinstructions is usually called the microprogram memory. This technique was identified by Wilkes in the 1950's as a structured approach to the random control logic in a computer. A microinstruction usually has two primary parts. These are: (1) the definition and control of all elemental micro-operations to be carried out and (2) the definition and control of the address of the next microinstruction to be executed. The definition of the various micro-operations to be carried out usually includes such things as ALU source operand selection, ALU function, ALU destination, carry control, shift control, interrupt control, data-in and data-out control and so forth. The definition of the next microinstruction function usually includes identifying the source selection of the next microinstruction address, and in some cases, supplying the actual value of that microinstruction address. Microprogrammed machines are usually distinguished from non-microprogrammed machines in the following manner. Older, non-microprogrammed machines implemented the control function by using combinations of gates and flip-flops connected in a somewhat random fashion in order to generate the required timing and control signals for the machine. Microprogrammed machines, on the other hand, are normally considered highly ordered and more organized with regard to the control function field. In its simplest definition, a microprogram control unit consists of the microprogram memory and the structure required to determine the address of the next microinstruction. Microprogramming is normally selected by the design engineer as a control technique for finite state machines because it improves flexibility, performance, and LSI utilization. Several additional key features of microprogrammed designs are listed below: - More structured organization - · Diagnostics can be implemented easily - · Design changes are simple - Field updates are easy - Adaptations are straightforward - · System definition can be expanded to include new features - Documentation and Service are easier - Design aids are available - · Cost and design time are reduced ### THE MICROPROGRAM MEMORY The microprogram memory is simply an N word by M bit memory used to hold the various microinstructions. For an N word memory, the address locations are usually defined as location 0 through N-1. For example, a 256-word microprogram memory will have address locations 0 through 255. Each word of the microprogram memory consists of M bits. These M bits are usually broken into various field definitions and the fields can consist of various numbers of bits. It is the definition of the various fields of a microprogram word that is usually referred to as FORMATTING. An example of how microinstruction fields are defined in a typical machine microprogram memory word is as follows: Field 1 - General purpose Field 2 - Branch address Field 3 - Next microinstruction address control Field 4 - Condition code multiplexer control Field 5 - Interrupt control Field 6 - Fast clock/slow clock select Field 7 - Carry control Field 8 - ALU source operand control Field 9 - ALU function control Field 10 - ALU destination control Field 11 - Shift multiplexer control Field 12 - etc. ### **EXECUTING MICROINSTRUCTONS** Once the microprogram format has been defined, it is necessary to execute sequences of these microinstructions if the machine is to perform any real function. In its simplest form, all that is required to sequence through a series of microinstructions is a microprogram address counter. The microprogram address counter simply increments by one on each clock cycle to select the address of the next microinstruction. For example, if the microprogram address counter contains address 23, the next clock cycle will increment the counter and it will select address 24. The counter will continue to increment on each clock cycle thereby selecting address 25, address 26, address 27, and so forth. If this were the only control available, the machine would not be very flexible and it would be able to execute only a fixed pattern of microinstructions. The technique of continuing from one microinstruction to the next sequential microinstruction is usually referred to as CONTINUE. Thus, in microprogram control definition, we will use the CONTINUE (CONT) statement to mean simply incrementing to the next microinstruction. ### MICROPROGRAM JUMPING If the microprogram control unit is to have the ability to select other than the next microinstruction, the control unit must be able to load a JUMP address. The load control of a counter can be a single bit field within the microprogram word format. Let us call this one-bit field the microprogram address counter load enable bit. When this bit is at logic 0, a load will be inhibited and when this bit is a logic 1, a load will be enabled. If the load is enabled, the JUMP address contained within the microprogram memory will be parallel loaded into the microprogram address counter. This results in the ability to perform an N-way branch. For example, if the branch address field is eight bits wide, a JUMP to any address in the memory space from word 0 through word 255 can be performed. This simple branching control feature allows a microprogram memory controller to execute sequential microinstructions or perform a JUMP (JMP) to any address either before or after the address currently contained in the microprogram address counter. ### CONDITIONAL JUMPING While the JUMP instruction has added some flexibility to the sequencing of microprogram instructions, the controller still lacks any decision-making capability. This decision-making capability is provided by the CONDITIONAL JUMP (COND JMP) instruction. Figure 1 shows a functional block diagram of a microprogram memory/address controller providing the capability to jump on either of two different conditions. In this example, the load select control is a two-bit field used to control a Figure 1. A Two-Bit Control Field Can be Used to Select CONTINUE, BRANCH, or CONDITIONAL BRANCH. four-input multiplexer. When the two-bit field is equivalent to binary zero, the multiplexer selects the zero input which forces the load control inactive. Thus, the CONTINUE microprogram control instruction is executed. When the two-bit load select field contains binary one, the D1 input of the multiplexer is selected. Now, the load control is a function of the Condition 1 input. If Condition 1 is logic 0, the microprogram address counter increments and if Condition 1 is logic 1, the jump address will be parallel loaded in the next clock cycle. This operation is defined as a CONDITIONAL JUMP. If the load select input contains binary 2, the D2 input is selected and the same conditional function is performed with respect to the Condition 2 input. If the load select field contains binary 3, the D3 input of the multiplexer is selected. Since the D3 input is tied to logic HIGH, this forces the microprogram address counter to the load mode independent of anything else. Thus, the jump address is loaded into the microprogram address counter on the next clock cycle and an UNCONDITIONAL JUMP is executed. This load select control function definition is shown in Table 1. TABLE 1. LOAD SELECT CONTROL FUNCTION. | S <sub>1</sub> | So | Function | |----------------|----|-----------------------| | 0 | 0 | Continue | | 0 | 1 | Jump Condition 1 True | | 1 | 0 | Jump Condition 2 True | | 1 | 1 | Jump Unconditional | ### OVERLAPPING THE MICROPROGRAM INSTRUCTION FETCH Now that a few basic microprogram address control instructions have been defined, let us examine the control instructions used in a microprogram control unit featuring the overlap fetching of the next microinstruction. This technique is also known as "pipelining". The block diagram for such a microprogram control unit is shown in Figure 2. The key difference when compared with previous microprogrammed architectures is the existence of the "pipeline register" at the output of the microprogram memory. By definition, the pipeline register (or microword register) contains the microinstruction currently being executed by the machine. Simultaneously, while this microinstruction is being executed, the address of the next microinstruction is applied to the microprogram memory and the contents of that memory word are being fetched and set-up at the inputs to the pipeline register. This technique of pipelining can be used to improve the performance of the microprogram control unit. This results because the contents of the microprogram memory word required for the next cycle are being fetched on an overlapping basis with the actual execution of the current microprogram word. It should be realized that when the pipeline approach is used, the design engineer must be aware of the fact that some registers contain the results of the previous microinstruction executed, some registers contain the current microinstruction being executed, and some registers contain data for the next microinstruction to be executed. Figure 2. Overlapping (or Pipelining) the Fetch of the Next Microinstruction. Let us now compare the block diagram of Figure 2 with that shown in Figure 1. The major difference, of course, is the addition of the pipeline register at the output of the microprogram control memory. Also, notice the addition of the address multiplexer at the source of the microprogram memory address. This address multiplexer is used to select the microprogram counter register or the pipeline register as the source of the next address for the microprogram memory. The condition code multiplexer is used to control the address multiplexer in this address selection. By placing an incrementer at the output of the address multiplexer, is is possible to always generate the current microprogram address "plus one" at the input of the microprogram counter register. In Figure 1, the microprogram address counter was described as a counter and could be a device such as the Am25LS161 counter. In the implementation as shown in Figure 2, the Am25LS161 counter is not appropriate. Instead, an incrementer and register are used to give the equivalent effect of a counter. The key difference between using a true binary counter and the incrementer register described here is as follows. When the jump address from the pipeline register is selected by the multiplexer, the incrementer will combinatorially prepare that address plus one for entry into the microprogram counter register. This entry will occur on the LOW-to-HIGH transition of the clock. Thus, the microprogram counter register can always be made to contain address plus one, independent of the selection of the next microinstruction address. When the address multiplexer is switched so that the microprogram counter register is selected as the source of the microprogram memory address. the incrementer will again set-up address plus one for entry into the microprogram counter register. Thus, when the address multiplexer selects the microprogram counter register, the address multiplexer, incrementer and microprogram counter register appear to operate as a normal binary counter. The condition code multiplexer $S_0S_1$ operates in exactly the same fashion as described for the condition code multiplexer of Figure 1. That is, binary zero in the pipeline register (the current microinstruction being executed) forces an unconditional selection of the microprogram register via $D_0$ . Binary one or binary two in the next address select control bits of the pipeline register cause a conditional selection at the address multiplexer via $D_1$ or $D_2$ . Thus, a CONDITIONAL JUMP can be executed. Binary three in the next address select portion of the pipeline register causes an UNCONDITIONAL JUMP instruction to be executed via $D_3$ . When the overall machine timing is studied, it will be observed that the key difference between overlap fetching and non-overlap fetching involves the propagation delay of the microprogram memory. In the non-pipelined architecture, the microprogram memory propagation delay must be added to the propagation delay of all the other elements of the machine. In the overlap fetch architecture, the propagation delay associated with the next microprogram memory address fetch is a separate loop independent of the other portion of the machine. ### SUBROUTINING IN MICROPROGRAMMING CONTROL Thus far, we have examined the CONTINUE instruction as well as the CONDITIONAL and UNCONDITIONAL JUMP instructions for overlap fetch. Just as in the programming of minicomputers and microcomputers, the advantages of SUBROUTINING can be realized in microprogramming. The idea here, of course, is that the same block of microcode (or even a single microinstruction) can be shared by several microinstruction sequences. This results in an overall reduction in the total number of microprogram memory words required by the design. If we are to jump to a subroutine, what is required is the ability to store an address to which the subroutine should return when it has completed its execution. Examining the block diagram of Figure 3, we see the addition of a subroutine and loop (push/pop) stack (also called the file) and its associated stack pointer. The control signals required by the stack are an enable stack signal (FILE ENABLE = FE) which will be used to tell the file whenever we wish to perform a push or a pop, and a push/pop control (PUP) used to control the direction of the stack pointer (push or pop). In this architecture, the stack pointer always points to the address of the last microinstruction written on the stack. This allows the "next address multiplexer" to read the stack at any time via port F. When this selection is performed, the last word written on the stack will be the word applied to the microprogram memory. The condition code multiplexer of the previous example has also been replaced by a next address control unit. This next address control unit (Am29811A) can execute 16 different next address control functions where most of these functions are conditional. Thus, the device has four instruction inputs as well as one condition code test input which is connected to the condition code multiplexer. Note also that the next address control field of the microprogram word has been expanded to a four-bit field. Outputs from the Am29811A next address control block are used to control the stack pointer and the next address multiplexer of the Am2911. In addition, the device has outputs to control the three-state enable of the pipeline register and the three-state enable of the starting address decode PROM. Also, the architecture has a counter that can be used as a loop-counter or event counter. The 16 instructions associated with the Am29811A are listed in Table 2. As is easily seen by referring to Table 2, three of the instructions in this set are associated with subroutining in microprogram memory. The first instruction of this set, is a simple conditional JUMP-TO-SUBROUTINE where the source of the subroutine address is in the pipeline register. The RETURN-FROM-SUBROUTINE instruction is also conditional and is used to return to the next microinstruction following the JUMP-TO-SUBROUTINE instruction. There is also a conditional JUMP-TO-ONE-OF-TWO-SUBROUTINES, where the subroutine address is either in the PIPELINE register or in the internal REGISTER in the Am2911. This instruction will be explained in more detail later. ### TYPICAL COMPUTER CONTROL UNIT ARCHITECTURE USING THE Am2911 AND Am29811A The microprogram memory control unit block diagram of Figure 3 is easily implemented using the Am2911 and Am29811A. This architecture provides a structured state machine design capable of executing many highly sophisticated next address control instructions. The Am2911 contains a next address multiplexer that provides four different inputs from which the address of the next microinstruction can be selected. These are the direct input (D), the register input (R), the program counter (PC), and the file (F). The starting address decoder (mapping PROM) output and the pipeline register output are connected together at the D input to the Am2911 and are operated in the three-state mode. The architecture of Figure 3 shows an instruction register capable of being loaded with a machine instruction word from the data bus. The op code portion of the instruction is decoded using a mapping PROM to arrive at a starting address for the TABLE 2. FUNCTIONAL DESCRIPTION OF Am29811A INSTRUCTION SET. | | | | | | INPUTS | | | OL | JTPUTS | | | |----------|------|---|-----------------------|-------|-----------------------|------|---------------------|------|---------|-------|------| | MNEMONIC | INST | - | JCT<br>I <sub>1</sub> | | FUNCTION | TEST | NEXT ADDR<br>SOURCE | FILE | COUNTER | MAP-E | PL-E | | JZ | L | L | L | L | JUMP ZERO | X | D ' | HOLD | LL | Н | L | | CJS | L | L | L | Н | COND JSB PL | L | PC | HOLD | HOLD | Н | L | | | | | | | | н | D | PUSH | HOLD | Н | L | | JMAP | L | L | Н | L | JUMP MAP | X | D | HOLD | HOLD | L | - Н | | CJP | L | L | Н | Н | COND JUMP PL | L | PC | HOLD | HOLD | Н | L | | | | | | | | н | D | HOLD | HOLD | Н | L | | PUSH | L | Н | L | L | PUSH/COND LD CNTR | L | PC | PUSH | HOLD | Н | L | | | | | | | | н | PC | PUSH | LOAD | н | L | | JSRP | L | Н | L | Н | COND JSB R/PL | L | R | PUSH | HOLD | Н | L, | | | | | | | | н | D | PUSH | HOLD | н | L | | CJV | L | Н | н | L | COND JUMP VECTOR | L | PC | HOLD | HOLD | Н | Н | | | | | | 35.71 | | Н | D | HOLD | HOLD | н | н | | JRP | L | Н | Н | н | COND JUMP R/PL | L | R | HOLD | HOLD | Н | L | | | | | | | | н | D | HOLD | HOLD | н | L | | RECT | Н | L | L | L | REPEAT LOOP, CNTR ≠ 0 | L | F | HOLD | DEC | Н | L | | | | | | | | н | PC | POP | HOLD | н | L | | RPCT | H. | L | L | Н | REPEAT PL, CNTR ≠ 0 | L | D | HOLD | DEC | Н | L | | | | | | | | н | PC | HOLD | HOLD | н | L | | CRTN | Н | L | Н | L | COND RTN | L | PC | HOLD | HOLD | Н | L | | | | | | 3.6 | | н | F | POP | HOLD | н | L | | CJPP | Н | L | Н | Н | COND JUMP PL & POP | L | PC | HOLD | HOLD | Н | L | | | | | | | | Н | D | POP | HOLD | н | L | | LDCT | Н | Н | L | L | LOAD CNTR & CONTINUE | X | PC | HOLD | LOAD | н | L | | LOOP | Н | н | L | Н | TEST END LOOP | L | F | HOLD | HOLD | Н | L | | | | | | | | н | PC | POP | HOLD | н | L | | CONT | Н | н | Н | L | CONTINUE | Х | PC | HOLD | HOLD | н | L | | JP | Н | Н | Н | Н | JUMP PL | X | D | HOLD | HOLD | н | L | Figure 3. A Typical Computer Control Unit Using the Am2911 and Am29811A. | Abbreviation | Name | Function | | | | | | | | |----------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Di | Direct Input Bit i | Direct input to register/counter and multiplexer. Do is LSB | | | | | | | | | li . | Instruction Bit i | Selects one-of-sixteen instructions for the Am2910 | | | | | | | | | CC | Condition Code | Used as test criterion. Pass test is a LOW on CC. | | | | | | | | | CCEN | Condition Code Enable | Whenever the signal is HIGH, $\overline{CC}$ is ignored and the part operates as though $\overline{CC}$ were true (LOW). | | | | | | | | | CI | Carry-In | Low order carry input to incrementer for microprogram counter | | | | | | | | | RLD | Register Load | When LOW forces loading of register/counter regardless of instruction or condition | | | | | | | | | ŌĒ | Output Enable | Three-state control of Y; outputs | | | | | | | | | CP | Clock Pulse | Triggers all internal state changes at LOW-to-HIGH edge | | | | | | | | | Vcc | +5 Volts | | | | | | | | | | GND | Ground | | | | | | | | | | Yi | Microprogram Address Bit i | Address to microprogram memory, Yo is LSB, Y11 is MSB | | | | | | | | | FULL | Full | Indicates that five items are on the stack | | | | | | | | | PL Pipeline Address Enable | | Can select #1 source (usually Pipeline Register) as direct input source | | | | | | | | | MAP | Map Address Enable | Can select #2 source (usually Mapping PROM or PLA) as direct input source | | | | | | | | | VECT | Vector Address Enable | Can select #3 source (for example, Interrupt Starting Address) as direct input source | | | | | | | | microinstruction sequence required to execute the machine instruction. When the microprogram memory address is to be the first microinstruction of the machine instruction sequence, the Am29811A next address control unit selects the multiplexer D input and enables the three-state output from the mapping PROM. When the current microinstruction being executed is selecting the next microinstruction address as a JUMP function, the JUMP address will be available at the multiplexer D input. This is accomplished by having the Am29811A select the next address multiplexer D input and also enabling the three-state output of the pipeline register branch address field. The register enable input to the Am2911 is connected to ground so that this register will always load the value at the Am2911 D input. The value at D is clocked into the Am2911's register (R) at the end of the current microcycle, which makes the D value of this microcycle available as the R value of the next microcycle. Thus, by using the branch address field of two sequential microinstructions, a conditional JUMP-TO-ONE-OF-TWO-SUBROUTINES or a conditional JUMP-TO-ONE-OF-TWO-BRANCH-ADDRESSES can be executed by either selecting the D input or the R input of the next address multiplexer. When sequencing through continuous microinstructions in microprogram memory, the program counter in the Am2911 is used. Here, the Am29811A simply selects the PC input of the next address multiplexer. In addition, most of these instructions enable the three-state outputs of the pipeline register associated with the branch address field, which allows the register within the Am2911 to be loaded. The 4 x 4 stack in the Am2911 is used for looping and subroutining in microprogram operations. Up to four levels of subroutines or loops can be nested. Also, loops and subroutines can be intermixed as long as the four-word depth of the stack is not exceeded. ### ARCHITECTURE OF THE Am2910 The Am2910 is a bipolar microprogram controller intended for use in high-speed microprocessor applications. It allows addressing of up to 4K words of microprogram. A block diagram is shown in Figure 4. The controller contains a four-input multiplexer that is used to select either the register/counter, direct input, microprogram counter, or stack as the source of the next microinstruction address. The register/counter consists of 12 D-type, edge-triggered flip-flops, with a common clock enable. When its load control, $\overline{\text{RLD}}$ , is LOW, new data is loaded on a positive clock transition. A few instructions include load; in most systems, these instructions will be sufficient, simplifying the microcode. The output of the register/counter is available to the multiplexer as a source for the next microinstruction address. The direct input furnishes a source of data for loading the register/counter. Figure 4. Am2910 Block Diagram. The Am2910 contains a microprogram counter ( $\mu$ PC) that is composed of a 12-bit incrementer followed by a 12-bit register. The $\mu$ PC can be used in either of two ways. When the carry-in to the incrementer is HIGH, the microprogram register is loaded on the next clock cycle with the current Y output word plus one (Y+1 $\rightarrow$ $\mu$ PC). Sequential microinstructions are thus executed. When the carry-in is LOW, the incrementer passes the Y output word unmodified so that $\mu$ PC is reloaded with the same Y word on the next clock cycle (Y $\rightarrow$ $\mu$ PC). The same microinstruction is thus executed any number of times. The third source for the multiplexer is the direct (D) inputs. This source is used for branching. The fourth source available at the multiplexer input is a 5-word by 12-bit stack (file). The stack is used to provide return address linkage when executing microsubroutines or loops. The stack contains a build-in stack pointer (SP) which always points to the last file word written. This allows stack reference operations (looping) to be performed without a pop. The stack pointer operates as an up/down counter. During microinstructions 2, 4 and 5, the PUSH operation is performed. This causes the stack pointer to increment and the file to be written with the required return linkage. On the cycle following the PUSH, the return data is at the new location pointed to by the stack pointer. During six other microinstructions, a POP operation occurs. This places the information at the top of the stack onto the Y outputs. The stack pointer decrements at the next rising clock edge following a POP, effectively removing old information from the top of the stack. The stack pointer linkage is such that any sequence of pushes, pops or stack references can be achieved. At RESET (Instruction 0), the depth of nesting becomes zero. For each PUSH, the nesting depth increases by one; for each POP, the depth decreases by one. The depth can grow to five. After a depth of five is reached, FULL goes LOW. Any further PUSHes onto a full stack overwrites information at the top of the stack, but leaves the stack pointer unchanged. This operation will usually destroy useful information and is normally avoided. A POP from an empty stack places non-meaningful data on the Y outputs, but is otherwise safe. The stack pointer remains at zero whenever a POP is attempted from a stack already empty. The register/counter is operated during three microinstructions (8, 9, 15) as a 12-bit down counter, with result = zero available as a microinstruction branch test criterion. This provides efficient iteration of microinstructions. The register/counter is arranged such that if it is preloaded with a number N and then used as a loop termination counter, the sequence will be executed exactly N+1 times. During instruction 15, a three-way branch under combined control of the loop counter and the condition code is available. The device provides three-state Y outputs. These can be particularly useful in designs requiring automatic checkout of the processor. The microprogram controller outputs can be forced into the high-impedance state, and pre-programmed sequences of microinstructions can be executed via external access to the address lines. ### **OPERATION** Table 4 shows the result of each instruction in controlling the multiplexer which determines the Y outputs, and in controlling the three enable signals $\overline{PL}$ , $\overline{MAP}$ and $\overline{VECT}$ . The effect on the $\mu PC$ , the register/counter, and the stack after the next positive-going clock edge is also shown. The multiplexer determines which internal source drives the Y outputs. The value loaded into $\mu PC$ is either identical to the Y output, or else one greater, as determined by CI. For each instruction, one and only one of the three outputs $\overline{PL}$ , $\overline{MAP}$ and $\overline{VECT}$ is LOW. If these outputs control three-state enables for the primary source of microprogram jumps (usually part of a pipeline register), a PROM which maps the instruction to a microinstruction starting location, and an optional third source (often a vector from a DMA or interrupt source), respectively, the three-state sources can drive the D inputs without further logic. Several inputs, as shown in Table 4 can modify instruction execution. The combination $\overline{CC}$ HIGH and $\overline{CCEN}$ LOW is used as a test in 10 of the 16 instructions. $\overline{RLD}$ , when LOW, causes the D input to be loaded into the register/counter, overriding any HOLD or DEC operation specified in the instruction. $\overline{OE}$ , normally LOW, may be forced HIGH to remove the Am2910 Y outputs from a three-state bus. TABLE 4. Am2910 MICROINSTRUCTION SET. | HEX | | | REG/<br>CNTR | CCEN = LC | FAIL_<br>DW and CC = HIGH | CCEN = HI | PASS<br>GH or CC = LOW | REG/ | | |-------|----------|-----------------------|---------------|-----------|---------------------------|-----------|------------------------|--------|--------| | 13-10 | MNEMONIC | NAME | CON-<br>TENTS | Υ | STACK | Υ | STACK | CNTR | ENABLE | | 0 | JZ | JUMP ZERO | × | 0 | CLEAR | .0 | CLEAR | HOLD | PL | | 1 | CJS | COND JSB PL | X | PC | HOLD | D | PUSH | HOLD | PL | | 2 | JMAP | JUMP MAP | X | D | HOLD | D | HOLD | HOLD | MAP | | 3 | CJP | COND JUMP PL | X | PC | HOLD | D | HOLD | HOLD | PL | | 4 | PUSH | PUSH/COND LD CNTR | X | PC | PUSH | PC | PUSH | Note 1 | PL | | 5 | JSRP | COND JSB R/PL | X | R | PUSH | D | PUSH | HOLD | PL | | 6 | CJV | COND JUMP VECTOR | X | PC | HOLD | D | HOLD | HOLD | VECT | | 7 | JRP | COND JUMP R/PL | X | R | HOLD | D | HOLD | HOLD | PL | | _ | | | <b>#0</b> | F | HOLD | F | HOLD | DEC | PL | | 8 | RFCT | REPEAT LOOP, CNTR ≠ 0 | = 0 | PC | POP | PC | POP | HOLD | PL | | | DOOT | DESCRIPTION ON TO 10 | ≠0 | D | HOLD | D | HOLD | DEC | PL | | 9 | RPCT | REPEAT PL, CNTR ≠ 0 | = 0 | PC | HOLD | PC | HOLD | HOLD | PL | | Α | CRTN | COND RTN | X | PC | HOLD | F | POP | HOLD | PL | | В | CJPP | COND JUMP PL & POP | X | PC | HOLD | D | POP | HOLD | PL | | С | LDCT | LD CNTR & CONTINUE | X | PC | HOLD | PC | HOLD | LOAD | PL | | D | LOOP | TEST END LOOP | × | F | HOLD | PC | POP | HOLD | PL | | Е | CONT | CONTINUE | X | PC | HOLD | PC | HOLD | HOLD | PL | | F | THE | TUDES WAY BOAROU | ± 0 | F | HOLD | PC | POP | DEC | PL | | P | TWB | THREE-WAY BRANCH | = 0 | D | POP | PC | POP | HOLD | PL | Note: If $\overline{CCEN}$ = LOW and $\overline{CC}$ = HIGH, hold; else load. X = Don't Care. The stack, a five-word last-in, first-out 12-bit memory, has a pointer which addresses the value presently on the top of the stack. Explicit control of the stack pointer occurs during instruction 0 (RESET), which makes the stack empty by resetting the SP to zero. After a RESET, and whenever else the stack is empty, the content of the top of stack is undefined until a PUSH occurs. Any POPs performed while the stack is empty put undefined data on the F outputs and leave the stack pointer at zero. Any time the stack is full (five more PUSHes than POPs have occurred since the stack was last empty), the FULL warning output occurs. No additional PUSH should be attempted onto a full stack; if tried, information at the top of the stack will be overwritten and lost. #### THE Am2910 INSTRUCTION SET The Am2910 provides 16 instructions which select the address of the next microinstruction to be executed. Four of the instructions are unconditional — their effect depends only on the instruction. Ten of the instructions have an effect which is partially controlled by an external, data-dependent condition. Three of the instructions have an effect which is partially controlled by the contents of the internal register/counter. The instruction set is shown in Table 4. In this discussion it is assumed that CI is tied HIGH. In the ten conditional instructions, the result of the data-dependent test is applied to $\overline{CC}$ . If the $\overline{CC}$ input is LOW, the test is considered to have been passed, and the action specified in the name occurs; otherwise, the test has failed and an alternate (often simply the execution of the next sequential microinstruction) occurs. Testing of $\overline{CC}$ may be disabled for a specific microinstruction by setting $\overline{CCEN}$ HIGH, which unconditionally forces the action specified in the name; that is, it forces a pass. Other ways of using $\overline{CCEN}$ include (1) tying it HIGH, which is useful if no microinstruction is data-dependent; (2) tying it LOW if data-dependent instructions are never forced unconditionally; or (3) tying it to the source of Am2910 instruction bit $I_0$ , which leaves instructions 4, 6 and 10 as data-dependent but makes others unconditional. All of these tricks save one bit of microcode width. The effect of three instructions depends on the contents of the register/counter. Unless the counter holds a value of zero, it is decremented; if it does hold zero, it is held and a different microprogram next address is selected. These instructions are useful for executing a microinstruction loop a known number of times. Instruction 15 is affected both by the external condition code and the internal register/counter. Perhaps the best technique for understanding the Am2910 is to simply take each instruction and review its operation. In order to provide some feel for the actual execution of these instructions, Figure 5 is included and depicts examples of all 16 instructions. The examples given in Figure 5 should be interpreted in the following manner: The intent is to show microprogram flow as various microprogram memory words are executed. For example, the CONTINUE instruction, instruction number 14, as shown in Figure 5, simply means that the contents of microprogram memory word 50 is executed, then the contents of word 51 is executed. This is followed by the contents of microprogram memory word 52 and the contents of microprogram memory word 53. The microprogram addresses used in the examples were arbitrarily chosen and have no meaning other than to show instruction flow. The exception to this is the first example, JUMP ZERO, which forces the microprogram location counter to address ZERO. Each dot refers to the time that the contents of the microprogram memory word is in the pipeline register. While no special symbology is used for the conditional instructions, the text to follow will explain what the conditional choices are in each example. It might be appropriate at this time to mention that AMD has a microprogram assembler called AMDASM, which has the capability of using the Am2910 instructions in symbolic representation. AMDASM's Am2910 instruction symbolics (or mnemonics) are given in Figure 5 for each instruction and are also shown in Table 4. Instruction 0, JZ (JUMP and ZERO, or RESET) unconditionally specifies that the address of the next microinstruction is zero. Many designs use this feature for power-up sequences and provide the power-up firmware beginning at microprogram memory word location 0. Instruction 1 is a CONDITIONAL JUMP-TO-SUBROUTINE via the address provided in the pipeline register. As shown in Figure 5, the machine might have executed words at address 50, 51 and 52. When the contents of address 52 is in the pipeline register, the next address control function is the CONDITIONAL JUMP-TO-SUBROUTINE. Here, if the test is passed, the next instruction executed will be the contents of microprogram memory location 90. If the test failed, the JUMP-TO-SUBROUTINE will not be executed; the contents of microprogram memory location 53 will be executed instead. Thus, the CONDITIONAL JUMP-TO-SUBROUTINE instruction at location 52 will cause the instruction either in location 90 or in location 53 to be executed next. If the TEST input is such that location 90 is selected, value 53 will be pushed onto the internal stack. This provides the return linkage for the machine when the subroutine beginning at location 90 is completed. In this example, the subroutine was completed at location 93 and a RETURN-FROM-SUBROUTINE would be found at location 93. Instruction 2 is the JUMP MAP instruction. This is an unconditional instruction which causes the $\overline{\text{MAP}}$ output to be enabled so that the next microinstruction location is determined by the address supplied via the mapping PROMs. Normally the JUMP MAP instruction is used at the end of the instruction fetch sequence for the machine. In the example of Figure 5, microinstructions at locations 50, 51, 52 and 53 might have been the fetch sequence and at its completion at location 53, the jump map function would be contained in the pipeline register. This example shows the mapping PROM outputs to be 90; therefore, an unconditional jump to microprogram memory address 90 is performed. Instruction 3, CONDITIONAL JUMP PIPELINE, derives its branch address from the pipeline register branch address value (BR<sub>0</sub>-BR<sub>11</sub> in Figure 6). This instruction provides a technique for branching to various microprogram sequences depending upon the test condition inputs. Quite often, state machines are designed which simply execute tests on various inputs waiting for the condition to come true. When the true condition is reached, the machine then branches and executes a set of microinstructions to perform some function. This usually has the effect of resetting the input being tested until some point in the future. Figure 5 shows the conditional jump via the pipeline register address at location 52. When the contents of microprogram memory word 52 are in the pipeline register, the next address will be either location 53 or location 30 in this example. If the test is passed, the value currently in the pipeline register (3) will be selected. If the test fails, the next address selected will be contained in the microprogram counter which, in this example, is 53. Instruction 4 is the PUSH/CONDITIONAL LOAD COUNTER instruction and is used primarily for setting up loops in microprogram firmware. In Figure 5, when instruction 52 is in the pipeline register, a PUSH will be made onto the stack and the counter will be loaded based on the condition. When a PUSH occurs, the value pushed is always the next sequential instruction address. In this case, the address is 53. If the test fails, the counter is not Figure 5. Am2910 Execution Examples. loaded; if it is passed, the counter is loaded with the value contained in the pipeline register branch address field. Thus, a single microinstruction can be used to set up a loop to be executed a specific number of times. Instruction 8 will describe how to use the pushed value and the register/counter for looping. Instruction 5 is a CONDITIONAL JUMP-TO-SUBROUTINE via the register/counter or the contents of the PIPELINE register. As shown in Figure 5, a PUSH is always performed and one of two subroutines executed. In this example, either the subroutine beginning at address 80 or the subroutine beginning at address 90 will be performed. A return-from-subroutine (instruction number 10) returns the microprogram flow to address 55. In order for this microinstruction control sequence to operate correctly, both the next address fields of instruction 53 and the next address fields of instruction 54 would have to contain the proper value. Let's assume that the branch address fields of instruction 53 contain the value 90 so that it will be in the Am2910 register/counter when the contents of address 54 are in the pipeline register. This requires that instruction at address 53 load the register/counter. Now, during the execution of instruction 5 (at address 54), if the test failed, the contents of the register (value = 90) will select the address of the next microinstruction. If the test input passes, the pipeline register contents (value = 80) will determine the address of the next microinstruction. Therefore, this instruction provides the ability to select one of two subroutines to be executed based on a test condition. Instruction 6 is a CONDITIONAL JUMP VECTOR instruction which provides the capability to take the branch address from a third source heretofore not discussed. In order for this instruction to be useful, the Am2910 output, VECT, is used to control a three-state control input of a register, buffer, or PROM containing the next microprogram address. This instruction provides one technique for performing interrupt type branching at the microprogram level. Since this instruction is conditional, a pass causes the next address to be taken from the vector source, while failure causes the next address to be taken from the microprogram counter. In the example of Figure 5, if the CONDITIONAL JUMP VECTOR instruction is contained at location 52, execution will continue at vector address 20 if the TEST input is HIGH and the microinstruction at address 53 will be executed if the TEST input is LOW. Instruction 7 is a CONDITIONAL JUMP via the contents of the Am2910 REGISTER/COUNTER or the contents of the PIPELINE register. This instruction is very similar to instruction 5; the conditional jump-to-subroutine via R or PL. The major difference between instruction 5 and instruction 7 is that no push onto the stack is performed with 7. Figure 5 depicts this instruction as a branch to one of two locations depending on the test condition. The example assumes the pipeline register contains the value 70 when the contents of address 52 is being executed. As the contents of address 53 is clocked into the pipeline register, the value 70 is loaded into the register/counter in the Am2910. The value 80 is available when the contents of address 53 is in the pipeline register. Thus, control is transferred to either address 70 or address 80 depending on the test condition. Instruction 8 is the REPEAT LOOP, COUNTER ≠ ZERO instruction. This microinstruction makes use of the decrementing capability of the register/counter. To be useful, some previous instruction, such as 4, must have loaded a count value into the register/counter. This instruction checks to see whether the register/counter contains a non-zero value. If so, the register/counter is decremented, and the address of the next microinstruction is taken from the top of the stack. If the register counter contains zero, the loop exit condition is occurring; control falls through to the next sequential microinstruction by selecting $\mu$ PC; the stack is POP'd by decrementing the stack pointer, but the contents of the top of the stack are thrown away. An example of the REPEAT LOOP, COUNTER $\neq$ ZERO instruction is shown in Figure 5. In this example, location 50 most likely would contain a PUSH/CONDITIONAL LOAD COUNTER instruction which would have caused address 51 to be PUSHed on the stack and the counter to be loaded with the proper value for looping the desired number of times. In this example, since the loop test is made at the end of the instructions to be repeated (microaddress 54), the proper value to be loaded by the instruction at address 50 is one less than the desired number of passes through the loop. This method allows a loop to be executed from 0 to 4095 times. Single-microinstruction loops provide a highly efficient capability for executing a specific microinstruction a fixed number of times. Examples include fixed rotates, byte swap, fixed point multiply, and fixed point divide. Instruction 9 is the REPEAT PIPELINE REGISTER, COUNTER ≠ ZERO instruction. This instruction is similar to instruction 8 except that the branch address now comes from the pipeline register rather than the file. In some cases, this instruction may be thought of as a one-word file extension; that is, by using this instruction, a loop with the counter can still be performed when subroutines are nested five deep. This instruction's operation is very similar to that of instruction 8. The differences are that on this instruction, a failed test condition causes the source of the next microinstruction address to be the D inputs; and, when the test condition is passed, this instruction does not perform a POP because the stack is not being used. In the example of Figure 5, the REPEAT PIPELINE, COUNTER ≠ ZERO instruction is instruction 52 and is shown as a single microinstruction loop. The address in the pipeline register would be 52. Instruction 51 in this example could be the LOAD COUNTER AND CONTINUE instruction (number 12). While the example shows a single microinstruction loop, by simply changing the address in a pipeline register, multi-instruction loops can be performed in this manner for a fixed number of times as determined by the counter. Instruction 10 is the conditional RETURN-FROM-SUBROUTINE instruction. As the name implies, this instruction is used to branch from the subroutine back to the next microinstruction address following the subroutine call. Since this instruction is conditional, the return is performed only if the test is passed. If the test is failed, the next sequential microinstruction is performed. The example in Figure 5 depicts the use of the conditional RETURN-FROM-SUBROUTINE instruction in both the conditional and the unconditional modes. This example first shows a jump-tosubroutine at instruction location 52 where control is transferred to location 90. At location 93, a conditional RETURN-FROM-SUBROUTINE instruction is performed. If the test is passed, the stack is accessed and the program will transfer to the next instruction at address 53. If the test is failed, the next microinstruction at address 94 will be executed. The program will continue to address 97 where the subroutine is complete. To perform an unconditional RETURN-FROM-SUBROUTINE, the conditional RETURN-FROM-SUBROUTINE instruction is executed unconditionally; the microinstruction at address 97 is programmed to force CCEN HIGH, disabling the test and the forced PASS causes an unconditional return. Instruction 11 is the CONDITIONAL JUMP PIPELINE register address and POP stack instruction. This instruction provides another technique for loop termination and stack maintenance. The example in Figure 5 shows a loop being performed from address 55 back to address 51. The instructions at locations 52, 53 and 54 are all conditional JUMP and POP instructions. At address 52, if the TEST input is passed, a branch will be made to address 70 and the stack will be properly maintained via a POP. Should the test fail, the instruction at location 53 (the next sequential instruction) will be executed. Likewise, at address 53, either the instruction at 90 or 54 will be subsequently executed, respective to the test being passed or failed. The instruction at 54 follows the same rules, going to either 80 or 55. An instruction sequence as described here, using the CONDITIONAL JUMP PIPELINE and POP instruction, is very useful when several inputs are being tested and the microprogram is looping waiting for any of the inputs being tested to occur before proceeding to another sequence of instructions. This provides the powerful jump-table programming technique at the firmware level. Instruction 12 is the LOAD COUNTER AND CONTINUE instruction, which simply enables the counter to be loaded with the value at its parallel inputs. These inputs are normally connected to the pipeline branch address field which (in the architecture being described here) serves to supply either a branch address or a counter value depending upon the microinstruction being executed. There are altogether three ways of loading the counter the explicit load by this instruction 12; the conditional load included as part of instruction 4; and the use of the RLD input along with any instruction. The use of RLD with any instruction overrides any counting or decrementation specified in the instruction, calling for a load instead. Its use provides additional microinstruction power, at the expense of one bit of microinstruction width. This instruction 12 is exactly equivalent to the combination of instruction 14 and RLD LOW. Its purpose is to provide a simple capability to load the register/counter in those implementations which do not provide microprogrammed control for RLD. Instruction 13 is the TEST END-OF-LOOP instruction, which provides the capability of conditionally exiting a loop at the bottom; that is, this is a conditional instruction that will cause the microprogram to loop, via the file, if the test is failed else to continue to the next sequential instruction. The example in Figure 5 shows the TEST END-OF-LOOP microinstruction at address 56. If the test fails, the microprogram will branch to address 52. Address 52 is on the stack because a PUSH instruction had been executed at address 51. If the test is passed at instruction 56, the loop is terminated and the next sequential microinstruction at address 57 is being executed, which also causes the stack to be POPd; thus, accomplishing the required stack maintenance. Instruction 14 is the CONTINUE instruction, which simply causes the microprogram counter to increment so that the next sequential microinstruction is executed. This is the simplest microinstruction of all and should be the default instruction which the firmware requests whenever there is nothing better to do. Instruction 15, THREE-WAY BRANCH, is the most complex. It provides for testing of both a data-dependent condition and the counter during one microinstruction and provides for selecting among one of three microinstruction addresses as the next microinstruction to be performed. Like instruction 8, a previous instruction will have loaded a count into the register/counter while pushing a microbranch address onto the stack. Instruction 15 performs a decrement-and-branch-until-zero function similar to instruction 8. The next address is taken from the top of the stack until the count reaches zero; then the next address comes from the pipeline register. The above action continues as long as the test condition fails. If at any execution of instruction 15 the test condition is passed, no branch is taken; the microprogram counter register furnishes the next address. When the loop is ended, either by the count becoming zero, or by passing the conditional test, the stack is POP'd by decrementing the stack pointer, since interest in the value contained at the top of the stack is then complete. The application of instruction 15 can enhance performance of a variety of machine-level instructions. For instance, (1) a memory search instruction to be terminated either by finding a desired memory content or by reaching the search limit; (2) variable-field-length arithmetic terminated early upon finding that the content of the portion of the field still unprocessed is all zeroes; (3) key search in a disc controller processing variable length records; (4) normalization of a floating point number. As one example, consider the case of a memory search instruction. As shown in Figure 5, the instruction at microprogram address 63 can be Instruction 4 (PUSH), which will push the value 64 onto the microprogram stack and load the number N, which is one less than the number of memory locations to be searched before giving up. Location 64 contains a microinstruction which fetches the next operand from the memory area to be searched and compares it with the search key. Location 65 contains a microinstruction which tests the result of the comparison and also is a THREE-WAY BRANCH for microprogram control. If no match is found, the test fails and the microprogram goes back to location 64 for the next operand address. When the count becomes zero, the microprogram branches to location 72, which does whatever is necessary if no match is found. If a match occurs on any execution of the THREE-WAY BRANCH at location 65, control falls through to location 66 which handles this case. Whether the instruction ends by finding a match or not, the stack will have been POP'd once, removing the value 64 from the top of the stack. ### Am29811A Instruction Set Difference The Am29811A instruction set is identical to the Am2910 except for instruction number 15. In the Am29811A, instruction number 15 is an unconditional JUMP PIPELINE REGISTER instruction. This provides the ability to unconditionally branch to any address contained in the branch address field of the microprogram. Thus, an unconditional N-way branch can be performed. Use of this instruction as opposed to a forced conditional jump pipeline instruction simply allows the condition code multiplexer select field to be shared (formatted) with other functions. ## TYPICAL COMPUTER CONTROL UNIT ARCHITECTURE USING THE Am2910 The microprogram memory control unit block diagram of Figure 6 is easily implemented using the Am2910. This architecture provides a structured state machine design capable of executing many highly sophisticated next address control instructions. The architecture of Figure 6 shows an instruction register capable of being loaded with a machine instruction word from the data bus. The op code portion of the instruction is decoded using a mapping PROM to arrive at a starting address for the microinstruction sequence required to execute the machine instruction. When the microprogram memory address is to be the first microinstruction of the machine instruction sequence, the Am2910 next address control selects the multiplexer D input and enables the three-state output from the mapping PROM. When the current microinstruction being executed is selecting the next microinstruction address as a JUMP function, the JUMP address will be available at the multiplexer D input. This is accomplished by having the Am2910 select the next address multiplexer D input and also enabling the three-state output of the pipeline register branch address field. The register enable input to the Am2910 can be grounded so that this register will load the value at the Am2910 D input. The value at D is clocked into the Am2910's register (R) at the end of the current microcycle, which makes the D value of this microcycle available as the R value of the next microcycle. Thus, by using the branch address field of two sequential microinstructions, a conditional JUMP-TO-ONE-OF-TWO-SUBROUTINES or a conditional JUMP-TO-ONE-OF-TWO-BRANCH-ADDRESSES can be executed by either selecting the D input or the R input of the next address multiplexer. When sequencing through continuous microinstructions in microprogram memory, the program counter in the Am2910 is used. Here, the control logic simply selects the PC input of the next address multiplexer. In addition, most of these instructions enable the three-state outputs of the pipeline register associated with the branch address field, which allows the register within the Am2910 to be loaded. The 5 x 12 stack in the Am2910 is used for looping and subroutining in microprogram operations. Up to five levels of subroutines or loops can be nested. Also, loops and subroutines can be intermixed as long as the five word depth of the stack is not exceeded. ### **CCU TIMING** The minimum clock cycle that can be used in a CCU design is usually determined by the component delays along the longest "pipeline-register-clock to logic to pipeline-register-clock" path. At the beginning of any given clock cycle, data available at the output of the microprogram memory, counter status, and any other data and/or status fields, are latched into their associated pipeline registers. At this point, all delay paths begin. Visual inspection will not always point out the longest signal delay path. Figure 6. A Typical Computer Control Unit Using the Am2910. The obviously long paths are a good place to start, but each definable path should be calculated on a component by component basis until the truly longest logic signal path is found. Referring to Figure 6, a number of potentially long paths can be identified. These include the instruction register to pipeline register time, the pipeline register to pipeline register time via the condition code multiplexer and the status to pipeline register time. In order to demonstrate the technique for calculating the AC performance of the Am2910 state machine design, the timing diagrams of Figure 7 are presented. Here, a number of propagation delay paths are evaluated such that the reader can learn the technique for performing these computations. All of the propagation delays have been calculated using typical propagation delays because at the time of this writing, the characterization of the Am2910 has not been completed. When the final data sheet is published, the user need only select the appropriate worst case specifications and he can compute the desired maximum propagation delays for his design. Also, by looking at the typical propagation delay numbers, the designer will be able to evaluate the design margin in the system after he has completed all of the worst case calculations. These typical propagation delays represent the expected values if a system were set up on the bench and actual measurements would be taken at 5V and 25°C operating temperature. While Figure 6 and Figure 7 deal with the Am2910 microprogram sequencer, it is also instructive to evaluate the AC performance of a typical computer control unit using the Am2911 and Am29811A. Figure 3 shows such a connection and will be used as the basis for performing the propagation delay path calculations. The calculations for the various propagation delay paths are demonstrated in Figure 8 and are intended to show the technique for computing these delays. As before, the typical propagation delays have been used in the computation for comparison purposes. The user can derive the maximum numbers at 25°C and 5V, commercial temperature range and power supply variations or military temperature range and power supply variations as required for his design. When Figure 7 and Figure 8 are reviewed in detail, the reader will recognize that the longest propagation delay paths in the case of the Am2910 as well as the Am2911 and Am29811A involve the three-state enables on the map PROM or the pipeline register for the branch address. If absolute maximum speed is desired, these paths can be eliminated by using one of several techniques. One technique is to simply allocate one or more bits in the pipeline register to control the three-state enables of the various devices connected to the D input of the Am2910. For the example of Figure 6, one bit would be sufficient and the pipeline register could be implemented using an Am74S175 register. This would allow the true and complement outputs to be used to drive the pipeline register branch address output enable and the mapping PROM output enable. Thus, these longest paths would be eliminated and an improvement of about 30ns would be achieved. A second technique for eliminating these propagation delay paths would be to use a four input NAND gate and a four input NOR gate to encode the equivalent function of the MAP enable and the PL enable. This technique is demonstrated in Figure 9. Again, an Am74S175 register would be used as the pipeline register to provide the instruction inputs to the Am2910 sequencer. This would allow instruction 2 to be decoded to provide the MAP enable signal and "NOT INSTRUCTION 2" to be decoded as the pipeline enable signal. This technique can be applied as well to the computer control unit of Figure 3 to accomplish the same longest path elimination. Figure 7. Propagation Delay Calculations on the Am2910 Microprogram Sequencer. Figure 7. Propagation Delay Calculations on the Am2910 Microprogram Sequencer (Cont.). Figure 7. Propagation Delay Calculations on the Am2910 Microprogram Sequencer (Cont.). Figure 7. Propagation Delay Calculations on the Am2910 Microprogram Sequencer (Cont.). Figure 8. Propagation Delay Calculations for the Am2911 and Am29811A Design. Figure 8. Propagation Delay Calculations for the Am2911 and Am29811A Design (Cont.). Figure 8. Propagation Delay Calculations for the Am2911 and Am29811A Design (Cont.). Figure 8. Propagation Delay Calculations for the Am2911 and Am29811A Design (Cont.). Figure 8. Propagation Delay Calculations for the Am2911 and Am29811A Design (Cont.). Figure 9. Using NAND and NOR Gates to Improve Am2910 Speed. In order to compare the performance of the Am2910 with the Am2911 and Am29811A, Table 5 is presented. Here the propagation delays for the Am2911 and Am29811A are for a 12-bit wide microprogram sequencer configuration. If a wider configuration is used, only one additional carry input to carry output delay must be added to the appropriate paths of these calculations. A 12-bit wide Am2911/29811A configuration has been evaluated so that an "apples to apples" comparison can be made. As is shown in Table 5, a number of combinations are possible for the longest AC propagation delay paths for these microprogram sequencers. First, the continue instruction can be executed the fastest of any of the microprogram instructions if the continues are sequential. That is, from the second continue on, the typical microcycle can be either 61 or 64ns respectively. To achieve this speed, it is required that various signals throughout the architecture be stable such that the only paths that enter into the propagation delay calculation are the clock-to-output of the microprogram counter, the microprogram memory and the pipeline register setup. The second group of instructions shown in Table 5 show some examples of instruction execution and jumping. These examples assume that the $\overline{\text{MAP}}$ and $\overline{\text{OE}}$ outputs are not used as described earlier. These calculations apply to several of the instructions but not to all the instructions. For the Am2910 sequencer all of the propagation delays are around 80 to 85ns; while for the Am2911/Am29811A combination, the propagation delays range from about 80ns to 100ns, depending on the instruction. It should be noted that certain other instructions such as push and conditional load counter should be evaluated to determine the speed at which they can be executed. The last two instructions shown in Table 5 are for jumps where the output enable of the field supplying the address to the D inputs of the microprogram sequencers are controlled by either the Am2910 or Am29811A. Notice that for Am2910 configuration, the jump map represents the longest propagation delay path and is 103ns typical. Also, for the Am2911/Am29811A combination, the jump map instruction also represents the longest propagation delay path and is 109ns typical. It is not the purpose of this exercise to show every possible propagation delay path; but rather, to show the reader the technique for computing propagation delays such that any design can be evaluated and the worst case past derived. Even here, not all of the worst case numbers shown in Table 5 have been derived in Figures 7 and 8. This was done intentionally and is left as an exercise for the student. If the Am2909 or Am2911 and the Am29811A are combined into microprogram sequencers of either 8 bits in width or 16 bits in width, the calculations need only be modified slightly to determine the microcycle times. Obviously, if two Am2911s are used, the worst case propagation delay paths do not change. However, if four Am2911s are used, the carry path will become the longer propagation delay path on several of the computations. This may be offset however since larger microprogram PROMs may be used if 64K of microcode is actually being addressed or high power buffers may be placed between the Am2911 outputs and the microprogram memory to provide sufficient drive for such a large microprogram store. In addition, the Am2909 and Am2911 may be used without the Am29811A where the user wishes to generate a special purpose instruction set or very high speed control of the internal multiplexer and push pop stack. In some, designs as much as 25 to 30ns, typical, can be removed from the longest propagation delay paths of the design by using high speed Schottky SSI. While this has not been the typical case, some designers have used it to provide a performance improvement not achievable with a standard Schottky condition code multiplexer and the Am29811A next address control unit. ### **APPLICATIONS** It should be understood that the microprogram state machine built using either the Am2910 or the Am2911/29811A represents a general purpose state machine controller. Applications for this type of microprogrammed control include uses in minicomputers, communications, instrumentation, controllers and peripherals as well as special purpose processors. Typically, the microprogrammed approach provides a more structured organization to the design and allows the design engineer the greatest flexibility in implementation. It is important to understand that microprogrammed machines need not be part of a typical minicomputer type structure. That is, a general purpose minicomputer usually has a machine instruction set that is totally different from its microprogram instruction control. As such, it is essential that the designer new to computer design and microprogram design understand the difference between a machine instruction and a microprogram instruction. This differentiation is shown in Figure 10 where a typical 16-bit machine level instruction is demonstrated as compared with a typical microprogram instruction. The machine level instruction usually consists of 16 bits and in this example, these bits are used to provide the op code, source register definition and destination register definition. The microprogram instruction on the other hand usually consists of anywhere from 32 to 128 bits in a typical minicomputer type design. Here, the bits are used to control the elemental functions of a machine such as the Am2910 instruction control and condition code multiplexer, the Am2903 source, ALU function and destination control and so forth. For purposes of this explanation, let us assume that the machine level instruction is available to the machine programmer while the microprogram TABLE 5. SUMMARY OF LONGEST AC PATHS FOR MICROPROGRAM SEQUENCERS. | Instruction | Am2910 | Am2911<br>Am29811A | Comments | | | | |---------------------|--------|--------------------|-------------------------------------------------------|--|--|--| | Continue | 61 | 64 | The fastest instruction. Assumes sequential continues | | | | | Instruction Execute | 84 | 88 | If the MAP and PL outputs are not used. | | | | | Jump Map (no OE) | 83 | 78 | | | | | | Jump PL (No OE) | 78 | 101 | | | | | | Jump Map (via OE) | 103 | 109 | If the MAP and PL outputs | | | | | Jump PL (via OE) | 98 | 104 | are used. | | | | Figure 10. Understanding Machine and Microprogram Instructions. instruction is not available to the machine programmer at the assembly language level. Let it suffice to say that this assumption is not necessarily valid in machines being designed today. Perhaps one of the most typical applications of the microprogrammed computer control unit state machine design is as the controller for a minicomputer. Here, the function of the microprogrammed controller is to fetch and execute machine level instructions. The flow required to perform this function is depicted in Figure 11 which should be representative for all general purpose type machines. Figure 11 shows that after initialization, the computer control unit simply fetches machine instructions, decodes these instructions and then fetches the required operands such that the original instruction can be executed. This cycle of fetching and executing instructions is performed without end. Such things as hardware halts or resets are ignored and should be assumed to only cause re-initialization. Once the flow of a typical computer control unit is understood, it is possible to evaluate a number of architectures using the Am2910 or Am2911/Am29811A such that the flow diagram of Figure 11 can be implemented. ### STATE MACHINE ARCHITECTURES After a machine instruction is fetched from memory, it is normally placed in the machine instruction register as described in Figure 6. Then the op code portion of the instruction is decoded so that a sequence of microinstructions in the microprogram memory can be selected for execution. Each microinstruction is fetched and its contents placed in the pipeline register as shown in Figure 6 for execution. While the architecture of Figure 6 is recommended and has been used throughout the preceding portion of this chapter, it should be understood that a number of architectures are possible using these microprogram sequencers. The normal flow in fetching microinstructions is to determine the address of the next microinstruction, fetch the contents at that address and set up this data at the input of the pipeline register such that it can be clocked into the pipeline register for execution. If we assume that a clock is being used to clock the pipeline register, the Am2910, the machine instruction register and the Am2903 microprocessor bit slices, it is possible to define a number of computer control unit designs where the relationship between the clock edges is different. There seem to be a minimum of seven different architectures that can be defined based on placing registers in the appropriate signal paths and storing data on the low-to-high transition of the Figure 11. Computer Control Flow Diagram. clock. For purposes of this discussion, we will assume that all clocked devices will operate using the same clock such that changes will occur on the LOW-to-HIGH transition of the clock. While it is possible to use multiphase clocks and tie different clock phases to different devices, that type of system operation will not be described here. In all cases, we will be talking about the flow of signals between LOW-to-HIGH transitions of the clock. Typically, a cycle is started by a clock edge at a device and the signals begin to flow from one device to the next until a set-up time to a clock edge results. Then, the next microinstruction is executed in exactly the same manner. There are three different identifiable types of microinstruction sequences where only one register is in the signal flow loop. The first of these we shall call an Address-Based microinstruction cycle. It usually starts with the address of a microprogram memory word being stored in a register by the clock. This address has been determined by the previous microinstruction. This address then accesses the microprogram memory to fetch its contents which are presented at its outputs to control the Arithmetic Logic Unit and the results of the Arithmetic Logic Unit function may be used to determine the next address selected that will be stored in this microprogram address register. This is shown as Figure 12a. The second type of microprogram architecture is called Instruction-Based. Here, the register is placed at the output of the microprogram memory as shown in Figure 12b. Again, the cycle consists of executing the microinstruction in the ALU; perhaps using the results of the operation to determine the address of the next microinstruction and then fetching the contents of that microinstruction and setting this new data up at the input to the register. The third basic architecture for microprogram control is called Data-Based. Here, a register is used to hold the status data from the ALU and this is the determining clock point for the cycle. Here, the status register initiates the selection of the next address from which the microprogrammed data is fetched and this microprogram instruction is used to execute a new function in the ALU thereby setting up the results for the status register. This scheme is shown in Figure 12c. Note that this scheme requires an additional register at the output of the microprogram memory to hold a portion of the microprogram instruction for controlling the condition code multiplexer and Am2910 instruction set. These primitive architectures for microprogrammed control demonstrate the three points at which a register can be placed to provide a start and an end for the microcycle. In a general sense, each of these three architectures is one level pipelined. This, however, is not the definition normally associated with pipelining of microprogram control. If combinations of the above described architectures are implemented, an improvement in performance will be realized. In each of the three architectures thus described (address-based, instruction-based, and data-based), all of the signal paths are in series and must be transcended before a microcycle can be completed. They are quite easy to program, however, since all of the tasks are completed in the loop before proceeding to the next microinstruction. As stated earlier, these tend to be the slowest of the possible architectures for microprogram control. This disadvantage can be overcome by using a technique referred to as pipelining in microprogram control. In a pipeline architecture, we overlap the fetch of the next microinstruction while we are executing the current microinstruction. This is achieved by inserting additional registers in the overall path such that we can hold the signals step-by-step. There are three possible combinations of the above mentioned architectures that can be utilized in microprogram control. These are address-instruction-based, address-data-based, and instruction-data-based. While each of these represent two stages of pipelining, we normally refer to these as the pipelined architectures. These are shown in Figure 12d, 12e and 12f. It is the instruction-data based architecture that is recommended for the Am2910 and provides the overall best trade-off in cost versus performance. The last possible architecture using registers in the signal path is a combination of all three architectures and is called address-instruction-data-based microprogram control and is shown in Figure 12g. Here, three stages of pipeline are involved and we normally refer to this as two-level pipelined archiecture. Needless to say, if no pipelining were involved at all, we would have a ring oscillator. Figure 12. Standard Microprogram Control Architectures. ### (c) Data Based Am2910 CLOCK A MICROPROGRAM MEMORY I (A) REGISTER I (A-1) Am2901A ALU S (A-1) MPR-481 (d) Instruction-Data Based (e) Instruction-Address Based MAP CLOCK Am2910 Am2910 CLOCK A+1 A+2 REGISTER MICROPROGRAM MEMORY A+1 I (A+1) MICROPROGRAM MEMORY PIPELINE REGISTER I (A) I (A+1) REGISTER STATUS REGISTER S(A-1) S (A) MPR-482 MPR-483 Shaded Lines Show Required Signal Flow to Complete a Microcycle: Determine Address, Fetch Instruction and Execute. Figure 12. Standard Microprogram Control Architectures (Cont.). Figure 12. Standard Microprogram Control Architectures (Cont.). The advantage of the instruction-data-based architecture is that the address and contents of the next microinstruction are being fetched while the current microinstruction in the pipeline register (Figure 6) is being executed. This allows a shorter microcycle since the microprogram memory fetch and ALU execution can be operated in parallel. The results of this type operation are demonstrated in Figure 13 where we see a typical timing diagram of the microprogram execution of the address-data-based instruction architecture. It should be noted that when the computational aspects of a microinstruction are not completed in the same microcycle, they obviously cannot be used to determine the address of another microcycle until the computation has been completed and stored in the status register. Thus, this pipelined architecture offers significant speed improvement except in the case of certain conditional jumps. In other words, the conditional jump may not use the status register information of the immediately preceding microinstruction because the computation is just being performed. For this architecture, the conditional jump fetch must be executed on the cycle after the status register contains the proper execution results. This can be seen by studying Figure 13. In most microprogram designs this is not a disadvantage because other housekeeping and ALU operations can be performed while the address of the next microinstruction is being determined using the current contents of the status register. While it is not directly pertinent to the discussion at this time, let us point out that the Am2904 has been designed such that the machine architect can utilize both instruction-data-based architecture as well as instruction-based architecture if no housekeeping is required. Thus, the Am2910 and Am2904 can be used in a variable architecture cycle to achieve maximum performance for the machine. Figure 13. Timing Diagram of Microprogram Execution. Figure 14. Typical Am2910 Microprogram Control Unit. ### The Am2910 in Computer Control A general state machine design using the Am2910 is shown in Figure 14. Here, all three output enables are used to advantage in order to control the mapping PROM, pipeline register and vector PROM in this design. This design is very straightforward and in fact is identical to that shown earlier. One area that should not be overlooked is that of initializing the Am2910 at power up. One technique for accomplishing this is to use a pipeline register with a clear input to provide all LOWs to the instruction inputs of the Am2910. This will cause a reset of the stack in the Am2910 and force the outputs to the zero word and microcode which can be used for the initialization routine. Typically, power up will result in the firing of a timer which can be connected to the clear input of the register. Figure 15 shows the technique for initializing the Am2910 using this method. One advantage of the Am2909 when compared to either the Am2910 or Am2911 is the OR inputs to the microprogram address field. These OR inputs allow two, four, eight or 16-way branching for each device if proper control is used. This control can be accomplished using the Am29803A, 16-way branch control unit. A typical computer control unit using the Am2909, Am2911, Am29803A and Am29811A is shown in Figure 16. In this example, the least significant microprogram control sequencer is an Am2909 and the two more significant sequencers are Am2911s. Figure 15. Initializing the Am2910. Figure 16. A High Performance Microprogram Controller Using the Am2909, Am29811A and Am29803A. ### DETAILED DESCRIPTION OF THE Am2911 AND Am29811A IN A COMPUTER CONTROL UNIT The detailed connection diagram of a straight-forward computer control unit is shown in Figure 17. This design features all of the next address control functions described previously and a few features have also been added. Referring to Figure 17, the instruction register consists of two Am25LS377 Eight-Bit Registers with Clock Enable. These registers are designated as U1 and U2 and provide ability to selectively load a 16-bit instruction. This particular design assumes that the instruction word consists of an eight-bit op code as well as eight bits of other data. Therefore, the op code is decoded using three 256-word by 4-bit PROMs. The Am29761 has been selected for this function and is shown in Figure 17 as U3, U4 and U5. The basic control function for the microprogram memory is provided by the Am2911s. In this design, three Am2911s (U6, U7, and U8) are used so that up to 4K words of microprogram memory can be addressed. The microprogram memory can consist of PROMs, ROMs, or RAMs, depending on the particular design and the point of its development. This particular design shows the capability of a 64-bit microword; however, the actual number of bits used will vary from design to design. The pipeline register associated with the computer control unit consists of five integrated circuits designated U16, U17, U18, U19 and U20. One of the features of the architecture depicted in Figure 17 is the event counter shown as U9, U10 and U11. This event counter consists of three Am25LS163s connected as a 12-bit counter. The counter can be parallel loaded with a 12-bit word from pipeline registers U18, U19 and U20. The multiplexer and D-type flip-flop (U21 and U22) at the counter overflow output (U9) is present to improve system cycle time and will be described in detail later. This design also features a 16-input condition code multiplexer using two Am74S251s, which are designated U12 and U14. Condition code polarity control capability has been added to the design by using an Am74S158 Two-Input Multiplexer designated as U13. The W outputs and Y outputs from U12 and U14 have been connected together but only one set of outputs will be enabled at a time via the three-state control signal designated as $\mathsf{R}_{20}$ and $\overline{\mathsf{R}_{20}}.$ Since the Y output is inverting and the W output is non-inverting, the two-input multiplexer, U13, can be used to select the test condition as either inverting or non-inverting. This allows the test input on the Am29811A Next Address Control Unit, U15, to execute conditional instructions on either the inverted or non-inverted polarity of the test signal. For example, a CONDITIONAL BRANCH may be performed on either carry set or carry reset. Likewise, the same CONDITIONAL BRANCH might be performed on either the sign bit as a logic one or the sign bit as a logic zero. Note that the Am29811A Next Address Control Unit has eight outputs. Four outputs to control the Am2911's So, S<sub>1</sub>, PUP and FE inputs. Two outputs to control the three-state enables of the devices connected to the D inputs, i.e., a map enable (MAP E) to select the mapping PROMs and a pipeline enable (PL E) to enable the three-state Am2918 outputs which make up a 12-bit wide branch address field. The remaining two Am29811A outputs are for loading and enabling the Am25LS163 counters. CNT ENABLE from the Am29811A is active-LOW while the Am25LS163 counter requires an active-HIGH enable, therefore CNT ENABLE from the Am29811A is passed through one section of the Two-Input Multiplexer (U13) for inversion. An alternative counter, the Am25LS169, has enable as active-LOW; therefore, this inversion through U13 is not required. At this point, a discussion of the typical operation of this computer control unit is in order. First, bits 0-11 of the microprogram memory output word, are connected to the pipeline register designated U18, U19 and U20. The Am2918 has been selected for this portion of the pipeline register because of its continuous outputs and three-state outputs. The three-state outputs are connected to the D inputs of the Am2911 to provide a branch address whenever needed. These 12 bits are designated BR<sub>0</sub>-BR<sub>11</sub>. The Q outputs of these same Am2918s are designated R<sub>0</sub>-R<sub>11</sub> and are connected to the parallel load input of the Am25LS163 Counters. Thus, the counter can be loaded with any value between 0 and 4,095. Many designs will take advantage of R<sub>0</sub>-R<sub>11</sub> and use it as a general purpose field whenever the counter is not being loaded or a jump pipeline is not being performed. Using a microprogram memory field for more than one function (branch address and counter load value in this example) is called FOR-MATTING and will be covered in greater detail later. The other two devices in the pipeline register shown on the architecture of Figure 17 are U16 and U17. First, U17 receives four bits (12, 13, 14 and 15) from the microprogram memory to provide four-bit instruction field to the Am29811A. This four-bit field, designated R<sub>12</sub>-R<sub>15</sub>, provides the actual next address control instruction for the computer control unit. R<sub>16</sub> is the polarity control bit for the test input and is connected to the select input of the Am74S158 Two-Input Multiplexer. When R<sub>16</sub> is LOW, the signal at the Am29811A test input will be inverted, but when R<sub>16</sub> is HIGH, the test input will be non-inverted. The Am74S175 has been used as part of the pipeline register (U16) because it has both inverting and non-inverting outputs. Signals $R_{17},\,R_{18}$ and $R_{19}$ are used to control the One-of-Eight Multiplexer (U12 and U14) A, B and C inputs. Pipeline register output $R_{20}$ and $\overline{R_{20}}$ are used to enable either the U12 outputs or the U14 outputs such that a one-of-sixteen multiplexer function is implemented. In this design, the TEST 0 input of U14 is connected to ground. This provides a convenient path for converting any of the conditional instructions to non-conditional instructions. That is, any of the conditional instructions can be executed unconditionally by selecting the TEST 0 input which is connected to ground and forcing the polarity control to either the inverting or non-inverting condition. This allows the execution of unconditional JUMP, unconditional JUMP-TO-SUBROUTINE, and unconditional RETURN-FROM-SUBROUTINE instructions. Bit 21 from the microprogram memory utilizes a flip-flop in U17 as part of the pipeline register. This output, $R_{21}$ , is used as the enable input to the instruction register. Needless to say, other techniques for encoding this enable function in a formatted field could be provided. # A HIGH PERFORMANCE COMPUTER CONTROL UNIT USING THE Am2909 AND Am29803A The high performance CCU (Figure 18) is of a similar basic design as the previously described CCU. The major differences are, referring to Figure 18, the addition of an extended enable control (U16), a vector input (U24 and U25), and an Am29803A 16-way Branch Control Unit (U23). These performance enhancements are more related to function than to actual circuit speed. The use of these enhancements by the microprogram provides greater flexibility in controlling a machine's environment, and can reduce the microinstruction count required to perform a particular task, which has the effect of increasing overall system throughput. In describing this high performance CCU design, those sections which remain unchanged from the previous description (Figure 17), will not be covered again. This includes the mapping PROMs, sequencer, Am29811A, counter, condition test inputs and associated polarity control, and the pipeline register. The areas that will be covered are: extended enable control (U16), Vector inputs (U24 and U25), and the Am29803A 16-way Branch Control Unit (U23). ### **Extended Enable Control** Extended enable control is accomplished via an Am74S139 dual two-to-four line decoder in conjunction with the Am29811A next address control unit. In Figure 17, PL E and MAP E of the Am29811A were connected directly to the components that they are to control (pipeline registers and mapping PROMs, respectively). Likewise, CNT LOAD and CNT ENABLE are connected directly to the counters that they control (with the exception that CNT ENABLE requires inversion when using Am25LS163 counters). In Figure 18, PL E, MAP E, CNT LOAD and CNT ENABLE go to the inputs of the Am74S139 two-to-four line decoder (U16). When either PLE or MAPE is LOW, then either 2Y1 or 2Y2 of U16 is LOW and either the pipeline branch address registers or mapping PROMs are enabled. If both PL E and MAP E are HIGH, then output 2Y<sub>3</sub> of U16 is LOW enabling the threestate outputs of U24 and U25 which are alternate microprogram starting address decoders (alternate mapping PROMs), and called VECTOR INPUT in this design. Likewise, CNT LOAD and CNT ENABLE follow the same rules, enabling the counter to load or count via 1Y1 and 1Y2 of U16. ### Vector Input The "Vector Input" provides the system designer with a powerful next starting address control. For example, one possible use might be as an interrupt vector. For instance, use the "Interrupt Request" output of an Am2914 Vectored Priority Interrupt Controller (or group of Am2914s) as an input to one of the conditional test inputs of multiplexers (U12 or U14). Then connect the Am2914 Vector Out lines to the vector mapping PROMs (Vector input U24 and U25). The microprogram then could, at the appro- priate time, test for a pending interrupt and if present, jump in microprogram memory directly to the routine which handles the specific interrupt as requested via the Am2914 Vector Output lines. This routine will take the proper steps to preserve the status of the interrupt system, and then will service the interrupt. This is one of many possible uses for the Vector Input. Other possible uses include both hardware and software "TRAP" routines and so forth. As can be seen, the design presented here uses the Vector Enable line (output 2Y<sub>3</sub> or U16) to enable an alternate starting address input at the Am2911. This, however, does not preclude the use of other devices in place of mapping PROMs as the D-input vector source. It should be understood that this does not accomplish a "microinterrupt" function in that it is not a random possibility. Instead a microprogrammed test is made and an alternate microroutine is performed. A true "microprogram interrupt" is one that could occur at any microinstruction. The Am2910 does not handle this case internally. ### Am29803A 16-Way Branch Control Unit The Am29803A provides 16-way branch control when used in conjunction with the Am2909 bipolar microprocessor sequencer, and is shown as U23 in Figure 18 with its pipeline register U22. The Am29803A has four TEST-inputs, four INSTRUCTION-inputs, four OR-outputs, and an enable control. The four OR-outputs connect directly to the Am2909 OR-inputs (U8 in Figure 18). The four INSTRUCTION-inputs to the Am29803A provide control over the TEST-inputs and OR-outputs, and are provided by the microprogram via the pipeline register U22 (Figure 18). Basically, the INSTRUCTION-inputs $(I_0-I_3)$ provide sixteen instructions $(0-F_{16})$ which can select sixteen possible combinations of the TEST-inputs and provide a specific output on the OR-outputs depending upon the state of the inputs being tested. (The subscript 16 refers to basic 16.) All possible combinations of instruction-inputs, TEST-inputs and OR-outputs are shown in Figure 19. Note that instruction zero does not test any inputs (a disable instruction). Instructions 1, 2, 4 and 8 test one input and can cause a branch to one of two words. Instructions 3, 5, 6, 9, 10 and 12 test two inputs and can jump to one of four words (a 4-word page). Instructions 7, 11, 13 and 14 test three inputs and can jump on an eight word page. Instruction number 15 tests all four inputs and the result can jump to any word on a sixteen word page. ### USING THE Am29803A In the architecture of Figure 18, the Am29803A allows 2-way, 4-way, 8-way or 16-way branching as determined by selectable combinations of the TEST-inputs. Referring to Figure 19, the ZERO instruction (all instruction bits LOW) inhibits the testing of any TEST-inputs, thus providing LOW OR-outputs. Any single TEST-input selected (T<sub>0</sub>, T<sub>1</sub>, T<sub>2</sub> or T<sub>3</sub>) will result in OR<sub>0</sub> being HIGH or LOW in correspondence with the polarity of the selected TEST-input. Selecting any combination of two TEST inputs results in the outputs OR<sub>0</sub> and/or OR<sub>1</sub> being HIGH or LOW, following a mapped one-to-one relationship, i.e., OR<sub>0</sub> and OR<sub>1</sub> will follow the TEST-inputs, but no matter which pair of TEST-inputs are selected, their HIGH/LOW condition is mapped to the ORo and OR1 outputs. Likewise, selecting any three TEST inputs, will map their HIGH/LOW condition to the OR0, OR1 and OR2 outputs. Selecting all four TEST-inputs, of course, causes a one-toone relationship to exist between the HIGH/LOW conditions of the TEST-inputs and the corresponding OR-outputs. Refer to Figure 19 to verify the relationships between INSTRUCTIONinputs, TEST-input, and OR-output. It is very important that the mapping relationship between these signals be completely understood. When using the Am29803A TEST-OR capability as shown in Figure 18, the microprogrammer must position the applicable microcode within microprogram memory so that the low-order address bits are available for ORing. Sequencer instructions using the Am2909/2911 D-inputs (JRP, JSRP, JP and CJS in particular) are ideally suited for the Am29803A TEST-OR capability. The jump-to-location, available via pipeline BR<sub>0</sub>-BR<sub>11</sub> or the Am2909/2911 register, can contain the address of a branch table. A branch table is merely a sequential series of unconditional jump instructions. The particular jump instruction executed is determined by the low-order address bits; that is, the first jump instruction in a branch table must start at a location in microprogram memory whose low-order address bit (or bits) is zero. If a single Am29803A TEST-input is selected (2-way branching) then only the least significant bit in the beginning branch table address needs to be zero. Two Am29803A TEST-inputs selected (4-way branching) requires that the branch table start on an address with the low-order two bits equal to zero; 8-way branching requires three low-order zero bits, and 16-way branching requires four low-order zero address bits. Understanding this branch control concept is really quite simple. The branch table is located in microprogram memory beginning at a location whose address has sufficient low-order zero bits to accommodate the number of selected Am29803A TEST-inputs. If, for instance, three TESTinputs were selected, the first jump instruction in the branch table must be at an address whose low-order three bits are zero, such as address 0F8<sub>16</sub>. The second jump instruction in the branch table would begin in microprogram memory address 0F9<sub>16</sub>. The third jump at location 0FA<sub>16</sub>, the fourth at 0FB<sub>16</sub>, etc. Through all eight locations (0F8<sub>16</sub>-0FF<sub>16</sub>). Assume the following pipeline instruction (referring to Figure 18): (1) U22 selects three Am29803A TEST-inputs, (2) U18 instructs the Am29811A Next Address Controller to select the Am2909/2911 D-inputs, (3) U16 enables the pipeline branch address as the D source, and (4) U19, U20 and U21 supplies the address 0F8<sub>16</sub> as the branch address. The Am29803A TEST-inputs will be ORed into the low-order three bit positions, thus providing a jump entry into the branch table indexed by the value of the OR bits. Each instruction in the branch table is usually a jump instruction, which allows the selection of a particular microcode routine determined by the value presented at the Am29803A TEST-inputs. These jump instructions are the first instruction of the particular sequence. There are, of course, many other ways to use the Am29803A 16-way Branch Control Unit. The microprogram memory address supplied via an Am2909 sequencer can be modified by the Am29803A 16-way Branch Control Unit. Remember, however, that the microcode associated with this address modification relies on certain address bits being zero, therefore this microcode is not arbitrarily relocatable. The above discussion describes using the D-input and branching to provide low-order zeroes to use the OR inputs. Through proper design, the Register, PC Counter, or File can be used equally well. # THE COMPLETE COMPUTER CONTROL UNIT USING THE Am2910 A detailed connection diagram for a straightforward computer control unit using the Am2910 is shown in Figure 20. This design utilizes the Am25LS377 as U1 and U2 to implement a 16-bit instruction register. The op code outputs from the instruction register drive three Am29761 PROMs to perform the op code decoding function. These are shown in the diagram of Figure 20 as U3, U4 and U5. The Am2910 sequencer (U6) is used to perform the basic microprogram sequencing function. | Function | 13 | 12 | 11 | 10 | Т3 | T <sub>2</sub> | Т1 | T <sub>0</sub> | OR <sub>3</sub> | OR <sub>2</sub> | OR <sub>1</sub> | OR | |------------------------------------------------------------------------|-------|-----|----|------------|------------------|----------------|--------|----------------|-----------------|-----------------|-----------------|-------------| | No Test | L | L | L | L | X | Х | X | Х | L | L | L | L | | Test T <sub>0</sub> | L | L | L | Н | X | X | X | L<br>H | L | L | L | L | | Test T <sub>1</sub> | L | L | Н | L | X | × | L | X | L | L | L | L<br>H | | | | | | | X | X | L | L | L | L | L | L | | Test T <sub>0</sub> & T <sub>1</sub> | L | L | Н | Н | ××× | ××× | H | H<br>L<br>H | L | L | H | L | | Test T <sub>2</sub> | L | н | L | L | X | L | X | X | L | L | L | L | | | | | | | X | H<br>L | X | X | L | L | L | H<br>L | | Test T <sub>0</sub> & T <sub>2</sub> | L | Н | L | Н | X | L<br>H | × | H | L | L | L | H | | | | | | 3 101 | X | H<br>L | X<br>L | H<br>X | L | L | H<br>L | H | | Test T <sub>1</sub> & T <sub>2</sub> | L | Н | Н | L | X<br>X | L | H | X | Ĺ | Ĺ | Ĺ<br>H | H | | | 2.00 | | | The R | X | Н | Н | X | L | L | Н | Н | | | | | | | X | L | L | H | L | L | L | H | | Test T <sub>0</sub> , T <sub>1</sub> & T <sub>2</sub> | L | н | н | н | X<br>X<br>X<br>X | L | H | H | L | L | H | H | | 0, 1, 2, 2 | 148 | | | | × | Н | L | H | L | H | L | L | | | | | | | × | H | Н | H | L | H | H | L | | Test T.3 | Н | L | L | L | L | × | × | × | L | L | L | L<br>H | | | | | | | L | X | X | L | L<br>L | L | L | L | | Test T <sub>0</sub> & T <sub>3</sub> | Н | L | L | Н | Н | × | × | L<br>H | Ĺ | Ĺ | Н | L | | | 100 | | | 8.37 | L | | L | X | L | L | L | L | | Test T <sub>1</sub> & T <sub>3</sub> | Н | L | Н | L | H | ×<br>×<br>× | H | X | L | L | H | H | | | | | | | H | X | H<br>L | X<br>L | L | L | H<br>L | H | | | | | | | Ł | × | L<br>H | H | L | Ĺ | L<br>H | H | | Test T <sub>0</sub> , T <sub>1</sub> & T <sub>3</sub> | н | L | Н | Н | L | X | H | H | L | L | H | H | | | | | | | Н | × | L | H | L | Н | L | Н | | | | | | | Н | × | Н | Н | L | Н | H | H | | Test T <sub>2</sub> & T <sub>3</sub> | н | н | L | L | L | H | × | × | L | L | L | L | | 2 0 | | | | _ | H | H | × | × | L | L | H | L | | | STEEL | | | | L | L | × | L | L | L | L | L | | Total To. To. 9. To | 9.5.3 | | | | L | H | × | L<br>H | L | L | H | L | | Test T <sub>0</sub> , T <sub>2</sub> & T <sub>3</sub> | Н | Н | L | Н | H | L<br>L | × | L | Ĺ | H | L | L | | | | | | | Н | H | X | L | L | H | H<br>H | H<br>L<br>H | | | | 150 | | | L | L | L | X | L | L | L | L | | | | | | 100 | Ľ | H | H | X | L | L | H | H | | Test T <sub>1</sub> , T <sub>2</sub> & T <sub>3</sub> | Н | Н | Н | L | L<br>H | H | H | .X<br>X | L | L<br>H | H | H | | | | | | | H | H | H | X | L | H | L<br>H | H | | | | | | A STATE OF | H | H | H<br>L | X<br>L | L | Н | Н | H | | | | | | | Ĺ | Ĺ | L | H | Ė | L | L | H | | | | | | | L | L | Н | Н | L | L | H | H | | | | | | | L | H | L | H | L | H<br>H | L | H | | Test T <sub>0</sub> , T <sub>1</sub> , T <sub>2</sub> & T <sub>3</sub> | н | Н | ц | н | L | H | Н | H | L | H | H | H | | | - | п | Н | н | H | L | L | L<br>H | Н | L | L | L | | | | | | | H | L | H | L | H | Ĺ | H | Ë | | | | | | | H | H | Ĺ | L | H | H | L | L | | | | | | 200 | H | H | HH | L | Н | H | H | H | L = LOW, H = HIGH, X = Don't care Figure 19. Function Table. A 16 input condition code multiplexer function is provided by using two Am2922s as U7 and U8. These devices allow one of sixteen inputs to be tested and the polarity of the test can also be determined. The pipeline register consists of U9, U10, U11, U12 and U13. These devices are edge triggered D type registers and have been selected to provide unique functions as required depending on their bit positions in the pipeline register. An Am74S175 was selected for U9 because both a true and complement output were desired to provide control to the condition code multiplexer three state enables. An Am74S174 register was selected as U10 because it provides a clear input for initializing the Am2910 microprogram sequencer. Three Am2918s were selected for U11, U12 and U13 because they have a three state output that can be used to provide the branch address field to the D inputs of the Am2910 and they also have a set of outputs that can be used to provide other control signals via this field when it does not contain a branch address. No specific devices are shown for the microprogram memory as the user should select the desired width and depth depending on his design. ### ANOTHER DESIGN EXAMPLE The Am2909, Am2910, Am2911, Am29811A and Am29803A have been designed to operate in the microprogram sequencing section of any digital state machine. Typically, the examples shown are for performing the computer control unit function of a typical minicomputer class machine. The design engineer should not limit his thinking for the use of these devices simply to that of microprogram sequencing in a computer control unit. These devices can be successfully used in other areas of designing such as memory control, DMA control, interrupt control and special purpose microprogrammed machine architectures. In order to provide an example of a design using these devices in something other than a typical computer control unit, a microprogrammed CRT controller is described in the following. In order to provide some basis for the design of a CRT controller, the requirements of this controller must be spelled out. These are given as follows: - A) Character size: 5 x 7 dot matrix. The character field will be 7 dots by 10 horizontal lines thereby providing ample space for the 5 x 7 character and the intervening space between characters and lines of characters. - B) 80 characters per line. A standard 80 character per line display will be utilized and there will be 18 character periods allowed for horizontal retrace time. - C) 24 lines of characters per frame. This provides a total of 240 visible lines per frame (24 lines of characters by 10 horizontal lines per character). There are a total of 24 lines provided for vertical retrace bringing the total number of lines per frame to 264. - D) Refresh rate: 60 frames per second. Therefore, the horizontal line rate will be 264 x 60 = 15,840Hz. As there are a total of 80+18=98 character periods in a line, the character rate will be $98 \times 15.84=1,552.32$ KHz, and the dot rate will be $7 \times 1.5288=10.86624$ MHz. (Note: No interlace is used.) - E) It is assumed that there is a 2K word deep x 8-bit wide character RAM available to the host computer in which it can write the ASCII equivalent of the characters to be displayed. If scrolling is to be used, the host computer must also write the first visible character's address divided by 16<sub>10</sub> into the Am25LS374 "First Address Register". - F) This CRT controller must generate an 11-bit character address that is used by the 2K word deep character RAM. It must also generate the required video enable signals and the horizontal and vertical blanking signals. ### Principle of Operation A detailed block diagram of the CRT controller is shown in Figure 21. The block diagram shows an interface to an SBC-80/10 data bus, address bus and control bus. The outputs of the CRT controller are connected to a CRT monitor on the block diagram. Otherwise the block diagram shows a straightforward use of the Am2910 and three Am2911s to implement the CRT control function using microprogrammed techniques. The SBC-80/10 was selected for this example since it is well known. A logic diagram of the CRT controller is shown in Figure 22. Three Am29775 512-word x 8-bit registered PROMs are used to contain the 23-bit wide microprogram. While only a minimum number of words are used in the design as shown, many additional words can be used to add various options (as described later). The address for these Am29775 registered PROMs is provided by an Am2910 microprogram sequencer. Three Am2911 sequencers are used to generate the character address for the character RAM. The least significant Am2911 sequencer is connected as a divide by 16 counter. This RAM address is compared with the desired last character address (80 x 24 = 1920) value using an Am25LS2521 8-bit equal to detector. When the last address is detected, it can be sensed at the condition code multiplexer (Am25LS153) that is used to select the condition code for the Am2910 sequencer. The data derived from the 2K word character RAM is decoded by a character generator (6061) in this design and the character output is parallel loaded into an Am25LS23 shift register. This shift register is used to provide the video signal from its $Q_0$ output to eventually drive the display via an Am74S240 buffer. The diagram of Figure 22 depicts an oscillator input source to supply the dot frequency. In this design, a 10.86624MHz oscillator should be connected to this oscillator input point. This oscillator input signal is used to clock the shift register containing the individual dot bits (dot-on or dot-off) and also drives an Am25LS169 counter which divides this frequency by 7 to generate the character rate clock. This character rate clock is used throughout the controller to provide a timing signal for the state machine design. An Am25LS168 decade counter is used to generate the line inputs for the character generator and to count 10 horizontal lines per character space. This counter is clocked by the horizontal blanking signal (HB) and its $\overline{\text{RCO}}$ output is used as one of the condition code multiplexer inputs. The $\overline{\text{RCO}}$ output can be tested to determine when 10 counts have been executed by the counter and it is also used to enable the last address comparator during the 10th horizontal line time. When the host computer accesses the character RAM, the HOST-ACCESS line is pulled LOW. This removes the Am2911 outputs from the character RAM address bus. When this access occurs, improper data may be present at the shift register inputs. Thus, the character generator PROM output is disabled by the HOST-ACCESS signal during this time. When power is applied to this CRT controller or whenever it is reset, the RESET line is driven LOW. This signal is inverted through an Am25LS240 and then disables a part of the pipeline register outputs as well as enabling one half of an Am25LS241. This Am25LS241 inserts LOWs onto the instruction (I) inputs of the Am2910 sequencer. Then, the next character rate clock will force the microprogram address outputs to zero and the microprogram for the CRT controller as shown in Figure 23 will be executed starting at address zero. Figure 21. CRT Controller Block Diagram. ### The Microprogram for the CRT Controller Table 6 shows a complete description of the microprogrammed CRT controller microcode. Execution of these microinstructions is controlled by the Am2910 sequencer. As can be seen in Table 6, several techniques were used in this short microprogram to provide the different counting requirements of this CRT controller. Although only one format (80 characters per line, 24 lines per frame) was shown here, the designer can easily configure his own format by simply changing some constants in the microprogram. As an exercise, the reader is encouraged to find a means to program the CRT controller for different formats. The host computer software could configure the controller format by using an additional register similar to the "First Address Register". This will be discussed in an appendix at the end of this chapter. A complete wiring diagram for the microprogrammed CRT controller is shown in Figure 24. This can be used directly with the interface shown in Appendix A such that the CRT controller can be connected directly to an Am9080A based microprocessor system. Appendix A also depicts the use of a 2K word x 8 bit character RAM as described previously. ### **CRT Controller Timing Considerations** As was discussed earlier, the character clock frequency for the CRT controller is 1,552.32KHz. Thus, it is desirable to calculate the longest path of the design to ensure that none exceed this clock period of 644.1ns. The timing diagrams of Figure 25 depict a number of different paths with the associated propagation delay calculations When all of the timing diagrams of Figure 25 are examined, it will be found that only three show propagation delay times of over 200ns typical. Of these, the worst case is 318ns as shown in Figure 25(i). Since the requirement of the design is to insure that none exceed 644.1ns, we have more than a 2 to 1 margin in the design based on the typicals. Thus, we can see that the design will operate properly even over the full military temperature range and power supply variations based on this analysis. Figure 22. CRT Controller. | ADDR | | Am2910 | | Am2911 | | | | | | | | | | | |-------|-------------|--------|------|--------|----------------|----------------|----|-------|-------|----|----|----|--------|-----------------------------------------------------------------------------------------------------------| | (Hex) | (Hex) Label | 1 | CCEN | MUX | S <sub>1</sub> | S <sub>0</sub> | FE | ZEROH | ZEROL | Cn | НВ | VB | NUM | Comments | | 0 | INIT | CJV | L | 3 | Н | Н | L | Н | L | L | Н | L | X | ;Load first address from Register to 2911's file | | 1 | | LDCT | X | X | L | L | Н | Н | L | L | Н | L | 2310 | ;Load 2910's counter with member of rows/frame - 1 | | 2 | MAIN | CONT | Х | X | Н | L | Н | Н | L | Н | Н | L | X | ;Address supplied by 2911's file | | 3 | | CJP | L | 1 | L | L | Н | Н | н | Н | L | L | s | | | 4 | | CJP | L | 1 | L | L | Н | Н | Н | Н | 1 | L | \$ | | | 5 | | CJP | L | 1 | L | L | Н | н | н | н | L | Ĺ | s | ;One row: 5 x 16 = 80 characters | | 6 | | CJP | L | 1 | L | L | Н | Н | н | н | L | L | S | | | 7 | | CJP | L | 1 | L | L | Н | Н | Н | Н | L | L | \$ | | | 8 | | CJS | L | 0 | L | L | Н | н | н | н | Н | L | TENTH | of tenth (I-a) II | | 9 | | CJS | L | 2 | L | L | Н | н | н | н | | L | LASTA | ;If tenth (last) line of a row: jump to "TENTH" subroutine | | Α | | CJP | L | 1 | L | L | Н | Н | Н | н | | L | \$ | ;If last character: jump to "LASTA" subroutine | | В | | CJP | Н | X | L | L | Н | Н | X | X | | L | MAIN | ;Wait, until horizontal invisible counts done<br>;Then do the Main routine again | | С | TENTH | RPCT | × | x | L | L | L | Н | н | н | Н | L | GOBACK | ;Push next addr on 2911's file: jump to "GOBACK" if not | | D | | CJV | L | 3 | н | Н | L | Н | L | x | Н | н | X | End of Frame | | E | | LDCT | X | Y | L | L | Н | Н | X | Х | | н | 14610 | ;Load 2911's file from First Address Register<br>;Load 2910's counter with number of invisible characters | | F | | PUSH | | | | Ť | | | | | | | | during Vert retrace divided by 16, minus 1 | | 10 | | CJP | L | 3 | L | L | Н | Н | Н | Н | | H- | X | ;Push next PC to 2910's file for double | | 11 | | | L | 1 | L | | Н | Н | | Н | Н | Н | \$ | ;Wait for LS2911 to count 16 | | 12 | | RFCT | X | X | L | _ | Н | Н | | Н | Н | н | X | ;Decrement 2910's counter and jump one line back if = 0 | | 13 | | LDCT | X | X | L | _ | Н | Н | Н | Н | Н | Н | 2310 | ;Load 2910's counter again with number of rows/frame - | | | | CRTN | Н | X | L | L | Н | Н | Н | Н | Н | Н | Х | ;Return from subroutine | | 14 | GOBACK | CRTN | н | X | L | L | Н | Н | Н | н | Н | L | X | ;Return | | 15 | LASTA | CRTN | н | X | X | X | L | L | н | н | н | | x | ;Load zero to 2911's file and return. | Figure 23. Microprogram for the CRT Controller. # TABLE 6. DESCRIPTION OF THE MICROPROGRAM FOR THE CRT CONTROLLER. | Micro-<br>program<br>Address | Order Am2911 | High<br>Order Am2911s | Am2910 | Comments | | |------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | Since ZERO is low, its output will be LOW. The Cn input (from the Pipeline Register) is LOW so that the microprogram incrementer will not increment. | Both S <sub>1</sub> and S <sub>0</sub> are HIGH so that the D inputs will be routed to the Y outputs. These inputs will come from the First Address Register (the Am2910 VECT is LOW). C <sub>n</sub> is LOW (see left column); therefore the microprogram counter will not increment. FE is LOW (and PUP is always HIGH) causing the present output to be pushed on the stack. The character address is already the "First Character Address". | The CJV instruction is selected. Therefore, VECT output will be LOW, enabling the "First Address Register onto the internal 8-bit bus. CCEN is LOW; the MUX is selecting a constant HIGH, and the sequencer will address the next consecutive microprogram address (word 1). | This instruction pushes the "First Character Address" more significant bits onto the Am2911's file, and continues to the next microinstruction. | | | 1 | ZERO and C <sub>n</sub> are still LOW, so no change in this device. | S <sub>1</sub> and S <sub>2</sub> are LOW; thus, the Y outputs will be the current PC, (the same as the Y outputs were in the previous step). C <sub>n</sub> is still LOW, therefore no change will occur in the PC. | LDCT is selected and the number of character-rows per frame minus 1 (23 <sub>10</sub> ) is loaded into the Am2910 register/counter. The sequencer addresses the next microinstruction. | | | | 2<br>"MAIN" | Maintaining ZERO LOW assures the proper starting address. C <sub>n</sub> is HIGH; therefore, the internal PC will be incremented. | With S <sub>1</sub> = HIGH, S <sub>0</sub> = LOW and FE = HIGH, the Am2911 will refer to its internal file (the starting address of this particular character-row) without popping. | The Am2910 will generate the next microprogram address. | This is the starting location for the main loop. | | TABLE 6. DESCRIPTION OF THE MICROPROGRAM FOR THE CRT CONTROLLER (Cont.). | Micro-<br>program<br>Address | Low<br>Order Am2911 | High<br>Order Am2911s | Am2910 | Comments | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | This Am2911 now counts up using its PC incrementer. At the final count (moving from $F_{16}$ to 0) its $C_{n+4}$ output will be HIGH. | Initially these two Am2911s will not change their Y outputs since their C <sub>n</sub> input is LOW. However, when the C <sub>n</sub> input goes HIGH, the internal PC will increment | With the MUX selecting the $C_{n+4}$ output from the least significant Am2911 slice, the CC input to the Am2910 sequencer will be LOW until the Am2911 counts 16. $\overline{CC}$ = LOW will cause the next microprogram address to be the pipeline register contents; this is also the current microprogram address (word 3). When $C_{n+4}$ goes HIGH, $\overline{CC}$ will go HIGH and together with $\overline{CCEN}$ = LOW, will force the Am2910 to address the next consecutive microprogram address (4). | This microstep will be executed 16 times. (Note that 80 = 5 x 16. | | 4<br>through<br>7 | Same as 3. | Same aş 3. | Same as 3, except that at each address, the current micro-program address is written. | The microprogram itself is used as a counter in this application since the count is only 5, the microprogram is relatively short versus the memory's depth and this is a convenient means to economize on chip count. | | 8 | Continues to count (note that it enters this line with an output of zero). | Since C <sub>n</sub> is LOW (see left column) no change occurs in these devices. Note that the Y outputs contain the more significant bits of the address of the first character of the next character row. | The MUX selects the Am25LS168 ten-line-counters RCO as the condition code input to the Am2910 (CC). If the line count is less than 10, CC will be HIGH and the next microinstruction will be addressed. If the tenth line of a character row is executed, CC will be LOW and a JUMP-TO-SUB-ROUTINE to an address, supplied by the pipeline register ("TENTH") will be executed. | We are now at the end of a TV line. Therefore, the Horizontal Blanking Signal (HB) is HIGH. The least significant Am2911 slice now counts the invisible characters during the horizontal retrace. | | 9 | Continues to count through the internal PC incrementer. | No change. | The MUX now selects the Last Address Comparator output for $\overline{CC}$ . If the current more significant bits of the characteraddress coincide with the last address + 1 (1920 <sub>10</sub> /16) a subroutine call will be performed to "LASTA". Otherwise, the microprogram will continue consecutively. | Note that 80 characters/row and 24 rows/frame requires a 1920 <sub>10</sub> word memory. When the last memory location (1920 <sub>10</sub> ) is read out, the scan wibegin at 0. | | А | Continues to count. At count 15, C <sub>n+4</sub> goes HIGH. | No change until C <sub>n</sub> goes HIGH, then count. | Same as at address 3. | Waiting for the least significant<br>Am2911 to count to 15. This<br>microstep will be executed<br>as many times as necessary<br>to accomplish this. | | В | It doesn't matter what this device does at this microstep because at the next microstep it will receive LOW on its ZERO input. | No change. | Unconditionally (CCEN = HIGH) steers the microprogram to the address supplied by the pipeline register ("MAIN" = 2). | Performing a JUMP to the beginning of the main-loop (address 2). | | C<br>"TENTH" | Continues to count. | No change. | If internal counter is equal to zero, it means that 24 character rows were already displayed and we are at the bottom of the CRT display. A vertical retrace period is needed and the microprogram will continue sequentially. If the counter is not yet zero, we do not need to execute the vertical retrace routine and the next address will be supplied by the piperegister ("GOBACK" = 14 <sub>16</sub> ) while the internal counter is decremented. | The decision whether the bottom of the CRT (End of Frame) is reached or not is made internally in the Am2910, using its counter. | TABLE 6. DESCRIPTION OF THE MICROPROGRAM FOR THE CRT CONTROLLER (Cont.). | Micro-<br>program<br>Address | Low<br>Order Am2911 | High<br>Order Am2911s | Am2910 | Comments | |------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D | $\overline{\text{ZERO}} = \text{LOW}, \text{ therefore, output Y} = 0. \text{ This is necessary to assure that } C_{n+4} \text{ is LOW}.$ | Same as at address 0. | Same as at address 0. | As we are at the End of Frame<br>the "First-Address-Register"<br>contents (enabled by the<br>Am2910's VECT output) is<br>pushed onto the Am2911's file<br>Note that the Vertical Blanking<br>Signal (VB) goes HIGH. | | E | Same as at address B. | No change. | The internal counter is loaded with 146 <sub>10</sub> , supplied by the pipeline register. The next consecutive microstep is addressed. | (146 <sub>10</sub> + 1) x 16 <sub>10</sub> = 2352 <sub>10</sub> equals the number of characte periods during vertical retrace. Loading 2352 <sub>10</sub> directly into th Am2910's counter would required bits. Usingthis scheme we reduce the microprogram width | | F | Counts. | No change. | With CCEN = LOW and CC = HIGH (supplied from a constant HIGH by the MUX), the next address (10 <sub>16</sub> ) will be pushed onto the Am2910 file, the counter will not be affected and the next consecutive microstep will be addressed. | This is a preparatory step for the 2 step "Vertical Retrace" double nested loop. | | 10 <sub>H</sub> | Counts. When final count is reached, $C_{n+4}=HIGH.$ No change with $C_n=LOW;$ increments with $C_n=HIGH.$ This has no practical affect as the HB signal is HIGH, and at the beginning of the next visible line, the correct address will be fetched from the file (address 2). | | The MUX supplies the C <sub>n+4</sub> output of the less significant Am2911 slice to the Am2910 $\overline{CC}$ input. While this signal is low, the Am2910 will select the pipeline register as the source of the next microinstruction address. The current address (10 <sub>H</sub> ) being written there, this instruction will be executed until $\overline{CC}$ goes HIGH. Then the next consecutive instruction will be selected through the Am2910 internal PC. | Again, this is a possible way to dwell on a certain microstep waiting a condition to change its status (like address 3 throug 7). This is the internal loop of a double-nested loop system. | | 11 <sub>H</sub> | Counts. | No change. | If the final count has been reached, the next micro-instruction will be addressed and the internal stack will be popped (adjusted). Otherwise, the next microinstruction address will be the one residing on the top of the stack (which is 10 <sub>16</sub> ). | This is the external loop of the double-nested loop system, which counts the vertical retractinterval. By adding a single microinstruction the chip count was reduced. | | 12 <sub>H</sub> | Counts. | No change. | Same as at address 1. | Reinitializes the Am2910 intern<br>counter with the number of<br>character rows per frame. | | 13 <sub>H</sub> | Counts. | No change. | Unconditional return from subroutine. (CCEN = HIGH). | End of "TENTH" subroutine at End of Frame (with vertical retrace). | | 14 <sub>H</sub><br>GOBACK'' | Counts. | No change. | Unconditional return from subroutine. | End of "TENTH" subroutine without vertical retrace. | | 15 <sub>H</sub><br>"LASTA" | Counts. | Pushes zero into file. | Unconditional return from subroutine. | A one-line subroutine to reini-<br>tialize character address to zero | a) Figure 25. Figure 25. (Cont.) Figure 25. (Cont.) Figure 25. (Cont.) MPR-498 Figure 25. (Cont.) #### SUMMARY The Am2910 provides a powerful solution to the microprogram memory sequence control problem. The Am2910 is a fixed instruction set, 12-bit wide microprogram sequencer. In addition, the Am2909, Am2911, Am29811A and Am29803A provide another solution to the microprogram sequencing problem. These devices are bit slice oriented and provide more potential flexibility to the microprogram sequencing solution. All of these devices are particularly well suited for the high performance computer control unit and structured state machine designs using overlap fetch of the next microinstruction — also referred to as instruction-data-based microprogram architecture. These Am2900 family microprogram control devices offer the highest performance LSI solution to the problem of microprogram control. They provide a number of conditional-branch source addresses as well as conditional jump-to-subroutine and conditional-return instructions. In addition, several techniques for timed and untimed looping are provided such that loops from one to several microinstructions can be executed. All of the devices described in this chapter are competitively priced and currently available. In addition, all of these devices are available with specifications guaranteed over the full commercial temperature range and power supply tolerance as well as the full military temperature range and power supply tolerance. All of these devices undergo 100% reliability assurance testing in compliance with MIL-STD-883. #### APPENDIX A Figure A1 shows the logic diagram of an interface circuit used to connect the microprogrammed CRT controller to any Am9080A type processor. Sixteen address-lines, eight data lines, a memory-read, a memory write and an I/O write signal are assumed to be used in an active LOW polarity. An Am25LS2521 8-bit comparator is used to decode the addresses of the 2K by 8 character memory. This memory can be placed anywhere in the memory space in increments of 2K by using 5 DIP-switches. The comparator is enabled by the presence of either the $\overline{\text{MMR}}$ or the $\overline{\text{MMW}}$ signal. The output of this comparator is the $\overline{\text{HOST ACCESS}}$ signal. The HOST ACCESS signal enables the two Am25LS240 buffers which connect the processor address bus to the character mem- ory address bus. It also enables one half of an Am25LS241 buffer transferring the $\overline{\text{MMR}}$ or $\overline{\text{MMR}}$ active LOW signal to the proper data buffer enable (Am25LS240's) and to the $\overline{\text{WE}}$ pins of the four Am9114 memories in case of a memory write operation. The $\overline{\text{CS}}$ of the other two memories are driven by A10 while the $\overline{\text{CS}}$ of the other two memories are driven by A10, thus forming a 2K by 8 memory space. An Am25LS2521 8-bit comparator is enabled by the $\overline{I/OW}$ control line. If n matches the settings of the DIP switches at the B inputs of the comparator, an OUT n instruction will write the data into the Am25LS374 "First Address Register". Figure A2 shows the complete wiring diagram of this interface circuit. Figure A1. CRT Controller. #### APPENDIX B #### General A software emulation of the CRT controller was written in BASIC-E and run on the System 29 support processor. Figure B1 is a printout of this program. #### **Notations** For reference purposes, each clock pulse (CP) in the program is numbered. The clocks are character-rate clocks. A subscript "10" signifies that this variable belongs to the Am2910 (e.g. R10 = the contents of the Am2910 Register Counter) and similarly a subscript 11 signifies the Am2911 dependent variables (e.g. Y11 – the Y outputs of the two more significant Am2911s). Usually the normal function names were used though for the active LOW functions the bar was deleted for simplicity. A 0 signifies always a LOW and 1 signifies HIGH. Other abbreviations used in the program: MA = Microprogram Address (Y output of the Am2910) CA = Character Address PC = Program Counter (internal) R = Register (internal) F = File (internal) SP = Stack Pointer (internal) TENC = The Am25LS168 decade counter L4B = The 4 least significant bits of CA (the Y outputs of the less significant Am2911 CN = Carry-in into the less significant Am2911 CN4 = Carry-out from the less significant Am2911 CN4 = Carry-in to the next significant Am2911 I10 = The Am2910 instruction HB = Horizontal Blanking signal (active HIGH) VB = Vertical Blanking signal (active HIGH) CPM = Maximum Clock Pulse (at which the program stops) #### Description The different groups and subroutines of the emulation program are as follows: (See Figure B1). <1000 series: The microcode. Subroutine 50 is the Am25LS168 decade counter clocking routine. TENTH is the RCO output of this device. 1000 series: This is essentially the Am2910 emulation. Note the definition of the two functions FNFAIL and FNPASS at the beginning of the program, compare to the Am2910 instruction definitions in its data sheet. 2000 series: The Am25LS153 multiplexer emulation. 2500 series: The less significant Am2911 emulation. Note that the only input to this device is ZEROL. CN and the internal PC (called L4B) are controlled in the CLOCK Subroutine (4000 series). 3000 series: The two more significant Am2911's emulation, $S_0$ and $S_1$ are treated as a single number (ranging from 0 through 3) and denoted by S11. 4000 series: The Clocking routine. 5000 series: The main emulation routine. It includes the Am25LS2521 comparator routine and checks the Clock Pulse against CPM to determine end of run. 5500 series: Emulation parameter setup (initialization). The starting and ending CP numbers, MA, TENC, R10 and VECTOR (The "First Address Register") can be set. 6000 series: Sets up the print-out parameters 7000 series: Printout subroutine 9000 series: Sets the program mode: RUN, PRINT or QUIT (return to CP/M) The emulation was exercised to evaluate fifteen different performance aspects of the CRT Controller. The results indicated that in all cases, the design operated as desired. ``` REM REV=12 PRINT REV 9000 REM HEADER PRINT PRINT PRINT " PRINT PRINT PRINT " A MICROPROGRAMMED CRT CONTROLLER EMULATION" PRINT PRINT PRINT PRINT BY MOSHE M. SHAVIT" PRINT " PRINT * ADVANCED MICRO DEVICES* PRINT " FEBRUARY 27, 1978" PRINT PRINT REM DIM F10(6) FNFAIL=CCEN=0 AND CC=1 DEF DEF FNPASS=CCEN=1 OR CC=0 REM REM REM GOTO 6000 REM PROGRAM PARAMETERS (REMOVED REV 6) REM REM <--REV 6 REM 9100 PRINT PRINT PRINT INPUT "R-UN, P-RINT OR Q-UIT "; MODES IF LEN(MODE$)=0 THEN GOTO 9100 MODE=ASC(MODE$)-79 IF MODE<1 OR MODE > 3 \ THEN PRINT MODES; " IS INVALID":\ GOTO 9100 ON MODE GOTO 9110,9120,9130 REM 9120 RETURN REM 9130 REM RUN PRINT INPUT "PUT RESULTS ON FILE (O IF DIRECT PRINTOUT) = ":WFILE$ PRINT "CP= ";CP; "MA= ";MA; "VECTOR= "; VECTOR; \ "CPM= ";CPM; "ROW= ";24-R10 INPUT "INITIALIZE (Y OR N; CP, MA=O IF N)";S$ IF S$="Y" \ THEN GOSUB 5500 \ REM INIT. CP=0 : MA=0 ELSE IF WFILE$= "O" \ THEN GOTO 6010 \ REM DIRECT PRINTOUT ELSE FILE WFILES : GOTO 5000 REM MAIN REM 9110 REM PRINT PRINT INPUT "GET RESULTS FROM FILE=":RFILE$ FILE RFILES REM 6000 REM PRINT PARAMETERS PRINT PRINT "OUTPUT FORMATS:" 6010 ``` Figure B1. ``` A=CP AND CA ONLY" PRINT " PRINT " B=CP, CA, HB, VB, MA" PRINT . C=CP, CA, MA, TENC, R10" PRINT " D=ALL" PRINT INPUT "FORMAT="; FORMATS IF LEN(FORMAT$)=0 THEN GOTO 6010 IF ASC(FORMAT$)<65 OR ASC(FORMAT$)>68 \ THEN PRINT FORMATS; " IS ILLEGAL" :\ GOTO 6010 PRINT REM 6020 REM IF WFILES NE "O" \ THEN CONTROLS="A" :\ GOTO 6030 PRINT "CLOCK CONTROL" PRINT " A=CONTINOUS* PRINT " B=STEP" INPUT "CONTROL="; CONTROLS IF LEN(CONTROL$)=0 THEN GOTO 6020 IF ASC(CONTROL$)<65 OR ASC(CONTROL$)>66 \ THEN PRINT CONTROLS: " IS ILLEGAL" :\ GOTO 6020 PRINT REM PRINT "OUTPUT CONTROL" 6030 A=AT EACH CF." PRINT " B=AT EVERY N-TH CP" PRINT " C=MANUAL CONTROL" PRINT " D=STARTING AT CPS AT EVERY CP" E=STARTING AT CPS AT EVERY N-TH CP" PRINT * INPUT "OUTPUT=":OUTPUT$ IF LEN(OUTPUT$)=0 THEN GOTO 6030 IF ASC(OUTPUT$)<65 OR ASC(OUTPUT$)>69 \ PRINT OUTPUTS; " IS ILLEGAL" :\ THEN GOTO 6030 O.CTL=ASC(OUTPUT$)-64 ON O.CTL GOTO 6090,6032,6090,6034,6036 INPUT "N=";N 6032 M=O GOTO 6090 INPUT "CPS= ";CPS 6034 GOTO 6090 INPUT "CPS= ";CPS 6036 INPUT "N= ":N M=0 GOTO 6090 REM 6090 FORMAT = ASC(FORMAT$)-64 ON FORMAT GOSUB 6190,6300,6200,6100 IF WFILE$="0" THEN GOTO 5000 REM MAIN REM 6900 PRINT IF END #1 THEN 6910 FOR I=1 TO 2 STEP 0 REM DO UNTIL END OF FILE READ #1; CP,R10,F1,SP10,PC10,CA,MUX,CC,CCEN,MA,TENC, CN4,F11,HB,VB F10(SP10)=F1 GOSUB 7000 REM PRINT (REV 7) GOSUB 5200 REM ESCAPE IF S=155 THEN PRINT:PRINT "ABORTED AT ";CP : GOTO 6910 ``` Figure B1 (Cont.) NEXT I ``` REM 6910 CLOSE 1 REM PRINTER PAGE EJECT (REV 7) OUT 100,12 GOTO 9100 REM 6100 PRINT PRINT "CP", "R10", "F10", "SP10", "PC10" PRINT "CA", "MUX", "CC", "CCEN", "MA" PRINT "TENC", "CN4", "F11", "HB", "VB" FRINT 6190 RETURN REM 6200 PRINT PRINT "CLOCK", "CHAR.ADDR", "2910 REG.", "LINE CNTR.", "NEXT MA" RETURN REM 6300 PRINT PRINT "CLOCK", "CHAR.ADDR", "H.BLANKING", "V.BLANKING", "NEXT MA" RETURN REM REM PRINT SUBROUTINE REM 7000 ON O.CTL GOTO 7010,7005,7002,7003,7004 REM 7002 INPUT "OUTPUT (Y OR N)";S$ IF S$="Y" \ GOTO 7010 \ THEN ELSE RETURN REM IF CP<CPS THEN RETURN ELSE GOTO 7010 7003 REM 7004 IF CPKCPS THEN RETURN ELSE GOTO 7005 REM 7005 M=M+1 IF M=N THEN M=O : GOTO 7010 ELSE RETURN REM 7010 ON FORMAT GOTO 7100,7200,7300,7400 REM 7100 PRINT "CP= ";CP, "CA= ";CA RETURN REM 7200 IF HB=O THEN HB$="L" ELSE HB$=" H" IF VB=0 THEN VB$="L" ELSE VB$=" H" PRINT CP, CA, HB$, VB$, MA RETURN REM 7300 PRINT PRINT CP, CA, R10, TENC, MA RETURN REM 7400 PRINT PRINT CP,R10,F10(SP10),SP10,PC10 PRINT CA, MUX, CC, CCEN, MA PRINT TENC, CN4, F11, HB, VB RETURN REM REM 5000 REM MAIN ROUTINE REM GOSUB 4000 REM CLOCK FETCH MICROCODE REM ON MA+1 GOSUB 30,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22 2911L GOSUB 2500 REM GOSUB 3000 REM 2911H Figure B1 (Cont.) ``` ``` CA=Y11*16+L4B REM CHARACTER ADDRESS REM COMPARATOR NEXT IF Y11=120 AND TENTH=0 \ REM REV 8 THEN COMP=0 \ ELSE COMP'=1 GOSUB 2000 REM MUX GOSUB 1000 REM 2910 REM REV 6 IF WFILE$="0" THEN GOSUB 7000 \ REM DIRECT PRINTOUT ELSE PRINT #1;CP,R10,F10(SP10),SP10,PC10,CA,MUX,\ CC, CCEN, MA, TENC, CN4, F11, HB, VB IF CONTROLS="B" THEN INPUT SS REM SINGLE STEP REM CHECK END OF RUN GOSUB 5200 ESCAPE (REV 7) REM IF S=155 THEN PRINT:PRINT "ABORTED AT ";CP : GOTO 5100 IF CP<CPM THEN GOTO 5000 REM REPEAT MAIN REM 5100 IF WFILE$ NE "O" THEN CLOSE (1) OUT 100,12 REM PRINTER PAGE EJECT (REV 7) GOTO 9100 REM REM 5200 SUB REV 7 5200 ESCAPE SUBROUTINE S=INP(97) S=INT(S/2) S=S/2-INT(S/2) IF S NE O THEN S = INP(96) RETURN REM 5500 INITIALIZATION REM PRINT SP10=1 PRINT "MA= ":MA 5505 INPUT "NEW MA (Y OR N)":S$ IF S$="N" THEN GOTO 5510 INPUT "MA=(0<=MA<22)":MA MA=INT(MA) IF MA<0 OR MA>21 \ PRINT MA: " IS ILLEGAL" :\ THEN GOTO 5505 IF MA=0 THEN TENC=0 : HB=1 : TENTH=1 REM 5510 PRINT PRINT "VECTOR= "; VECTOR INPUT "NEW VECTOR (Y OR N)";S$ 5515 IF S$="N" THEN GOTO 5520 INPUT "VECTOR=(0<=VECTOR<120)":VECTOR VECTOR=INT(VECTOR) IF VECTOR<0 OR VECTOR>119 \ PRINT VECTOR; " IS ILLEGAL" :\ THEN GOTO 5515 REM 5520 PRINT PRINT "CP= ";CP INPUT "NEW CP (Y OR N) ";S$ IF S$="N" THEN GOTO 5530 INPUT "CP(>=0)= ":CP 5525 CP=INT(CP) IF CP<0 THEN PRINT CP; " IS ILLEGAL" : GOTO 5525 REM 5530 PRINT PRINT "CPM= ":CPM INPUT "NEW CPM (Y OR N)":S$ 5535 IF S$="N" THEN GOTO 5540 ``` ``` INPUT "CPM=(CP+1<CPM)";CPM CPM=INT(CPM) IF CPM<CP+1 THEN PRINT CPM;" IS ILLEGAL"; "CP= "; CP : GOTO 5535 REM 5540 PRINT PRINT "TENC= "; TENC IF MA=0 THEN GOTO 5550 5545 INPUT "NEW TENC (Y OR N)";S$ IF S$="N" THEN GOTO 5550 INPUT "TENC=(O<=TENC<10)":TENC TENC=INT(TENC) IF TENC<0 OR TENC>9 \ THEN PRINT TENC: " IS ILLEGAL" :\ GOTO 5545 IF TENC=9 THEN TENTH=0 ELSE TENTH=1 REM 5550 PRINT PRINT "R10= ":R10 5555 INPUT "NEW R10 (Y OR N)":S$ IF S$="N" THEN GOTO 5560 INPUT "R10 (0<=R10<25)=";R10 R10=INT(R10) IF R10<0 OR R10>24 THEN PRINT R10; " IS ILLEGAL" : GOTO 5555 REM 5560 REM RETURN REM REM REM 30 I10=6 CCEN=0 MUX=3 S11 = 3 FE=0 ZEROH=1 ZEROL=0 CN=O HB=1 REM REV 2 VB=0 PL=0 RETURN REM 2 I10=12 S11=0 FE=1. ZEROH=1 ZEROL=0 CN=0 HB=1 REM REV 2 VB=0 PL=23 RETURN REM I10=14 3 S11=2 FE=1 ZEROH=1 ZEROL=0 CN=1. HB=1 REM REV 2 VB=0 RETURN REM 4 I10=3 ``` Figure B1 (Cont.) | | CCEN=0 | | REM | | | |------------|----------------|-------------------|-----------|--------------|----------------| | | MUX=1 | | 9 | I10=1 | | | | S11=0 | | | CCEN=0 | | | | FE=1 | | | MUX=0 | | | | ZEROH=1 | | | S11=0 | | | | ZEROL=1 | | | FE=1 | | | | CN=1 | | | ZEROH=1 | | | | HB=0 | | | ZEROL=1 | | | | VB=0 | | | CN=1 | | | | PL=3 | | | GOSUB 50 REM | TENC | | | RETURN | | | VB=0 | | | REM | IVE LOUIS | | | PL=12 | | | 5 | I10=3 | | | RETURN | | | J | CCEN=0 | | REM | | | | | MUX=1 | | 10 | I10=1 | | | | S11=0 | | | CCEN=0 | | | | FE=1 | | | MUX=2 | | | | ZEROH=1 | | | S11=0 | | | | ZEROL=1 | | | FE=1. | | | | CN=1 | | | ZEROH=1 | | | | HB≔O | | | ZEROL=1 | | | | VB=0 | | | CN=1 | | | | F'L=4 | | | GOSUB 50 | | | | RETURN | | | VB=0 | | | REM | | | | PL=21 | | | 6 | I10=3 | | nex | RETURN | | | | CCEN=0 | | REM<br>11 | I10=3 | | | | MUX=1 | | TT | CCEN=0 | | | | S11=0 | | | MUX=1 | | | | FE=1 | | | S11=0 | | | | ZEROH=1 | | | FE=1 | | | | ZEROL=1 | | | ZEROH=1 | | | | CN=1. | | | ZEROL=1 | | | | HB==O | | | CN=1 | | | | VB=0 | | | GOSUB 50 | | | | PL=5 | | | VB=0 | | | m. m. s. d | RETURN | | | P'L=10 | | | REM<br>7 | T10-7 | | | RETURN | | | / | I10=3 | | REM | | | | | CCEN=0 | | 12 | I10=3 | | | | MUX=1<br>S11=0 | | | CCEN=1 | | | | FE=1 | | | S11=0 | | | | ZEROH=1 | | | FE=1. | | | | ZEROL=1 | | | ZEROH=1 | | | | CN=1 | | | GOSUB 50 | | | | HB=0 | | | VB=0 | | | | VB=0 | | | PL=2 | | | | P'L=6 | | | RETURN | | | | RETURN | | REM | | | | REM | WE 10111 | | 13 | I10=9 | | | 8 | I10=3 | | | S11=0 | P. P. I. I. F. | | - | CCEN=0 | | | FE=0 REM | REV 5 | | | MUX=1 | | | ZEROH=1 | | | | S11=0 | | | ZEROL=1 | | | | FE=1 | | | CN=1 | | | | ZEROH=1 | | | GOSUB 50 | | | | ZEROL=1 | | | VB=0 | | | | CN=1 | | | PL=20 | | | | HB=0 | | REM | RETURN | | | | VB=0 | | 14 | I10=6 | | | | P'L=7 | | 7.4 | CCEN=0 | | | | RETURN | | | MUX=3 | | | | | Figure R1 (Cont.) | | S11=3 | | | | | Figure B1 (Cont.) | | | | ``` ZEROH=1 ZEROL=0 GOSUB 50 VB=1 RETURN REM 15 I10=12 S11=0 REM REV 10 FE=1 REV 10 REM ZEROH=1 REMOVED REV 10 REM ZEROH=1 REM GOSUB 50 VB=1 PL=119 RETURN REM 16 I10=4 CCEN=0 MUX=3 S11=0 FE=1 ZEROH=1 ZEROL=1 CN=1 GOSUB 50 VB=1 RETURN REM 17 I10=3 CCEN=0 MUX=1 S11=0 FE=1 ZEROH=1 ZEROL=1 CN=1 GOSUB 50 VB=1 PL=16 RETURN REM I10=8 18 S11=0 FE=1 ZEROH=1 ZEROL=1 CN=1 GOSUB 50 VB=1 RETURN REM 19 I10=12 S11=0 FE=1 ZEROH=1 ZEROL=1 CN=1 GOSUB 50 VB=1 PL=23 RETURN REM 20 I10=10 ``` REM FE=0 REV 10 ``` CCEN=1 S11=0 FE=1 ZEROH=1 ZEROL=1 CN=1 GOSUB 50 VB=1 RETURN REM 21 I10=10 CCEN=1 S11=0 FE=1 ZEROH=1 ZEROL=1 CN=1 GOSUB 50 VB=0 RETURN REM 22 I10=10 CCEN=1 FE=0 REM REV 9 ZEROH=0 ZEROL=1 REM REV 9 CN=1 GOSUB 50 VB=0 RETURN REM 50 REM TEN-LINE-COUNTER CLOCKING SUBROUTINE IF HB=1 THEN RETURN HB=1 TENC=TENC+1 IF TENC=9 THEN TENTH=0 ELSE TENTH=1 IF TENC=10 THEN TENC=0 RETURN REM PUSH AND POP SUBROUTINES REMOVED REV 3 1000 REM 2910 INSTRUCTIONS SUBROUTINE ON I10+1 GOTO 1100,1110,1120,1130,1140,1150,1160,1170,1180, \ 1190,1200,1210,1220,1230,1240,1250 REM 1100 REM JZ MA=0 REM 2910 Y SP10=0 REM 2910 STACK POINTER (=0 REV 3) RETURN REM 1110 REM CJS IF FNFAIL \ THEN MA=PC10 \ MA=PL :\ ELSE PUSH=1 REM REV 3 RETURN REM JMAP 1120 REM PRINT "JMAP NOT PROGRAMMED" RETURN REM 1130 REM CJP IF FNFAIL \ MA=PC10 \ THEN ELSE MA=PL RETURN ``` ``` REM 1140 PUSH REM IF FNPASS THEN R10=PL LOAD COUNTER REM MA=PC10 PUSH=1 REM REV 3 RETURN REM 1150 REM JSRP PRINT "JSRP NOT PROGRAMMED" RETURN REM 1160 REM CJV IF FNFAIL \ THEN MA=PC10 \ ELSE MA=VECTOR RETURN REM 1170 REM JRP IF FNFAIL \ THEN MA=R10 \ ELSE MA=PL RETURN REM 1180 REM RFCT IF R10=0 \ THEN MA=PC10 :\ POF=1 \ ELSE MA=F10(SP10) :\ R10=R10-1 RETURN REM 1190 RPCT REM IF R10=0 \ THEN MA=PC10 \ ELSE MA=PL :\ R10=R10-1 RETURN REM 1200 REM CRTN IF FNFAIL \ THEN MA=PC10 \ ELSE MA=F10(SP10) :\ REM POP=1 REV 3 RETURN REM 1210 REM CJPP PRINT "CJPP NOT PROGRAMMED" RETURN REM 1220 REM LDCT R10=PL. MA=PC10 RETURN REM 1230 REM LOOP IF FNFAIL \ THEN MA=F10(SP10) \ ELSE MA=PC10 :\ POP=1 REM REV 3 RETURN REM 1240 REM CONT MA=PC10 ``` RETURN Figure B1. (Cont.) ``` REM 1250 REM TUB PRINT "TWB NOT PROGRAMMED" RETURN REM REM MUX SUBROUTINE 2000 REM ON MUX+1 GOTO 2100,2200,2300,2400 REM 2100 IF TENTH=0 \ THEN CC=0 \ ELSE CC=1 RETURN REM IF CN4=0 \ 2200 THEN CC=0 \ ELSE CC=1 RETURN REM IF COMP=0 \ 2300 THEN CC=0 / CC=1 ELSE RETURN REM 2400 CC=1 RETURN REM REM LEAST SIGNIFICANT 2911 (2911L) SUBROUTINE 2500 REM IF ZEROL=0 THEN L4B=0 RETURN REM REM REM REM MORE SIGNIFICANT 2911S (2911H) SUBROUTINE 3000 REM ON S11+1 GOSUB 3100,3200,3300,3400 IF ZEROH=0 THEN Y11=0 RETURN REM 3100 Y11=PC11 RETURN REM Y11=R11 3200 RETURN REM 3300 Y11=F11 RETURN REM 3400 IF I10=6 \ Y11=VECTOR \ THEN ELSE Y11=PL RETURN REM REM CLOCK SUBROUTINE 4000 REM REMOVED REV 4 REM PC10=MA+1 IF CN=1 THEN L4B=L4B+1 IF L4B>15 THEN L4B=0 : CN4=1 ELSE CN4=0 IF CN4=1 \ THEN PC11=Y11+1 \ ELSE PC11=Y11 IF FE=0 THEN F11=PC11 <--REV 3 REM ``` | | IF PUSH=1 \ | | |------------|-------------------|---------------------------------------| | | THEN | SP10=SP10+1 :\ | | | | F10(SP10)=PC10 :\ | | | | PUSH=0 | | | IF SP10>4 \ | | | | THEN | PRINT "2910 STACK FULL " :\<br>SF10=3 | | | IF POP=1 \ | | | | THEN | SP10=SP10-1 :\<br>POF=0 | | | IF SP10<0 \ | | | | THEN | PRINT "POP EMPTY FILE? ";CP :\ SP10=0 | | REM | REV 3> | | | | PC10=MA+1 | REM REV 4 | | | CP=CP+1<br>RETURN | | | REM<br>REM | | | | | | | Figure B1 (Cont.) #### APPENDIX C A simple circuit was designed to accommodate five different display formats and also to comply with the European 50Hz TV standard. Figure C1 is the circuit diagram of this additional circuit. The following parameters change when the format is changed: - 1) The number of characters/line. - 2) The number of lines/frame. - The number of characters to display (i.e., the address of the last character). - 4) The line frequency and therefore the dot frequency. The number of characters/line is counted by the least significant Am2911 sequencer via the microcode. Therefore, the microcode can be changed to change the number of characters/line. The number of lines/frame is counted by a constant, loaded into the Am2910 internal counter by the microcode. The microcode can be changed to vary the number of lines/frame. The scan is reinitialized to zero when the last address $\pm 1$ is attained. U<sub>9</sub> (Am25LS2521) detects this address by comparing bits A<sub>4</sub> through A<sub>10</sub> of the character address bus to a constant supplied to its B inputs. A table listing these constants is shown in Figure C1. By setting the DIP switches according to that table, the character scan will reinitialize correctly. The same constant is routed through one half of an Am25LS240 (U24) to the internal data bus. At microprogram address zero, a JUMP MAP instruction enables these outputs thereby putting a starting address on the bus according to the table in Figure C1. The microprogram is shown on Figure C2. | FORMAT | LAST<br>CHAR. ADD. +1 | COMPAR<br>LAST AL | | S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> | MAP<br>ADDRESS | DOT FREQ. (MHz) | |---------|-----------------------|-------------------|-----|-----------------|----------------|----------------|----------------|----------------|-----------------| | 24 x 80 | 1920 | 120D | 78H | Н | Н | Н | Н | 0F0 | 10.86624 | | 24 x 64 | 1536 | 96D | 60H | Н | Н | L | L | 0F3 | 9.09216 | | 24 x 32 | 768 | 48D | 30H | L | Н | Н | L | 0F9 | 5.544 | | 16 x 32 | 512 | 32D | 20H | L | Н | L | L | 0FB | 5.376 | | 16 x 16 | 256 | 16D | 10H | L | L | Н | L | 0FD | 3.65568 | | | | | | A <sub>10</sub> | A <sub>9</sub> | A <sub>8</sub> | A <sub>7</sub> | | | Figure C1. ``` A>TYPE CRT.DEF ; CRT DEFINITION FILE ; BY MOSHE M. SHAVIT ; REV Ø 3/8/78 CRT CONTROLLER -- DEFINITIONS TITLE WORD 24 1 VB#1,23X FE: DEF 1X,1VB#1,22X ZEROH: DEF 2X,2V%:Q#,20X S11: DEF I10: 4X,4VH#,16X DEF CN: DEF 9X,1VB#1,14X ZERCI: 10X,1VB#1,13X DEF VB: DEF 11X,1VB#0,12X EB: DEF 12X,1VB#0,11X DEF CCEN: 13X,1Vb#,10X MUXØ: DEF 14X, B#00,8X MUX1: DEF 14X,B#10,8X 14X,B#01,8X MUX2: DEF MUX3: DEF 14X.B#11.8X PL: DEF 16X.8V%: L: EQU B#0 EQU H: B#1 COUNT: DEF B#1, B#1, B#00, 5X, B#1, B#1, B#0, B#0, 1X, 2X, 8X B#1,B#1,B#00,5X,B#1,B#1,B#0,B#1,1X,2X,8X COUNTE: DEF COUNTY: DEF B#1,B#1,B#00,5X,B#1,B#1,B#1,B#1,1X,2X,8X END A> ``` Figure C2. AMDASM Definition and Assembly Files for the CRT Controller. ``` AMDOS/29 AMDASM MICRO ASSEMBLER, V1.1 CRT CONTROLLER CET CONTROLLER MICROPROGRAM ; BY MOSHE M. SHAVIT ;REV 2 5/3/78 0000 I10 H#2 ; JUMP MAP 24 ROWS 80 CHARACTERS 60 F/S 0001 S2480: I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB 0002 I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & /VB & PL D#23 0003 M2480: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB 0004 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0005 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0006 I10 H#3 & CCEN L & MUX1 & COUNT & PL 0007 110 H#3 & CCEN L & MUX1 & COUNT & PL I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0008 I10 H#1 & CCEN L & MUX0 & COUNTH & PL T2480 0009 110 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA 000B I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ I10 H#3 & CCEN H & S11 0 & FE & ZERCH & HB H & VB & PL M2480 000C 000T T2480: I10 H#9 & S11 Ø & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOP ACK 000E I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / HB H & VB H 110 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#146 000F I10 H#4 & CCEN L & MUX3 & COUNTV 0010 0011 I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ 0012 I10 H#8 & COUNTY I10 H#C & COUNTY & PL D#23 0013 0014 I10 H#A & CCEN H & COUNTY 0015 GOBACK: I10 H#A & CCEN H & COUNTH 0016 LASTA: I10 H#A & CCEN H & FE L & ZERCH L & ZERCL & CN H & HB H & VB 24 ROWS 64 CHARACTERS 60 F/S I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & 0017 S2464: / CN L & HB H & VB 0018 I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & /VB & PL D#23 I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB 0019 M2464: I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 001A ØØ1B 110 H#3 & CCEN L & MUX1 & COUNT & PL $ I10 H#3 & CCEN L & MUX1 & COUNT & PL $ ØØ1 C ØØ1D I10 H#3 & CCEN L & MUX1 & COUNT & PL $ I10 H#1 & CCEN L & MUXØ & COUNTH & PL T2464 001E 001F I10 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ 0020 I10 H#3 & CCEN H & S11 0 & FE & ZEROH & HB H & VB & PL M2464 0021 110 H#9 & S11 Ø & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB 0022 T2464: ACK 0023 I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / HB H & VB H 110 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#122 0024 I10 H#4 & CCEN L & MUX3 & COUNTV 0025 I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ 0026 ``` I10 H#8 & COUNTY 0027 ``` AMDOS/29 AMDASM MICRO ASSEMBLER. V1.1 CRT CONTROLLER I10 H#C & COUNTY & PL D#23 0028 0029 I10 H#A & CCEN H & COUNTY 24 ROWS 32 CHARACTERS 60 F/S 002A S2432: I10 E#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB 110 H#C & S11 Ø & FE & ZEROH & ZEROL L & CN L & HB H & ØØ2B /VB & PL D#23 I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB 002C M2432: I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 002D I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 002E I10 H#1 & CCEN L & MUX0 & COUNTH & PL T2432 002F I10 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA 0030 110 H#3 & CCEN L & MUX1 & COUNTH & PL $ 0031 I10 H#3 & CCEN H & S11 Ø & FE & ZEROH & HB H & VB & PL M2432 0032 I 10 H#9 & S11 0 & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB 0033 T2432: ACK I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & 0034 / HB H & VB H I10 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#74 0035 0036 I10 H#4 & CCEN L & MUX3 & CCUNTV 0037 I10 H#3 & CCEN L & MUX1 & COUNTY & PL $ I10 H#8 & COUNTY 0038 I10 H#C & COUNTY & PL D#23 0039 I10 H#A & CCEN H & COUNTY 003A 16 ROWS 32 CHARACTERS 60 F/S 110 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & 003B S1632: / CN L & HB H & VB I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & 003C /VB & PL D#15 110 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB 003D M1632: I10 H#3 & CCEN L & MUX1 & COUNT & PL $ ØØ3E 003F I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0040 110 H#1 & CCEN L & MUXØ & COUNTH & PL T1632 I10 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA 0041 I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ 0042 0043 I10 H#3 & CCEN H & S11 Ø & FE & ZEROH & HB H & VB & PL M1632 I10 H#9 & S11 0 & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB 0044 T1632: ACK I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & 0045 / HB H & VB H I10 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#250 0046 0047 I10 H#4 & CCEN L & MUX3 & COUNTV I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ 0048 I10 H#8 & COUNTY 0049 084A I10 H#C & COUNTY & PL D#48 004B I 10 H#4 & CCEN L & MUX3 & COUNTY I10 H#3 & CCEN L & MUX1 & COUNTY & PL $ 004C I10 H#8 & COUNTY 004D 004E I10 H#C & COUNTY & PL D#15 ØØ4 F I 10 H#A & CCEN H & COUNTY 16 ROWS 16 CHARACTERS 60 F/S ``` ``` AMDOS/29 AMDASM MICRO ASSEMBLER, V1'.1 CRT CONTROLLER 0050 S1616: I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB 0051 I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & /VB & PL D#15 0052 M1616: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0053 0054 I10 H#1 & CCEN L & MUX0 & COUNTH & PL T1616 0055 I10 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA 0056 I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ I10 H#3 & CCEN H & S11 0 & FE & ZEROH & HB H & VB & PL M1616 0057 0058 T1616: I10 H#9 & S11 0 & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB ACK I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & 0059 / HB H & VB H 005A I10 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#203 ØØ5B I10 H#4 & CCEN L & MUX3 & COUNTY I10 H#3 & CCEN L & MUX1 & COUNTY & PL $ 005C 005D I10 H#8 & COUNTY 005E I10 H#C & COUNTY & PL D#15 005F I10 H#A & CCEN H & COUNTY ØØFØ ORG H#ØFØ ;24*8Ø 00F0 I10 H#3 & CCEN H & PL S2480 00F3 ;24*64 ORG H#ØF3 I10 H#3 & CCEN H & PL S2464 00F3 ØØF9 ORG H#ØF9 ;24*32 00FG I10 H#3 & CCEN H & PL S2432 ØØFB ORG H#ØFB ;16*32 00FB I10 H#3 & CCEN H & PL S1632 00FD ;16*16 ORG H#ØFD I10 .H#3 & CCEN H & PL S1616 00FD ;50 F/S ROUTINES 0100 ORG H#100 24 ROWS 80 CHARACTERS 50 F/S 0100 S2480E: I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & 0101 /VB & PL D#23 0102 M2480E: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB 0103 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0104 I10 H#3 & CCEN L & MUX1 & COUNT & PL 0105 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0106 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0107 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0108 I10 H#1 & CCEN L & MUX0 & COUNTH & PL T2480E 0109 I10 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA 010A I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ I10 H#3 & CCEN H & S11 0 & FE & ZEROH & HB H & VB & PL M2480E Ø10B ``` ACK 010C T2480E: I10 H#9 & S11 0 & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB AMDOS/29 AMDASM MICRO ASSEMBLER, V1.1 CRT CONTROLLER ``` I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZERCH & ZEROL L & Ø10D / HB H & VB H Ø1ØE I10 H#C & S11 Ø & FE & ZEROH & HB H & VB H & PL D#200 ; ITERATES 201 TIMES 010F I10 H#4 & CCEN L & MUX3 & COUNTY 0110 I10 H#3 & CCEN L & MUX1 & COUNTY & PL $ Ø111 I10 H#8 & COUNTV I10 H#C & COUNTY & PL D#239 Ø112 Ø113 I10 H#4 & CCEN L & MUX3 & COUNTV I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ 0114 Ø115 I10 H#8 & COUNTY Ø116 I10 H#C & COUNTV & PL D#23 0117 I10 H#A & CCEN H & COUNTY 24 ROWS 64 CHARACTERS 50 F/S Ø118 S2464E: I1Ø H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & 0119 /VB & PL D#23 Ø11A M2464E: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB Ø11B I10 H#3 & CCEN L & MUX1 & COUNT & PL $ I10 H#3 & CCEN L & MUX1 & COUNT & PL Ø11C 110 H#3 & CCEN L & MUX1 & COUNT & PL $ Ø11D Ø11E I10 H#3 & CCEN L & MUX1 & COUNT & PL $ I10 H#1 & CCEN L & MUX0 & COUNTH & PL T2464E Ø11F 0120 110 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ Ø121 I10 H#3 & CCEN H & S11 Ø & FE & ZEROH & HB H & VB & PL M2464E Ø122 Ø123 T2464E: I10 H#9 & S11 Ø & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB ACK I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & 0124 / HB H & VB H I10 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#200 0125 0126 I10 H#4 & CCEN L & MUX3 & COUNTV 0127 I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ I10 H#8 & COUNTV 0128 0129 I10 H#C & COUNTY & PL D#167 I10 H#4 & CCEN L & MUX3 & COUNTV Ø12A I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ Ø12B Ø120 I10 H#8 & COUNTY Ø12D I10 H#C & COUNTV & PL D#23 Ø12E I10 H#A & CCEN H & COUNTY 24 ROWS 32 CHARACTERS 50 F/S 012F S2432E: 110 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB 0130 I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & /VB & PL D#23 Ø131 M2432E: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB 0132 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ @133 I10 H#3 & CCEN L & MUX1 & COUNT & PL $ I10 H#1 & CCEN L & MUX0 & COUNTH & PL T2432E 0134 0135 110 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA Ø136 I10 H#3 & CCEN L & MUX1 & COUNTH & PL $ ``` ``` AMDOS/29 AMDASM MICRO ASSEMBLER, V1.1 CRT CONTROLLER I10 H#3 & CCEN H & S11 0 & FE & ZEROH & HB H & VB & PL M2432E 0137 Ø138 T2432E: I1Ø H#9 & S11 Ø & FE L & ZEROH & ZEROL & CN H & HB. H & VB & PL GOB ACK Ø139 110 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / HB H & VB H I10 H#C & S11 Ø & FE & ZEROH & HB H & VB H & PL D#224 Ø13A I10 H#4 & CCEN L & MUX3 & COUNTV Ø13B I10 H#3 & CCEN L & MUX1 & COUNTV & PL $ Ø13C Ø13D I10 H#8 & COUNTV Ø13E I10 H#C & COUNTY & PL D#23 Ø13F I10 H#A & CCEN H & COUNTY 16 ROWS 32 CHARACTERS 50 F/S Ø14Ø S1632E: I1Ø H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB I10 H#C & S11 0 & FE & ZEROH & ZEROL L & CN L & HB H & 0141 /VB & PL D#15 0142 M1632E: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0143 I10 H#3 & CCEN L & MUX1 & CCUNT & PL $ 0144 I10 H#1 & CCEN L & MUX0 & COUNTH & PL T1632E 0145 I10 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA 0146 110 H#3 & CCEN L & MUX1 & COUNTH & PL 0147 I10 H#3 & CCEN H & S11 Ø & FE & ZEROH & HB H & VB & PL M1632E 0148 Ø149 T1632E: I1Ø H#9 & S11 Ø & FE L & ZEROH & ZERCL & CN H & HB H & VB & PL GOB ACK I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & Ø14A / HB H & VB H I10 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#250 Ø14B I10 H#4 & CCEN L & MUX3 & COUNTY 014C I 10 H#3 & CCEN L & MUX1 & COUNTV & PL $ Ø14D I10 H#8 & COUNTY 014E Ø14F I10 H#C & COUNTY & PL D#223 ;475 I10 H#4 & CCEN L & MUX3 & COUNTV 0150 I10 H#3 & CCEN L & MUX1 & COUNTY & PL $ 0151 Ø152 I10 H#8 & COUNTY 0153 I10 H#C & COUNTY & PL D#15 0154 I10 H#A & CCEN H & COUNTV 16 ROWS 16 CHARACTERS 50 F/S 0155 S1616E: I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / CN L & HB H & VB I10 H#C & S11 Ø & FE & ZEROH & ZEROL L & CN L & HB H & 0156 /VB & PL D#15 0157 M1616E: I10 H#E & S11 2 & FE & ZEROH & ZEROL L & CN & HB H & VB I10 H#3 & CCEN L & MUX1 & COUNT & PL $ 0158 I10 H#1 & CCEN L & MUX0 & COUNTH & PL T1616E 0159 110 H#1 & CCEN L & MUX2 & COUNTH & PL LASTA Ø15A Ø15B I10 H#3 & CCEN L & MUX1 & COUNTH & PL I10 H#3 & CCEN H & S11 0 & FE & ZEROH & HB H & VB & PL M1616E 015C Ø15D T1616E: I1Ø H#9 & S11 Ø & FE L & ZEROH & ZEROL & CN H & HB H & VB & PL GOB ACK Ø15E I10 H#6 & CCEN L & MUX3 & S11 3 & FE L & ZEROH & ZEROL L & / HB H & VB H Ø15F 110 H#C & S11 0 & FE & ZEROH & HB H & VB H & PL D#200 I10 H#4 & CCEN L & MUX3 & COUNTY Ø16Ø ``` I10 H#3 & CCEN L & MUX1 & COUNTY & PL \$ I10 H#8 & COUNTY Ø161 0162 ``` Ø163 I10 H#C & COUNTY & PL D#121 I10 H#4 & CCEN L & MUX3 & COUNTY 0164 110 H#3 & CCEN L & MUX1 & COUNTY & PL $ Ø165 I10 H#8 & COUNTY Ø166 0167 I10 H#C & COUNTY & PL D#15 I10 H#A & CCEN H & COUNTY Ø168 ;24*80 Ø1FØ ORG H#1FØ I10 H#3 & CCEN H & PL S2480E 01F0 Ø1F3 H#1F3 ;24*64 ORG I10 H#3 & CCEN H & PL S2464E Ø1F3 H#1F9 ;24*32 Ø1F9 ORG I10 H#3 & CCEN H & PL S2432E Ø1F9 Ø1FB ORG H#1FB ;16*32 110 H#3 & CCEN H & PL S1632E Ø1FB Ø1FD ORG H#1FD ;16*16 Ø1FD I10 H#3 & CCEN H & PL S1616E END 0000 XXXX0010XXXXXXXX XXXXXXX 0022 01001001X1101XXX 00010101 0001 01110110X0001011 XXXXXXX 0023 01110110XX011011 XXXXXXXX 0002 11001100X0001XXX 00010111 0024 11001100XXX11XXX 01111010 0003 11101110X1001XXX XXXXXXX 0025 11000100X1111011 XXXXXXX 0026 11000011X1111010 00100110 0027 11001000X1111XXX XXXXXXX 0004 11000011X1100010 00000100 0005 11000011X1100010 00000101 0006 11000011X1100010 00000110 0028 11001100X11111XXX 00010111 0007 11000011X1100010 00000111 0029 11001010X111111XX XXXXXXX 0008 11000011X1100010 00001000 002A 01110110X0001011 XXXXXXX 0009 11000001X1101000 00001101 002B 11001100X0001XXX 00010111 002C 11101110X1001XXX XXXXXXX 000A 11000001X1101001 00010110 000B 11000011X1101010 00001011 002D 11000011X1100010 00101101 000C 11000011XXX011XX 00000011 002E 11000011X1100010 00101110 002F 11000001X1101000 00110011 000D 01001001X1101XXX 00010101 000E 01110110XX011011 XXXXXXX 0030 11000001X1101001 00010110 000F 11001100XXX11XXX 10010010 0031 11000011X1101010 00110001 0032 11000011XXX011XX 00101100 0010 11000100X1111011 XXXXXXX 0033 01001001X1101XXX 00010101 0011 11000011X11111010 00010001 0034 01110110XX011011 XXXXXXX 0012 11001000X1111XXX XXXXXXX 0013 11001100X1111XXX 00010111 0035 11001100XXX11XXX 01001010 0014 11001010X111111XX XXXXXXX 0036 11000100X1111011 XXXXXXX 0015 11001010X11011XX XXXXXXX 0037 11000011X1111010 00110111 0016 00XX1010X11011XX XXXXXXX 0038 11001000X1111XXX XXXXXXX 0039 11001100X1111XXX 00010111 0017 01110110X0001011 XXXXXXX 0018 11001100X0001XXX 00010111 003A 11001010X11111XX XXXXXXX 0019 11101110X1001XXX XXXXXXX 003B 01110110X0001011 XXXXXXX 001A 11000011X1100010 00011010 003C 11001100X0001XXX 00001111 003D 11101110X1001XXX XXXXXXX 001B 11000011X1100010 00011011 001C 11000011X1100010 00011100 003E 11000011X1100010 00111110 001D 11000011X1100010 00011101 003F 11000011X1100010 00111111 001E 11000001X1101000 00100010 0040 11000001X1101000 01000100 001F 11000001X1101001 00010110 0041 11000001X1101001 00010110 0020 11000011X1101010 00100000 0042 11000011X1101010 01000010 0043 11000011XXX011XX 00111101 0021 11000011XXX011XX 00011001 ``` Figure C2 (Cont.) | ~~. | | | | | | | | |------|------------------------|-----------|--|--|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | 0044 | 01001001X1101XXX | 00010101 | | | 011E | 11000011X1100010 0 | 0011110 | | 0045 | 01110110XX011011 | YYYYYYYY | | | 0110 | 11000001X1101000 0<br>11000001X1101001 0 | 04.00044 | | 0046 | 110011007771177 | 11111111 | | | ATTE | 11000001Y1101000 0 | 0100011 | | 2275 | TIMMITMANATIANA | 11111010 | | | 0120 | 11000001X1101001 0 | 0010110 | | 0047 | 11000100X1111011 | XXXXXXXX | | | 0121 | 11000001X1101001 0<br>11000011XX1011XX 0<br>11000011XXX011XX 0<br>01001001X1101XXX 0<br>01110110XX011011 XX<br>11001100XXX11XXX 1<br>11000100XXX11XXX 1<br>110000011X111011 XX<br>11001000XXX11XXX X | 0100001 | | 0048 | 11000011X1111010 | 91991999 | | | 4100 | 110000011111101010 | 0200001 | | 0040 | 11001000X1111XXX | DIDDIDDD | | | 0122 | IIOOOOIIIXXXOIIXX O | 0011010 | | | | YYYYYYY | | | 0123 | @1001001X1101XXX 0 | 0010101 | | ØØ4A | 11001100X11111XXX | 00110000 | | | 0124 | 01110110 YY011011 Y | YYYYYY | | | 11000100X1111011 | YYYYYYY | | | 0100 | A A COLA A CONTRACT TO IT A. | AAAAAA | | 0010 | 1100010011111011 | AAAAAAAA | | | 0125 | 11001100XXX11XXX 1 | 1001000 | | 884C | 11000011X1111010 | 01001100 | | | Ø126 | 11000100X1111011 X | XXXXXXX | | 004D | 11001000X1111XXX | XXXXXXXX | | | 0127 | 11000011 Y1111010 00 | 0100111 | | GG4F | 11001100X11111XXX | 00001111 | | | 24.00 | 11000011X11111010 VI | DIDELLI | | GGAT | 1100110011111111 | DEDELLIT | | | 0128 | 11001000X11111XXX X. | XXXXXXX | | | 11001010X11111XX | XXXXXXXX | | | Ø129 | 11001100X11111XXX 10 | 0100111 | | 0050 | Ø111Ø11ØXØØØ1Ø11 | XXXXXXXX | | | 0124 | 11000100 V1111011 V | AAAAAAA | | 0051 | 11001100X0001XXX | 00001111 | | | 0100 | 11000100XIIIIVII A | | | 0001 | 1100110010001111 | SESSITITI | | | 015B | 11000011X1111010 00 | 0101011 | | 0052 | 11101110X1001XXX | XXXXXXXX | | | Ø12C | 11001000X11111XXX XX | XXXXXXX | | 0053 | 11000011X1100010 | 01010011 | | | 012D | 11001100Y1111YYY 00 | 0010111 | | 0054 | 11000001X1101000 | 01011000 | | | 0405 | AACCACACTALATIAN DE | DETETTI | | 2255 | 11000000171101000 | DIDITODD | | | 012F | TIMMINIMINITY X | XXXXXXX | | 0055 | 11000001X1101001 | 00010110 | | | Ø12F | 01110110X0001011 X | XXXXXXX | | 0056 | 11000011X1101010 | 01010110 | | | 0130 | 11001100100011111 00 | 0010111 | | 0057 | 11000011XXX011XX | 01010010 | | | 0171 | 111011DDRDDDIAK DI | DETETTT | | 0050 | G1 GG1 GG1 V1 1 G1 VVV | 00000000 | | | 0101 | IIINIIINAINNIXXX XX | YYYYYY | | 0000 | 01001001X1101XXX | 00010101 | | | Ø132 | 11000011X1100010 00 | 0110010 | | 0059 | 01110110XX011011 | XXXXXXXX | | | Ø133 | 11000011X1100010 00 | 0110011 | | 005A | 11001100XXX11XXX | 11001011 | | | 0171 | 11000001111100010 01 | 0444000 | | 0050 | 1100011001111111111 | TIPPIPIT | | | 0104 | TIMMMMMIVIIMIMMM MA | 0111000 | | | 11000100X1111011 | YYYYYYY | | | Ø135 | 11000001X1101001 00 | 0010110 | | ØØ5C | | 01011100 | | | 0136 | 11000011X1101010 00 | 0110110 | | 005D | 11001000X1111XXX | YYYYYYY | | | 0170 | 11000011111101010 | 0110110 | | aast | 110011000111111111 | AAAAAAAA | | | 0121 | I I DO DO LI I Y Y Y DI LYY DE | 10001 | | 7500 | 11001100X1111XXX | ODDOTITI | | | 0138 | 01001001X1101XXX 00 | 0010101 | | ØØ5F | 11001010X11111XX | XXXXXXXX | | | Ø139 | 01110110XX011011 XX | XXXXXXX | | 00F0 | XXXXØØ11XXXXX1XX | 000000001 | | | 0171 | 1100110077771177 | 1100000 | | aars | XXXXØØ11XXXXX1XX | 22212111 | | | MCION | TIMMITMMYYYIIYYY II | 1100000 | | DOLO | VVVVANTIVVVVVIIV | DODINIII | | | 013B | 11000100X1111011 XX | XXXXXXX | | 00F9 | XXXX0011XXXXX1XX | 00101010 | | | Ø13C | 11000011X1111010 00 | a1111aa | | 00FB | XXXXØØ11XXXXX1XX | 00111011 | | | 017D | 11001000711111777 | AAAAAA<br>ATTTTE | | GOED | XXXX0011XXXXX1XX | 31313333 | | | DIOD | IIAMIMMAVIIIIIVVV VI | AAAAAAA | | 0010 | VVVVOOTIVVVVVIVV | DIDIDDDD | | | 013E | 11001100X11111XXX 00 | 0010111 | | 0100 | 01110110X0001011 | XXXXXXXX | | | Ø13F | 11001010X11111XX XX | XXXXXXX | | 0101 | 11001100X0001XXX | 00010111 | | | 0110 | 01110110V0001011 V | VVVVVV | | 0102 | 11101110X1001XXX | AAAAAAAA | | | DITE | ATTINITAY AND TATE Y | VVVVVV | | 0102 | 11101110X1001XXX | ΛΛΑΛΛΛΛ | | | 0141 | 11001100X0001XXX 00 | 0001111 | | 0103 | 11000011X1100010 | 00000011 | | | 0142 | 11101110X1001XXX XX | XXXXXXX | | 0104 | 11000011X1100010 | 00000100 | | | 0113 | 1100001171100010 01 | 1000011 | | | 11000011X1100010 | 00000101 | | | 0140 | I I D D D I I Y I I D D D I D D D D D D | TABBBIT | | | | DESERVED | | | 0144 | 11000011X1100010 01 | 1000100 | | 0106 | 11000011X1100010 | 00000110 | | | 0145 | 11000001X1101000 01 | 1001001 | | 0107 | 11000011X1100010 | 00000111 | | | 0146 | 11000001 V1101001 00 | 2010110 | | 0108 | 11000001X1101000 | 000001100 | | | DITO | TIESSESTATISTS SE | DATATIA | | | | DDDDTIDD | | | 0147 | 11000011X1101010 01 | 1000111 | | 0109 | 11000001X1101001 | 00010110 | | | 0148 | 11000011XXX011XX 01 | 1000010 | | Ø10A | 11000011X1101010 | 00001010 | | | 0140 | 01001001 Y 1 101 Y YY 00 | 2010101 | | | 11000011XXX011XX | 00000010 | | | 0111 | 01110110V 011101VV 05 | ANTELE | | | | 00000010 | | | NITH | STITETISTY VETTELL YY | YYYYYY | | | Ø1001001X1101XXX | 00010101 | | | Ø14B | 11001100XXX11XXX 11 | 1111010 | | Ø10D | 01110110XX011011 | XXXXXXXX | | | Ø14C | 11000100X1111011 YY | XXXXXXX | | | 11001100XXX11XXX | 11001000 | | | 011D | 1100001171111011 | 1001101 | | | | 11001000 | | | 0141 | TIMMMITYTITIMIM MI | 1001101 | | 010F | 11000100X1111011 | XXXXXXXX | | | 014E | 110001000XXX11XXX 11 11000100XX1111011 X: 11000100XX1111011 X: 11001100XX1111XXX 11 11001100X0001011 X: 11001100X0001XXX 11 1101110X0001011 X: 11001110X0001011 X: 11001110X10010 00 110000011X1101001 00 110000011X1101001 00 110000011X1101001 00 110000011X1101001 00 110000011X1101001 00 11000001X1101XXX 01 11001100XXX11XXX 11 11001100XXX11XXX 11 11001100XXX11XXX 11 11001100XXX11XXX 11 11001100XX1111XXX 00 1110110XX011011 X: 11001100XX1111XXX 00 1110110XX011011 X: 11001100XX1111XXX 00 1110110XX011011 X: 11001100XX1111XXX 00 1110110XX011011 X: 11001100XX1111XXX 00 1110110XX011011 X: 11001100XX1111XXX 00 1110110XX001011 X: 11001100XX1111XXX 00 1110110XX001011 X: 11001100XX1111XXX 00 1110110XX0011011 X: 110000011X1100010 01 110000011X1100010 01 110000011X1100010 01 110000011X1101010 1100000011X1101010 01 110000011X1101010 01 110000011X1101010 01 1100000011X1101010 01 110000011X1101010 01 110000011X1101010 01 1100000011X1101010 01 1100000011X1101010 01 1100000011X110010 01 110000011X110010 110000011X110000000000 | XXXXXXX | | 0110 | 11000011X1111010 | aaalaaaa | | | 014F | 11001100X1111XXX 11 | 1011111 | | | 11001000X1111XXX | AAAAAAA | | | 0150 | 11000100V1111011 VV | AAAAAA | | | | λλλλλλλ | | | 0151 | TIPOPIONY IIIINII YY | | | | 11001100X1111XXX | 11101111 | | | 0151 | 11000011X1111010 01 | 1010001 | | 0113 | 11000100X1111011 | XXXXXXXX | | | Ø152 | 11001000X1111XXX XX | XXXXXXX | | | 11000011X1111010 | 00010100 | | | 0153 | 11001100X1111XXX 00 | 3001111 | | | | DESTRIBE | | | DIOC | TIPPTIPPD VITITION DE | 20011111 | | | 11001000X1111XXX | | | | | 11001010X111111XX XX | | | Ø116 | 11001100X1111XXX | 00010111 | | | Ø155 | Ø111Ø11ØXØØØ1Ø11 XX | XXXXXXX | | 0117 | 11001010X11111XX | XXXXXXXX | | | | 11001100X0001XXX 00 | | | 0110 | Ø1110110X0001011 | AAAAAAAA | | | | | | | | | | | | | 11101110X1001XXX XX | | | | 11001100X0001XXX | | | | Ø158 | 11000011X1100010 01 | 1011000 | | | 11101110X1001XXX | | | | | | 1011101 | | | 11000011X1100010 | | | | | | | | | | | | | | 11000001X1101001 00 | | | | 11000011X1100010 | | | | Ø15B | 11000011X1101010 01 | 1011011 | | Ø11D | 11000011X1100010 | 00011101 | | | | 11000011XXX011XX 01 | | | | | | | | | | | # AMTOS/29 AMDASM MICRO ASSEMBLER, V1.1 CRT CONTROLLER 015D 01001001X1101XXX 00010101 015E 01110110XX011011 XXXXXXX 015F 11001100XXX11XXX 11001000 0160 11000100X1111011 XXXXXXX 0161 11000100X1111XXX XXXXXXXX 0163 11001000X1111XXX XXXXXXXX 0164 11000100X1111XXX XXXXXXXX 0165 11000100X1111XXX XXXXXXXX 0165 11000100X1111XXX XXXXXXXX 0167 11001100X1111XXX XXXXXXXX 0168 11001010X1111XXX 0000111 0169 XXXX0011XXXXXXXX 0000000 01F3 XXXX0011XXXXXXXX 0001000 01F9 XXXX0011XXXXXXXX 0100000 01FD XXXX0011XXXXXXXX 01010101 ## ENTRY POINTS ## SYMBOLS | GOBACK | 0015 | |--------|------| | H | 0001 | | L | 0000 | | LASTA | 0016 | | M1€16 | 0052 | | M1616E | 0157 | | M1632 | 003D | | M1632E | 0142 | | M2432 | 002C | | M2432E | 0131 | | M2464 | 0019 | | M2464E | Ø11A | | M2480 | 0003 | | M248ØE | 0102 | | S1616 | 0050 | | S1616E | @155 | | S1€32 | 003B | | S1632E | 0140 | | S2432 | 002A | | S2432E | Ø12F | | \$2464 | 0017 | | S2464E | 0118 | | \$2480 | 0001 | | S248@E | 0100 | | T1616 | 0058 | | T1616E | Ø15D | | T1632 | 0044 | | T1632E | 0149 | | T2432 | 0033 | | T2432E | 0138 | | T2464 | 0022 | | T2464E | 0123 | | T2480 | 000D | | T2480E | Ø10C | | | | TOTAL PHASE 2 ERRORS = Ø ## APPENDIX D The Microprogrammed CRT Controller was built on a System 29 universal card and exercised by the System 29 support processor. An Am9080A program was written to fill the character memory. Figure D1 is the listing of this program. In order to observe the correct output of the controller, an oscilloscope or CRT monitor can be connected through an adaptation circuit shown in Figure D2. | | | HE M. SH | | CHARACTER MEMORY | |------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01FF =<br>00FF =<br>8000 = | ŠTACK<br>FAR<br>CHARAD | EQU<br>EQU | 1FFH<br>0FFH<br>8000H | ;STACK POINTER<br>;FIRST ADDRESS REGISTER O/P PORT<br>;CHARACTER MEMORY STARTS HERE | | 0200<br>0200<br>0201<br>0203 | FA<br>CURAD<br>FIL | ORG<br>DS<br>DS<br>DS | STACK+1<br>1<br>2<br>2 | ;WORKING SPACE ABOVE STACK<br>;FIRST ADDRESS<br>;CURRENT ADDRRESS<br>;A(FIRST CHARACTER IN LINE) | | 0100<br>0100 31FF01<br>0103 213087<br>0106 220302<br>0109 220102<br>010C AF<br>010D D3FF<br>010F 320002<br>0112 CD1B01<br>0115 CD2C01<br>0118 C31501 | MAIN<br>7 | ORG<br>LXI<br>LXI<br>SHLD<br>SHLD<br>XRA<br>OUT<br>STA<br>CALL<br>CALL<br>JMP | FIL<br>CURAD<br>A<br>FAR<br>FA<br>CLEAR | PROGRAM STARTS HERE CHARAD ;LAST LINE, FIRST CHARACTER ;IN "FIRST CHARACTER IN LINE" BUFFER ;AND IN CURRENT ADDRESS BUFFER ;CLEAR A ;START ADDRESS≔O ;SAVE IN BUFFER ;CLEAR ALL CHAR. MEMORY ;READ CHARACTER AND PUT IN CHAR. MEMORY ;DO IT AGAIN | | 011B 0600<br>011D 210080<br>0120 110008<br>0123 70<br>0124 1B<br>0125 23<br>0126 7A<br>0127 B3<br>0128 C22301<br>012B C9 | CLEAR1 | MVI<br>LXI<br>MOV<br>DCX<br>INX<br>MOV<br>ORA<br>JNZ<br>RET | B,O<br>H,CHARAI<br>D,2048D<br>M,B<br>D<br>H<br>A,D<br>E<br>CLEAR1 | ;DATA=0 ;FIRST CHARACTER ADDRESS ;COUNTER ;CLEAR THAT ADDRESS ;COUNT ;NEXT ADDRESS ;CHECK ; IF DONE: ;NO. CONTINUE ;YES. BACK TO CALLER | | 012C 0E01<br>012E CD0500<br>0131 FE1A<br>0133 CA0000<br>0136 2A0102<br>0139 FE0D<br>013B CA4401<br>013E 77<br>013F 23<br>0140 220102<br>0143 C9 | ÖHARIN | MVI<br>CALL<br>CPI<br>JZ<br>LHLD<br>CPI<br>JZ<br>MOV<br>INX<br>SHLD<br>RET | C,1<br>5<br>1AH<br>0<br>CURAD<br>0DH<br>CRLF<br>M,A<br>H | ;CP/M READ CODE ;CP/M READ ROUTINE: ;CTL-Z? ;RETURN TO CPM IF YES ;FETCH CURRENT ADDRESS ;CR? ;YES. ;WRITE CHARACTER ;INCREMENT ;STORE IN BUFFER ;BACK TO CALLER | | 0144 E5<br>0145 D5<br>0146 C5<br>0147 F5<br>0148 1E0A<br>014A 0E02<br>014C CD0500<br>014F F1<br>0150 C1<br>0151 D1<br>0152 E1<br>0153 EB | ;<br>CRLF | PUSH<br>PUSH<br>PUSH<br>MVI<br>MVI<br>CALL<br>POP<br>POP<br>POP<br>POP<br>XCHG | H<br>ID<br>B<br>PSW<br>E,OAH<br>C,2<br>5<br>PSW<br>B<br>ID<br>H | ;ROUTINE TO ECHO LF<br>;SAVE CURRENT ADDRESS IN DE | Figure D1 | 0154 | 015000 | | LXI | B,80D | ;80 CHARACTERS/LINE | |----------|--------|-------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0157 | 2A0302 | | LHLD | FIL | FETCH FIRST CH. IN LINE ADDRESS | | 015A | 09 | | DAD | B | ;HL= A(NEXT LINE'S FIRST CH. ADD.) | | 015B | EB | | XCHG | | ;HL=CURRENT ADDR.,DE=A(NEXT LINE FIRST CH. ADDR) | | 015C | 0600 | | MVI | B,0 | ;DATA=0 | | 015E | 7C | CRLF2 | MOV | A,H | ; MORE SIGNIFICANT CURRENT ADDRESS | | 015F | | | CMP | D | ;=NEXT LINE FIRST ADDRESS? | | | C26801 | | JNZ | CRLF3 | ; NO | | 0163 | | | MOV | A.L | LESS SIGNIFICANT CURRENT ADDRESS | | 0164 | | | CMF | E | ;IS CURRENT LINE FULL? | | | CA6D01 | | JZ | CRLF4 | ; YES | | 0168 | | CRLF3 | MOV | M.B | STORE O AT THAT ADDRESS | | 0169 | | | INX | H | ; INCREMENT ADDRESS | | | C35E01 | | JMP | CRLF2 | #GO CHECK AGAIN | | 016D | | CRLF4 | MOV | A.H | :MORE SIGNIFICANT PART OF ADDRESS | | | E607 | | ANI | 7 | ONLY 3 LESS SIGNIFICANT BITS | | 0 18 0 | FE07 | | CPI | 7 | ;LAST LINE PASSED? | | | C27E01 | | JNZ | CRLF5 | NOT YET | | 0175 | | | MOV | A.L | :LESS SIGNIFICANT BYTE OF ADDRESS | | | FE80 | | CPI | вон | :ARE WE AT 780H=1920D? | | 0 14 7 - | C27E01 | | JNZ | CRLF5 | :NOT YET. SKIP | | | 210080 | | LXI | H.CHARA | THE PERSON OF THE MENT | | | 220302 | CRLF5 | SHLD | FIL | STORE IN FIRST CH. IN LINE BUFFER | | | 220302 | CKLFS | SHLD | CURAD | AND IN CURRENT ADDRESS BUFFER | | | | | LDA | FA | FETCH FIRST VISIIBLE CHARACTER ADDRESS | | | 3A0002 | | ADI | 5 | SCROLL. | | | C605 | | CPI | 120D | TOO MUCH? | | | FE78 | | | | :YES | | | CC9401 | | CZ | CRLFO | STORE IN FIRST ADDRESS BUFFER | | | 320002 | | STA | FA | | | | D3FF | | OUT | FAR | ;LOAD REGISTER | | 0193 | C9 | | RET | | ; RETURN TO CALLER | | | | 7 | | | | | | | 9 | VEA | | :FIRST ADDRESS=0 | | 0194 | | CRLFO | XRA<br>RET | A | FIRST BENESON | | 0195 | C9 | _ | KEI | | | | | | ÿ | | | | | | | ÿ | | | | Figure D1 (Cont.) Figure D2. ## MULTIPLEXER SELECT | R <sub>20</sub> | R <sub>19</sub> | R <sub>18</sub> | R <sub>17</sub> | SELECT | |-----------------|-----------------|-----------------|-----------------|---------| | 0 | 0 | 0 | 0 | TEST 0 | | 0 | 0 | 0 | 1 | TEST 1 | | 0 | 0 | 1 | 0 | TEST 2 | | | | | | | | 1 | 1 | 1 | 1 | TEST 15 | #### POLARITY CONTROL | R16 | OUTPUT | |-----|-----------------------| | 0 | COMPLEMENT<br>OF TEST | | 1 | TRUE TEST | #### **NEXT ADDRESS CONTROL** | R <sub>15</sub> | R <sub>14</sub> | R <sub>13</sub> | R <sub>12</sub> | FUNCTION | |-----------------|-----------------|-----------------|-----------------|---------------------| | × | X | X | Х | NEXT<br>INSTRUCTION | ## MACHINE INSTRUCTION REGISTER | R <sub>21</sub> | FUNCTION | |-----------------|----------| | 0 | LOAD | | 1 | HOLD | ## CONTROL VALUE | R <sub>11</sub> -R <sub>0</sub> | FUNCTION | | |---------------------------------|----------|--| | xxxxxx | VALUE | | ## JUMP ADDRESS | BR11-BR0 | FUNCTION | |----------|--------------| | xxxxxx | JUMP ADDRESS | #### MULTIPLEXER SELECT | | R <sub>20</sub> | R <sub>19</sub> | R <sub>18</sub> | R <sub>17</sub> | SELECT | |---|-----------------|-----------------|-----------------|-----------------|---------| | - | 0 | 0 | 0 | 0 | TEST 0 | | | 0 | 0 | 0 | 1 | TEST 1 | | | 0 | 0 | 1 | 0 | TEST 2 | | | | : | | | | | | 1 | 1 | 1 | 1 | TEST 15 | #### POLARITY CONTROL | R16 | OUTPUT | |-----|--------------------| | 0 | COMPLEMENT OF TEST | | 1 | TRUE TEST | #### **NEXT ADDRESS CONTROL** | R <sub>15</sub> | R <sub>14</sub> | R <sub>13</sub> | R <sub>12</sub> | FUNCTION | |-----------------|-----------------|-----------------|-----------------|---------------------| | × | × | X | X | NEXT<br>INSTRUCTION | ## MACHINE INSTRUCTION REGISTER | R <sub>21</sub> | FUNCTION | |-----------------|----------| | 0 | LOAD | | 1 | HOLD | ## COUNTER VALUE | R <sub>11</sub> -R <sub>0</sub> | FUNCTION | |---------------------------------|----------| | xxxxxx | VALUE | ## JUMP ADDRESS | BR <sub>11</sub> -BR <sub>0</sub> | FUNCTION | |-----------------------------------|--------------| | xxxxxx | JUMP ADDRESS | ## OR BRANCH CONTROL | | R <sub>25</sub> | R <sub>24</sub> | R <sub>23</sub> | R <sub>22</sub> | FUNCTION | |---|-----------------|-----------------|-----------------|-----------------|---------------------| | - | × | × | × | X | TEST<br>INSTRUCTION | ## MULTIPLEXER SELECT | R <sub>20</sub> | R <sub>19</sub> | R <sub>18</sub> | R <sub>17</sub> | SELECT | |-----------------|-----------------|-----------------|-----------------|---------| | 0 | 0 | 0 | 0 | TEST 0 | | 0 | 0 | 0 | 1 | TEST 1 | | 0 | 0 | 1 | 0 | TEST 2 | | | | | | | | | | | | | | 1 | 1 | 1 | 1 | TEST 15 | ## **NEXT ADDRESS CONTROL** | R <sub>15</sub> | R <sub>14</sub> | R <sub>13</sub> | R <sub>12</sub> | FUNCTION | |-----------------|-----------------|-----------------|-----------------|---------------------| | X | Х | Х | X | NEXT<br>INSTRUCTION | ## CONTROL VALUE | R <sub>11</sub> -R <sub>0</sub> | FUNCTION | |---------------------------------|----------| | XXX XXX | VALUE | ## POLARITY CONTROL | R <sub>16</sub> | OUTPUT | |-----------------|--------------------| | 0 | COMPLEMENT<br>TEST | | 1 | TRUE TEST | #### MACHINE INSTRUCTION REGISTER | R <sub>21</sub> | FUNCTION | |-----------------|----------| | 0 | LOAD | | 1 | HOLD | ## JUMP ADDRESS | BR <sub>11</sub> -BR <sub>0</sub> | FUNCTION | |-----------------------------------|--------------| | XXX XXX | JUMP ADDRESS | OTHER - And the control of th ADVANCED MICRO DEVICES, INC. 901 Thompson Place Sunnyvale California 94086 (408) 732-2400 TWX: 910-339-9280 TELEX: 34-6306 TOLL FREE (800) 538-8450 5-78