# THE 2900 FAMILY STUDY GUIDE AND TEACHER'S MANUAL ## THE 2900 FAMILY # STUDY GUIDE AND TEACHER'S MANUAL bу Donnamaie E. White, Ph.D. ADVANCED MICRO DEVICES, INC. Copyright © 1980 by Donnamaie E. White and Advanced Micro Devices, Inc. Advanced Micro Devices reserves the right to make changes in its products without notice in order to improve design or performance characteristics. The author and the company assume no responsibility for the use of any circuits described herein. 901 Thompson Place, P.O. Box 453, Sunnyvale, California 94086 (408) 732-2400 TWX: 910-339-9280 TELEX: 34-6306 ### PREFACE This book was prepared with emphasis on the 2900 Family members in which there is the most interest and the most need for instruction. A few of the older family members have been included as a reference point for those designers or students who have previously been exposed to bit-slice design and microprogramming. Later editions will add the newer family members as they are released. It is necessary that the reader have the latest edition of the 2900 Family Data Book and it is suggested that a copy of the nine part series of application notes, ## HOTBACs (How To Build A Computer) (which is also to be published by McGraw-Hill, New York (1980)), be available for reference. For the beginner, obtain a copy of ## White, D. E. Bit Slice Design: Controllers and ALUs to be published by Garland, New York (1980). As with the customer education seminars, the reader is assumed to be either an experienced SSI/MSI designer or an experienced assembly level programmer. The first section of this study guide is a sample exam which essentially surveys how much you have picked up from: 1) reading the application notes and the data book; or 2) completing the Advanced Micro Devices Customer Education seminar, ED2900A, "Introduction to Designing with the 2900 Family". It is the actual exam given at the end of the customer seminar. The emphasis of the exam is on the Am2910 microprogram controller and on the new Am29203 RALU, with a few guestions on related family members such as the Am2914 vectored priority interrupt controller, the Am2909/2911 microprogram sequencers and the Am2901 RALU. The second section is a series of exercises grouped on specific parts. Not all members of the 2900 Family are included. Some will be added in later editions, as they are developed; some are not included because they are difficult to comprehend. The Am 29116 bipolar microprocessor is included on an introductory level. If you are just beginning, work through the starred exercise sets only. (You will have to change Am27S27 questions to run off of an Am29lo.) These are the newer parts and any new designs should be done with these family members. Notice that no alpha designation follows the part number (such as Am290lC, Am29lOA, etc.). Always use the latest Data sheet. Do not waste time on outdated data. The Am2909 exercises are included for those who have a given system to maintain or to enhance. Section three is still evolving and consists of problems that have been used in ED2900A as homework design problems. (We had to have the classic traffic light and coffee machine controller problems!) These conceptually simple problems actually demonstrate good microcoding techniques for the Am2910. A beginner should look these problems over carefully. Structured Microprogramming (clean, readable code) is the objective. Always! 1 3 L . . 1 ν. Section four is the set of chapter end exercises developed for the Garland text. Some of the exercises come from the ED2900A and the ED2900B Microprogrammable Computer Architecture seminars. The exercises are paced to the text. Sections five, six and seven are the answers for sections one and two, and for parts of section four. Section three stands by itself. Every attempt was made to produce good microcode format. The microprogramming solutions are written using pseudo-mnemonic notation, some of which refers to the data sheets of the relevant parts and some of which was developed specifically for the exercises. The translations are intended to be obvious. For example: FQ/2->RAMQ means a double precision down shift with a RAM and Q register, the Q register being the least significant half of the pair. RAM3TORAMO means to link the RAM shift register to itself such that the RAM3 pin of the most significant slice (MSS) is output into the RAMO pin of the least significant slice (LSS). SPF2 means special function 2(HEX) for the Am2903/29203. Design of "typical" CPUs are given in abundance in the various chapters of HOTBACs and the 2900 Family Data book and such designs and microcode are not reproduced here. Section four questions which are not answered herein may be found in the references. Chapter 8 of the HOTBACs, for example, documents a minicomputer and gives 256 microinstructions for the design, including initialize and examples of the various addressing modes allowed. ## HOW DO YOU BEGIN? First, what is it that you wish to design? A high speed controller would use Am2910, Am29116. It may also use an Am2904. Adding interrupts might use one or more Am2914s. A high speed CPU or an emulation would use Am2910, Am29203 (breadboard with the Am2903 until the Am29203 is available), and the Am2904. With interrupts, add the Am2914s. A controller (computer or otherwise) requiring more than 4K microwords might replace the Am2910 with several Am2909/11s and an Am29811. A minicomputer instructions set would fit comfortably into 4K; a sophisticated high-speed hard disk controller might not. A computer with a program control unit (versus one using the data ALU to perform addressing) would build the PCU from Am2901s or Am2930/32s. Second, study the data sheets for the parts in which you have an interest, one at a time. Try to answer the questions for those parts that are included in section two. Third, study the example problems in section three and retry questions that you missed. Forth, read through the Garland text and the HOTBACs series (they are not identical!). Then, try to answer any remaining questions that you missed. You should at this point try the exam - just skip over the questions on the parts in which you have no interest. Finally, study the answers and compare to your own. # WHAT OTHER HELP IS THERE? The AMD 2900 Family literature is available from Advanced Micro Devices from the literature distribution center or from the Bipolar Applications group. Your local distributor or sales office would also have a supply. Page 3-1 in the 2900 Family Data Book lists the application notes that are available. The Customer Education Center at Advanced Micro Devices currently offers a three course series of seminars and workshops. ED2900A Introduction to Designing With the 2900 Family EDSYS29 Introduction to Designing With the AMC SYS/29 Development System (a development system for microprogram development and prototype check-out) ED2900B Microprogrammable Computer Architecture (everything you need to consider to develop a new CPU or emulate an old one with the 2900 Family) Additional seminars are being developed on topics such as high speed controller design (the Am29116) and computer arithmetic (Am29203/2903 algorithms). ED2910, "Basics of Bit-Slice", is a new course to be offered this spring. It is more elementary than the very intense ED2900A and is specifically for the beginner. If you have never microprogrammed, don't really know what that is, have never written or read assembly level programs, then this is the class that we recommend. Call us at: 408-732-2400 ext 3665 or ext 2325 Outside California: 800-538-8450 ext 3665 or ext 2325 Write us at: Advanced Micro Devices, Inc. Customer Education Center 490-A Lakeside Drive P.O. Box 435 Sunnyvale, CA 94086 Donnamaie E. White, Ph.D. ## PREFACE (how to use this book) ## TABLE OF CONTENTS ### I. SAMPLE EXAM ## II. EXERCISES GROUPED ON INDIVIDUAL PARTS - A. Am29811/2909/2911 (next addr. control, sequencers) - B. Am29803 (n-way branch support) - \* C. Am27S27 (registered PROM) - \* D. Am2910 (microprogram controller) - E. Am9124 (MOS RAM) - F. Am2914 (vectored priority interrupt controller) - G. Am2901 (RALU, bipolar microprocessor slice) - \* H. Am2903/29203 (RALU, bipolar microprocessor slice) - \* I. Am29705/29707 (dual-port RAM memory) - J. Am2904 (status and shift control unit) - \* K. Am29116 (16-bit bipolar microprocessor) <u>NEW!</u> (Over 70 questions introduce you to the new 16-bit Bipolar microprocessor) - \* marks more important parts ## III. CONCEPTUALLY SIMPLE PROBLEMS FOR BEGINNERS - A. Traffic Light Problems - Simple Traffic Light Introduces microprogramming - Advanced Traffic Light Microprogramming the Am2910 - B. The Famous Coffee Machine Microprogramming the Am2910 - C. A Very Simple Computer Introduces Microprogramming for a CPU Includes direct and indirect addressing - D. A Simple Data Monitor Problem Microprogramming from a meta-language definition Exercise: redo it for the Am29203 ## IV. PACED EXERCISES # Bit-Slice Design: Controllers and ALUs [White, D. E.: Garland Press: 1980] - A. Chapter 1 (introduction) - B. Chapter 2 (Basic CCU, timing) - C. Chapter 3 (Am2909, Am29811, Am29803) - D. Chapter 4 (Am2910, Am2914) - E. Chapter 5 (addressing, Am2910, Am2901) - F. Chapter 6 (as Chapter 5 but with the Am2903) - G. Chapter 7 (adds Am2904 to above) ## V. SOLUTIONS - A. Exam Answers - B. Exercise Answers (Specific parts) - 1. Am29811 Am2909/2911 - 2. Am 29803 - 3. Am27S27 - 4. Am 2910 - 5. Am9124 - 6. Am 2914 - 7. Am2901 - 8. Am 2903/29203 - 9. Am 29705/29707 - 10. Am2904 - 11. Am29116 - C. Chapter Exercise Solutions 2900 FAMILY STUDY GUIDE Am2900 REVIEW SAMPLE EXAM The following is a sample exam for ED2900A or any introductory course on the 2900 Family of Advanced Micro Devices. 1. Show the microcode (partial width only) to program these statements, assuming an Am29803-Am2909/11-Am29811 CCU. IF A THEN ON (T2T0) GO TO (10, 200, 30, 40) ELSE ON (T3T1) GO TO (20, 200, 10, 20) IF B THEN ON (T3T2T1) GO TO (10, 20, 30, 40,...) ELSE ON (T2T1T0) GO TO (100, 200, 300,...) Where: A and B are condition multiplexer input lines T3, T2, T1, T0 are test inputs to the Am29803 10, 20, 200, etc. are labels of statements The same label means the same statement The statements may be considered to be the beginning of a microroutine of unknown length 2. Show the microcode for the Am2910 instruction field and any other necessary sequence control fields to perform the following: IF A THEN DO SI S 2 53 6 TIMES; ELSE DO S1 S 2 S3 10 TIMES; Where: S1, S2, S3 are statement labels (the statements can do anything, we don't care) A is an input to the conditional multiplexer Given the following flow diagram: - 3. What Am2910 instruction would be at address 63? (Show 3 sequence control fields.) - 4. What Am2910 instruction would be at address 64? - 5. What Am2910 instruction would be at address 65? - 6. What value is on the stack (at the top) after executing the microinstruction at address 63? - 7. Why use a pipeline register at the microprogram memory output instead of at the Am2910 address output lines? - 8. How long does CCEN have to stay high to be detected? 9. List three ways to generate $\widetilde{\mathsf{OE}}_{\mathsf{PL}}$ , $\widetilde{\mathsf{OE}}_{\mathsf{VECT}}$ , $\widetilde{\mathsf{OE}}_{\mathsf{MAP}}$ . - 10. List two ways to "force a PASS" or TRUE at $\widetilde{CC}$ (Am2910); one way for a "PASS" at TEST (Am29811). - 11. How much RAM is on-board the Am2901? - 12. Is the RAM on the Am2901 expandable? If yes, how? - 13. How much RAM is on-board the Am2903? - 14. Is the RAM on the Am2903 expandable? If yes, how? - 15. How much RAM is on-board the Am29203? - 15. Is the RAM on the Am29203 expandable? If yes, how? - 17. How are race conditions avoided in the Am2901? - 19. Can the A, B addresses into the RAM on-board the Am2903 be identical, ie., may both address the same register in any one microcycle? - 19. If the RAM register enable is enabled, when is data written into the selected register? (Any of the RALUS) - 20. What is the guaranteed maximum capacitive load that the 2900 Family parts can drive without suffering some speed degredation? - 21. Are the Am2903 and the Am29203 pin for pin compatible? - 22. Which RALU supports BCD operation? - 23. Which RALU supports byte operations best? ### TRUE or FALSE - 1. The Am2909/2911 and a PROM can form a flexible control unit - 2. There is only one possible instruction set for the Am2910 if $\vec{RLD}$ , $\vec{CCEN}$ , and Ci are all held constant. - 3. $\overline{RLD}$ on the Am2910 can be tied to instruction line I or I without harming the DO-loop instructions. - 4. CJP, CJV, CJS, CJPP, JRP, and JSRP are all conditional branch statements in the Am2910 instruction set. - 5. A shift and an arithmetic operation may be done in the same microcycle when using the Am2903. - The Am2903 is faster than the Am2901B on the average. - 7. The functions available on the Am2901 are all available on the Am2903. - 8. It is practical to emulate the Am9080 (In8080) using the 2900 Family. - 9. The 2900 Family can be used to emulate the AmZ8000. - 10. The 2900 Family currently supports real-time interrupts easily ("easily" refers to both implementation and conceptual clarity). - 11. The Am2914 can be used for software level interrupt routines. - 12. The Am2914 can be used for firmware level interrupt routines. - 13. The Am2910 is a bit-slice device (expandable). - 14. The 2900 Family is a bipolar technology family, TTL compatible. - 15. The 2900 Family can be configured to operate with a 125ns microcyle via pipeline registers. 2900 FAMILY STUDY GUIDE Am2900 REVIEW SAMPLE EXAM - 16. A disk controller would never use an ALU. - 17. The Am2910 and Am2914 can be configured to handle subroutine or nonsubroutine calls to interrupt routines. - 18. The Am2909 and the Am2910 have wraparound stacks. - 19. The Am29803 attaches to the Am2911 to provide hardware supported case statements (N-way branching). - 20. The Am29811 and Am2910 support the loop structures DO While X is FALSE (DO UNTIL X is TRUE) and DO i TIMES. - 21. The Ri and Di inputs are tied together on the Am2909 and the Am2910. # EXERCISES ON SPECIFIC PARTS 2900 FAMILY STUDY GUIDE EXERCISES Am29811 Am2909/2911 # EXERCISES - Am29811 - Am2909/2911 1. Diagram the pin-to-pin connection of an Am29811 and three Am2911s. - 2. What is the logical value of $\overline{\mbox{OE}}$ if the Am29811 is to be always active? - 3. Name an application where you would wish $\overline{0E}$ to be variable. - 4. What are the counter load enable lines for? - 5. Diagram the connection of an Am29811 and an Am25LS2569s (counters) for a 12-bit control memory address system. 2900 FAMILY STUDY GUIDE EXERCISES Am29811 Am2909/2911 - 6. Is the TEST input active-high or active-low? - 7. Microcode the Am29811 to do the following: (show: address Am29811 instr TEST Br Addr) 2900 FAMILY STUDY GUIDE EXERCISES Am29803 | EXERCIS | SPS - | Am 2 9 | 80 | 13 | |-----------|-------|---------|------|----| | FX FKC 13 | 163 - | C11114- | ,,,, | • | - 1. How is the Am29803 turned off? - 2. How are $\overline{\sf OE}_1$ and $\overline{\sf OE}_2$ used? - 3. In any given design, how many different sets of 4 tests are possible without adding MUXs or other extra hardware (over and above the Am29803s)? - 4. What instruction allows $\mathbf{T}_3 \ \mathbf{T}_1 \ \mathbf{T}_0$ to be chosen for an 8-way branch? T<sub>3</sub> T<sub>0</sub>? T<sub>2</sub> T<sub>1</sub>? T<sub>3</sub> T<sub>2</sub> T<sub>1</sub> T<sub>0</sub>? 5. Microcode the Am29811 and Am29803 to do the following branch table: (show addr Am29811 instr Am29803 instr and the branch address) 2900 FAMILY STUDY GUIDE EXERCISES Am29803 6. Make a logic-level diagram of the Am29811 - Am29803 - Am2911/2909 configuration required to implement problem 5. above. Show PROM connections. 2900 FAMILY STUDY GUIDE EXERCISES Am27S27 # EXERCISES - Am27S27 Assume a 2Kx64 bit wide PROM memory has been designed using the Am27S27, and that Am29lls control the address lines. - l. Compute the address line current loads (worst case of course). - 2. Are buffers needed? - 3. What is the capacitive loading on the address lines? - 4. What is the amount of speed degredation due to capacitive loading on the Am2911s? (Use 0.lns/pf; 0.07ns/pf is typical.) - 5. What can be done to the design to avoid the affect? - 6. Repeat the loading computations for a 4Kx32 bit control memory. - 7. Repeat the loading computations for a $4\ensuremath{\mbox{Kx}} 64$ bit control memory. ## EXERCISES - Am2910 - 1. What does $\overline{RLD} = LOW do$ ? - 2. What does Ci = HIGH do? - 3. What does CCEN do? - 4. When should FULL be used? - 5. Can two (2) Am2910s be hooked together in a system? - 6. Name an application where you think you would want to do this. - 7. Name two instances when you would want to vary $\overline{\text{OE}}$ into the Am2910. - 8. How deep is the stack on the Am2910? - 9. Is this the same as the Am2909/11 stack? - 10. How does it differ if it does? - 11. What happens if you PUSH 8 times and do not POP between them? (Use as many lines as are needed and diagram stack contents using 1,2,3,4,5,6,7,8.) 12. Microcode the Am2910 to do the following flow. (Show: address Am2910 instr Test Br addr) 13. What are the main differences between the Am29811 and Am2910 instruction sets and control lines? | _ | _ | _ | | - | _ | | _ | _ | - | - | _ | - | - | - | - | - | - | - | - | - | _ | |---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---| | _ | _ | _ | _ | _ | _ | _ | _ | | | _ | _ | - | - | - | _ | - | - | - | - | - | - | | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | | _ | _ | - | _ | _ | - | _ | - | _ | - | | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | - | _ | _ | - | _ | | _ | _ | - 14. How does CJP differ from that of the 29811? - 15. Can the Am2910 be used with an Am29803? If yes, how? - 16. T or F: The 2910 is approximately equal to three 2911s, one 29811, one counter, and one decoder. - 17. Explain why both RFCT and RPCT are needed. - 19. Which is better if you are not sure about the reliability of the signal that you are using to terminate a DO-UNTIL loop: LOOP or TWB? And why? ED2900B EXERCISES Am2910 - 19. Write the code for an exit from a subroutine if TESTA is TRUE, no test enable control. - 20. Write the code for an unconditional exit from a subroutine. - 21. Repeat problem 20 if CCEN is available. - 22. Write a DO loop to execute one microinstruction 10 times, assuming that the stack is full and unavailable. - 23. Repeat problem 22, but use the stack this time; $\overline{CCEN}$ is not available. - 24. Repeat problem 23, but this time $\overline{\text{CCEN}}$ is available. - 25. Write a DO loop to execute one microintruction until TESTB is true. Do NOT allow the register to load. - 26. Write a DO loop to execute one microinstruction until TESTC is true OR the instruction has been executed 20 times. Branch to FAILADDR. Write it without $\overline{CCEN}$ and then write it using $\overline{CCEN}$ . - 27. Write code to branch to ADR1 if TESTD is FALSE or to ADR2 if TESTD is TRUE. $\vec{R}\vec{L}\vec{D}$ and $\vec{C}\vec{C}\vec{E}\vec{N}$ are not involved. - 28. Write code to jump to the subroutine at SUBA if TESTD is FALSE or to the subroutine at SUBB if TESTD is true. - 29. Write code to jump out of the middle of a DO loop (which uses LOOP, RFCT, or TWB) if TESTE is TRUE. Branch to address ADR3. ED2900B EXERCISES Am2910 - 30. Using $\overline{\text{RLD}}$ , load the register/counter with address SUBA three steps prior to the subroutine call above. - 31. Draw the flow diagram for normal execution of the CJS instruction and show the sequence control portion of the microinstruction. CJS appears at address 13; the subroutine is at address 40; and TESTC is tested. (Yes, symbolic labels are best when writing microcode.) - 32. Repeat 31, assume CCEN = HIGH. - 33. Repeat 31, assume $\overline{RLD}$ = LOW. - 34. Repeat 31, assume $C_{\hbox{in}}$ goes LOW just after loading of the CJS instruction into the microinstruction register. - $\frac{35.}{R\bar{L}\bar{D}},$ Devise a flowchart of the decision activity if TESTC, $\bar{R}\bar{L}\bar{D},$ $\bar{C}\bar{C}\bar{E}\bar{N}$ and C $_{in}$ are all present in the microword. 2900 FAMILY STUDY GUIDE EXERCISES Am2910 CODING SHEET | LABEL/ | 2910 | COND | | BR ADDR/ | |--------|-------|---------|------|----------| | ADDR | | MUX SEL | CCEN | COUNTER | | | | | | | | | | | | | | 1 | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | ! | | | | | | | <br> | | | | | | | i | | | | | <br> | | | | | | l<br> | | | | | | | | | | | | <br>! | | | | | | <br> | | | | | | <br> | | | | | | t . | | | | | | <br> | | | · | | | | | | | | | <br> | | | | | | 1 | | | | | | | | | | | LABEL/ | 2910 | COND | | BR ADDR/ | |--------|--------------|---------|------|----------| | ADDR | INSTR | MUX SEL | CCEN | COUNTER | | | | | | | | <br> | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | 1 | | | | | | | | • | | | | | | | | | | | <br><b></b> | | | | | | <del>-</del> | | | | | | | | | | | | <br><b></b> | | | | | | | | | | | | | | | | | | | | | | | | <br> | | | | | | ,<br> | | | | 2900 FAMILY STUDY GUIDE EXERCISES Am9140 # EXERCISES - Am9140 1. How many address lines are available? \_\_\_\_\_\_ \_\_\_\_\_\_ ------ - 2. Are any enables needed? - 3. Diagram a 4Kx32 bit memory. - 4. If a 4Kx32 Am9124 memory is used for a control memory, what is the load on the Am2910 output lines (current and capacitance)? - 5. Could an 8Kx32 bit memory be driven by an Am2910 (unaided)? - 5. How would you do it? ## EXERCISES - Am2914 - 1. How many levels of prioritized interrupt requests can be handled by one Am2914? - Are interrupt requests active high or active low? - 3. If you wish to mask an interrupt level, do you set the mask bit to 1 or to 0? - 4. Is this correct: $INR_7 \cdot \overline{MK}_7 = IR_7$ where $INR_i$ is the complement of the actual interrupt request line, MK<sub>i</sub> is the mask register bit, and $IR_i$ is the result of the mask operation? - 5. What Am2914 instruction causes the binary coded vector $\mathbf{V_i}$ to be loaded into the Vector Hold Register? - 6. What is the function of the vector hold register? - 7. When is the vector hold register cleared? - 8. What does the binary coded vector represent? - 9. Is the status register set equal to the priority of the interrupt currently being serviced? - 10. If the status fence is 5, what non-masked interrupts may be recognized? - 11. If four Am2914s are present in a system, how many lowest group enabled flip-flops can be low at a time (and still have correct operation)? - 12. Correct?: INTERRUPT REQUEST = DET INTERRUPT DISABLE PASS PRIORITY + PASS ALL ## EXERCISES - Am2901 - 1. Can the Q register be shifted by itself (without shifting the RAM shift register)? - 2. Is it possible to perform $R_c \leftarrow R_b + R_a$ in one microcycle? - 3. What is connected to $\mathbf{Y}_{\mathbf{i}}$ during execution of a NOP? - 4. Does the Am2901 perform a logical NAND or NOR function in one microcycle? - 5. Is the Am2901 designed for one's or two's complement arithmetic? - 6. Is it possible to perform $D_a + D_b \longrightarrow Y_i$ , where $D_a$ and $D_b$ are from outside the chip sources, in one microcycle? - 7. Diagram the interconnection of a 16-bit ALU that can perform RAM and Q register up and down shifts and rotates. Use the Am2901, Am2902 and multiplexers. - 8. Show the microword to do a single precision rotate of l bit down on register 6. (2910 instr., muxsel., braddr., ALU source, ALU func., ALU dest., A addr., B addr., Cin, rotate muxsel.) - 9. Refer to problem 8. above but do a rotate of 2 bits up in one microcycle. - 10. Is it possible to do R + $C_{in}$ in one microcycle? Show the code. - 11. Show the code required (for the 2910, 2901) to perform ${\rm D_A}$ + ${\rm D_B}$ --> ${\rm Y_i}$ . - 12. Show the code to perform $R_a + R_b \rightarrow R_c$ . - 13. Show the code to perform a byte swap on $\mathbf{R}_{\mathbf{S}}$ assuming no hardware assist. - 14. Show the code to perform PC --> MAR; PC <-- PC + 1, where PC = $R_{15}^{\circ}$ . ## 2900 FAMILY STUDY GUIDE EXERCISES Am2910 - Am2901 CODING SHEET | INST SEL COUNTER SRCE FUNC DEST ADDR ADDR SEL MUX SEL 8. 10. 11. 12. | ADDR | ı | 2910 | MUX | BR | ADDR | A | L | ប | RA | RB | Cin | ROTA | ATE | |--------------------------------------------------------------------------|------|---|------|-----|----|------|---|---|---|----|----|-----|------|-----| | 8. 9. 10. 11. 12. 13. | | | | | | | | | | | | | | | | 9 | 8. | | | | | | | | | | | | | | | 10. 11. 12. 13. | 9. | | | · | | | | | | | | | | | | 12. | 10. | | | | | | | · | | | | | | | | 12.<br> | | | | | | | | | | | | | · | | | 13. | 12. | | | | | | | | | | | | | | | | 13. | | | | | | | | | | | | , | | | 14. | 14. | | | | | | | | | | | | | | 2900 FAMILY STUDY GUIDE EXERCISES Am2901 | Which instruction lines provide | e or ao | the tor. | LOW I II.G. | |---------------------------------|----------------------------------------------|----------------------------------------------|----------------------------------------------| | Am2901 | 1 <sub>8</sub> 1 <sub>7</sub> 1 <sub>6</sub> | <sup>1</sup> 5 <sup>1</sup> 4 <sup>1</sup> 3 | 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | | Select of MUX at R(ALU) | | | | | Function select of ALU | | | | | Enables the Q register | | | | | Select of Output MUX | <del></del> | | | | Inhibit at R or S | | | | | Select of MUX at RAM input | | | | | Select of MUX at QREG input | | <del></del> | | | RAM enable | | | | | RAM <sub>O</sub> enable | | | <del></del> | | RAM <sub>3</sub> enable | | | | | Q <sub>0</sub> enable | | | | | Q <sub>3</sub> enable | | | · | | Select of MUX at S(ALU) | | | | 2900 FAMILY STUDY GUIDE EXERCISES Am2903/29203 # EXERCISES - Am2903 - Am29203 - 1. What is the difference between a logical and an arithmetic shift? - 2. Can the RAM shift register perform both logical and arithmetic shifts? - 3. Can the Q shift register perform both logical and arithmetic shifts? - 4. Can the Q register be shifted independently of the RAM shift register? - 5. How many special functions are implemented on the Am2903? - 6. Is it possible to load the Q register and not load the RAM register? - 7. Does the Am2903 perform the logical functions NAND and NOR in one microcycle? - 8. Does the Am2903 perform $R_a + R_b \longrightarrow R_c$ in one microcycle? - 9. Does the Am2903 perform $D_a$ + $D_b$ --> $Y_i$ in one microcycle, where $D_a$ and $D_b$ come from outside the chip sources? - 10. Can the Am2903 perform $S + C_{in}$ , $R + C_{in}$ , $S + C_{in}$ and $R + C_{in}$ , each in one microcycle? - 11. Which instruction lines control whether or not the special functions are active? - 12. Can the Q register be shifted as it is initially loaded (F --> Q/2; F --> 2Q)? 2900 FAMILY STUDY GUIDE EXERCISES Am 2903/29203 - 13. Can any RAM register be loaded when $\overline{I}_{ ext{EN}}$ is high? - 14. Are the status lines affected if single length normalize is executed with $\overline{I}_{\rm EN}$ = HIGH? - 15. Show the code (2910, 2903) to perform $D_a + D_b \longrightarrow Y_i$ . - 16. Show the code to perform $R_a + R_b \longrightarrow R_c$ . - 17. Show the code to perform a byte swap with no hardware assist. - 18. Show the code perform PC --> MAR; PC <-- PC + 1, where PC = $R_{15}$ . - 19. Show the code to perform $D_A \longrightarrow Q$ . - 20. Output $\langle R_2 \rangle$ and perform $2*(R_2 + 1)$ in one microcycle. - 21. Perform an unsigned 16-bit multiply. - 22. Perform a two's complement 16-bit multiply. - 23. Perform a double precision down shift using $R_2$ and Q. - 24. Perform 4\*R, --> Q. # 2900 FAMILY STUDY GUIDE EXERCISES Am2910 - AM2903/29203 CODING SHEET | LABEL/ | 4 | 2910 | MUX | BRADDR | A | L | Ü | RA | ŔB | Cin | ROT | ATE | |--------|---|------|-----|--------|------|------|------|------|------|-----|-----|-----| | ADDR | I | INST | SEL | COUNTR | SRCE | FUNC | DEST | ADDR | ADDR | SEL | MUX | SEL | | 15. | | | | | | | | | | | ١ | | | 16. | | | | | | | | | | | | | | 17. | | | | | | | | | | | | | | 18. | | ٠. | | | | | | - | - | | | | | 19. | | | | | | | | | | | | | | 20. | | | | | | | | | | | | | | 21. | | | | | | | | | | | | • | | 22. | | | | | | | | | | | | | | 23. | | | | | | | | | | | | | | 24. | | | | | | | | | | | | | | | | | | | | | | | | | | | Which group of instruction lines or enables controls the following? | Am2903 | E <sub>A</sub> 10 <sup>ŌE</sup> B | 1 <sub>4</sub> 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> | <sup>1</sup> 8 <sup>1</sup> 7 <sup>1</sup> 6 <sup>1</sup> 5 | |------------------------------------------|-----------------------------------|-------------------------------------------------------------|-------------------------------------------------------------| | Input MUX at R | | | | | RAM enable | | | <u></u> | | Switch to special functions | | | | | ALU function | | | | | WRITE enable | | | | | Q <sub>0</sub> enable | | | <del>.</del> | | Q <sub>3</sub> enable | | <del></del> | | | SIO <sub>O</sub> enable | | | | | SIO <sub>3</sub> enable . | | | | | Q Register enable | | | | | Input MUX at S | | | <del></del> | | Chip function (during special functions) | | | | | DB <sub>0-3</sub> enable | | | | | Status output select | | | | | Inhibit at R and S | | | | | Q input MUX | | | | | RAM input MUX | <del></del> | | . <u></u> | # 2900 FAMILY STUDY GUIDE EXERCISES Am2903/29203 - a. What four functions could appear at $C_{n+4}$ under instruction control? - b. How many different functions could appear at the $\tilde{P}/OVR$ pin under instruction control? - c. List them. - d. How many different functions could appear at the G/N pin under instruction control? - e. List them. - f. How many different functions could appear at the Z pin under instruction control? - g. List them. - h. Tor F: $\overline{ extsf{I}}_{ extsf{EN}}$ controls $\overline{ extsf{W}}ar{ extsf{I}}ar{ extsf{T}}ar{ extsf{E}}$ on the Am2903 and Am29203. - i. Can special functions be executed when $\overline{\mathrm{i}}_{\mathrm{EN}}$ = LOW? - j. What happens? - k. If the scratchpad RAM is not expanded past 16 registers, what connects to $\overline{WE}$ ? 2900 FAMILY STUDY GUIDE EXEPCISES Am 29705/29707 #### EXERCISES - Am29705/29707 - How many address lines are required? - 2. How many enables are there on this chip? - 3. If Am29705s are attached to Am2903s, what is connected to the write enable lines? - Refer to 3. above, what connects to LE? - 5. If two Am29705s, one Am2903 are in a system, can $\rm R_{C}$ <-- $\rm R_{A}^{+}$ $\rm R_{B}^{-}$ have one address from each of the three devices? - 6. Refer to 5. above, can data be brought directly from the data bus to any 29705 in one microcycle? - 7. Refer to 5. above, how many address lines are needed if all three devices may be used in any one microinstruction? If only one may be used in any one microinstruction? 2900 FAMILY STUDY GUIDE EXERCISES Am2904 #### EXERCISES - Am2904 Using HEX code (mnemonics haven't yet been created), write code for the Am2904 and the destination field of the Am2901 to perform: - 1. F/2 --> RAM, hold Q, ZERO --> RAM 3 MSS - 2. FQ/2 --> RAMQ, ZERO --> $RAM_3 |_{MSS}$ - 3. 2FQ --> RAMQ, ONE --> RAMO LSS - 4. 2F --> RAM, RAM<sub>3</sub> MSS --> RAM<sub>0</sub> LSS, hold Q Using HEX code write code for the Am2904 and the destination field of the Am2903 to perform: - 5. F/2 --> RAM, hold 0, $M_{N}$ --> $SIO_{3}|_{MSS}$ - 6. FO/2 --> RAMQ, $M_N$ --> $SIO_3|_{MSS}$ - 7. $F/2 \longrightarrow RAM$ , hold C, $I_C \longrightarrow SIO_3 |_{MSS}$ - 8. F/2 --> RAM (arithmetic shift), hold C, $I_{N} \oplus I_{OVR} \xrightarrow{--> SIO_{3}|_{MSS}} (careful!)$ - 9. What values on what instruction lines are necessary to cause $C_{in}$ to the Am2901 or Am2903 to be set as $^{u}_{C}$ ( $^{C}_{O}$ ) 2904 $^{=}$ $^{u}_{C}$ )? 2900 FAMILY STUDY GUIDE EXERCISES Am 2904 - 10. What values on what instruction lines cause the Machine Status Register, MSR, to be copied into the microstatus register, $\mu \text{SR},$ and MSR <-- $Y_{\dot{1}}$ ? - 11. How do you swap MSR and µSR? - 12. How do you set uSR only (not MSR)? - 13. How do you reset µSR? - 14. How do you set the M<sub>C</sub> bit only? - 15. How do you reset the $M_{C}$ bit only? - 16. How do you swap Mc and MOVR? - 17. Write code for the 2904 to perform the conditional test ( $\mu_N^{\oplus}$ $\mu_{ovr}^{\oplus}$ )+ $\mu_z$ and not alter the status register? - 18. IF $\overline{CE}_{\mu}$ , $\overline{CE}_{M}$ , $\overline{E}_{Z}$ , $\overline{E}_{C}$ , $\overline{E}_{N}$ , $\overline{E}_{OVR}$ are all LOW for the above, what happens? - 19. Write code to test $\mathbf{I}_{OVR};~\bar{C}\bar{E}_{\gamma},~\bar{C}\bar{E}_{M}$ are HIGH. - 20. Repeat 18. if $CE_{\mu} = LOW$ . What happens? - 21. Write code to test $M_C$ . Show microcode for the Am2910, Am2901 and Am2904 to preform the following: 22. $R_{15} \longrightarrow Y; R_{15} + 1 \longrightarrow R_{15}$ . 2900 FAMILY STUDY GUIDE EXERCISES Am 2904 - 23. Byte swap register 6 using no external hardware. - 24. Byte swap register 6 using SSI/MSI hardware assist. - 25. What are the differences in the microwords for the above exercises and those written for the Am2901 exercises? 2900 FAMILY STUDY GUIDE EXERCISES Am29116 - PRELIMINARY DATA #### EXERCISES - Am29116 #### True or False: - The Am29116 is a TTL compatible, ECL internal device. - The Am29116 is expandable (two can be hooked together). - 3. The Am29116 is for 8 bit or 16 bit intelligent controllers. - 4. The Am29116 can perform conditional testing on its status register. - 5. The barrel shifter 'shifts' (rotates) 1 to 15 bits up or down in one microcycle. - The Am29116 must be used with an Am2904. - The Am29116 can perform immediate operations. - 8. The Am29116 has a choice of four input sources to the MUX which in turn provides three ALU inputs, R, S, U. - The Am29116 can perform three address instructions. - 10. The Am2922 (MUX) and the Am2904 (GLUE) both have polarity control on the conditional inputs. - ll. Fast clock speed is synonomous with high throughput. - 12. The Am29116 can generate CRC polynomials up to 16 bits long. - 13. The Am29116 always has its ALU output at $Y_i$ . - 14. The ALU destinations are RAM, ACC, D Latch. - 15. Single operand instructions are PASS, COMPLEMENT, INCREMENT, and TWO'S COMPLEMENT. 2900 FAMILY STUDY GUIDE EXERCISES Am 29116 - PRELIMINARY DATA - 16. $D_{\mbox{OE}}$ (D with zero extend) is used for Two's complement arithmetic. - 17. $\bar{R}$ --> DEST is One's complement, $\bar{R}$ + 1 --> DEST is Two's complement. - 18. The Am 29116 can perform NAND, NOR, EXOR in one microcycle. - 19. Shift up can use 0, 1, or the QLINK bit as input to the LSB. - 20. Shift down uses 0, 1, or the QLINK bit as the only input choices to the MSB. - 21. Rotate can work in byte or word mode. - 22. Rotate uses the U ALU input. - 23. LOAD $2^n$ causes a mask (1 in a field of 0s) to be generated and used for loading RAM, ACC. - 24. Read bus, change bit, output to bus is possible in one microcycle with the Am29116. - 25. If you bit change the ACC, the destination is the ACC or the RAM. - 26. There are 17 choices for priority encoding. - 27. Byte mode prioritize does not use bits 8 15. - 28. The Am29116 can perform operations on up to and including 16 bit CRC polynomials. - 29. 95% of CRC calculations use 16 bit polynomials. - 30. The CRC calculations can be done forward or reverse (transmit bit 0 first or transmit bit 15 first). - 31. CRC can be done in byte or word mode. - 32. The status word can be loaded from D, RAM, ACC. 2900 FAMILY STUDY GUIDE EXERCISES Am29116 - PRELIMINARY DATA - 33. The Z, C, N, OVR status bits can be loaded $\underline{\text{without}}$ affecting LINK or FLAGs. - 34. You can set or reset the entire status word on the $\ensuremath{Am}\xspace 29116$ . - 35. You can set or reset the arithmetic flags individually on the Am29116. - 36. On the Am29116, you can load the status and the ACC registers both in the same microcycle if the RAM is the source. - 37. If the status register enable is on, the status register is frozen (any operation on the status register is "killed"). - 38. All conditional testing is performed on the stored values in the status register. #### FILL IN OR ANSWER: - 39. How many bits in the Am29116 status register? - 40. How many conditional tests can be made? - 41. Can you perform a conditional test during another instruction? If so, how? - 42. Can byte operations be performed in the upper or lower byte of the 16-bit Am29116? - 43. Can the Am29116 support a 100ns microcycle time? - 44. List three possible sources for single operand instructions. 2900 FAMILY STUDY GUIDE EXERCISES Am29116 - PRELIMINARY DATA - 45. Can you load the D (data) latch one byte at a time? - 46. List three possible source pairs for two operand instructions. - 47. If n = 2, show the pattern in the 16-bit word after a word rotate given: - 48. Does the Am29116 support $\langle R_3 \rangle$ .ROTATE. --> $\langle R_3 \rangle$ ? - 49. Does the Am29116 support $\langle R_3 \rangle$ .ROTATE. --> $\langle R_7 \rangle$ ? - 50. If there is no priority request, what is produced by the priority encoder (word mode)? - 51. If bit 15 is active, what is produced (word mode)? - 52. If bit 15 is active, what is produced (byte mode)? - 53. The Am29116 is an order of magnitude faster than the Am2901 which is an order of magnitude faster than the Am28000 for specific controller oriented operations. What can you say about program area? - 54. Can the Am29116 be used to do multiply? - 55. Can the Am29116 be used for bit operations? - 56. Can the Am29116 be used for rotate operations? - 5.7. Does the Am29116 have an ALU? - 58. Can the Am29116 be used to build a CPU? - 59. If the mask bit i is zero in a ROTATE-MERGE instruction, which operand's bit i is passed to the destination? - 60. If U = 0011 0001 0101 0110 R = 1010 1010 1010 1010MASK = 0101 1010 0110 1001 and n = 4 what bit pattern is produced by a word mode ROTATE-MERGE instruction? - 61. If the highest bit position with a one (1) is bit position 7, and the mask is $1010_{\rm HEX}$ , what is produced by a word prioritize instruction? - 62. Repeat for byte mode prioritize. - 63. For LOAD $2^{ m N}$ complement, $({ ilde 2}^{ m N}$ ), what happens? - 64. Suppose you want to do a word rotate down five bit positions. How do you do this on an Am29116? - 65. What is QLINK? - 66. Can you set/reset the ALU status bits one by one as with the Am2904 Machine status register? - 67. Can you set/reset the LINK and FLAGi status bits one at a time? - 68. In byte mode, are the lower 8 bits of the status register loaded? - 69. Which instructions do $\underline{\text{MOT}}$ cause the ALU status bits to be updated? - 70. When are the upper four status bits (LINK, FLAG1, FLAG2, FLAG3) changed? # DESIGNEPROBLEM. TRAFFIC MICHIS Assume a simple 4-way intersection, no protected left turns, nothing fancy required of the controls except that one street is RED while the other shows GREEN and YELLOW occurs between the RED and GREEN lights and visa versa (for simplicity). You have access to a 10 second clock signal. Timing is: RED-GREEN 60 seconds YELLOW 10 seconds Controls on all traffic light units are identical (same decoding). Use a counter and a PROM and any SSI you need and design a traffic light sequence controller for this intersection. (And, if you are a masochist, try doing this with D F/Fs or even J/Ks!) #### MICROPROGRAM | ACTU<br>CONT | PSEUDO- | | Ϋ́ | | | | |-------------------------|--------------------------------------|------------|------------|-------|---|-------------------| | ADDR S <sub>0</sub> S | $51\overline{5}0\overline{5}1$ RESET | LIGHT<br>1 | LIGHT<br>2 | RESET | | | | 0 0 | 0 1 1 0 | RED | GREEN | N | | | | 1 0 | 0 1 1 0 | RED | GREEN | N | | | | 2 0 | 0 1 1 0 | | | | | | | 3 . 0 | 0 1 1 0 . | etc | • | | | | | 4 0 | 0 1 1 0 | | | | | | | 5 0 | 0 1 1 0 | RED | GREEN | N | | | | 6 0 | 1 1 0 0 | YELLOW | YELLOW | 7 N | | | | 7 1 | 1 0 0 0 | GREEN | RED | N | | | | 8 1 | 1 0 0 0 | | | | | | | 9 1 | 1 0 0 0 | etc | • | | | | | 10 1 | 1 0 0 0 | | | | | | | 11 1 | 1 0 0 0 | | | | | | | 12 1 | 1 0 0 0 | GREEN | RED | N | | | | 13 1 | 0 0 1 1 | YELLOW | AETTOM | Y | < | RESET FOR COUNTER | #### SEQUENCE (GREY CODE) | Q <sub>3</sub> ( | 22 | 1 | 0 | s <sub>1</sub> s | 30 | | |------------------|----|---|----|------------------|----|--| | 0 | 0 | 0 | 01 | 0 | Ō | | | 0 | 0 | 0 | 1 | 0 | 0 | | | 0 | 0 | 1 | 1 | 0 | 0 | | | 0 | 0 | 1 | 0 | 0 | 0 | | | 0 | 1 | 1 | 0 | 0 | 0 | | | 0 | 1 | 1 | 1 | 0 | 1 | | | 0 | 1 | 0 | 1 | 1 | 1 | | | 0 | 1 | 0 | 0 | 1 | 1 | | | 1 | 1 | 0 | 0 | 1 | 1 | | | 1 | 1 | 0 | 1 | 1 | 1 | | | 1 | 1 | 1 | 1 | 1 | 1 | | | 1 | 0 | 1 | 1 | 1 | 1 | | | 1 | 0 | 1 | 0 | 1 | 0 | | | 1 | 0 | 0 | 0 | 0 | 0 | | #### **EQUATIONS** You are to design and microcode a controller (using the Am2910!) to handle the following intersection: There are four lights for straight-through traffic: | RED | YELLOW | GREEN | | | |-----|--------|-------|------|--------| | NA | 15s | 80s | MAIN | STREET | | NA | 10s | 40s | SIDE | STREET | There are four lights for protected left turn traffic: | RED | YELLOW | GREEN AR | ROW | | |-----|--------|----------|------|---------| | NA | 10s | 40s | вотн | STREETS | The four sensors, A, B, C, D, produce the SLT and MLT signals (side left turn, main left turn). In case you are wondering, Sunnyvale really has a light that works like this! Precocious students have been known to find it. To make the problem interesting, there are a few added considerations. If there is an accident, there is a manual override which allows all of the lights to be set to RED FLASH. And, because day traffic is heavier than night traffic, the controller can sense a control signal (timer generated if you wish) that tells it if it is day (normal operation), or night, when the straight-through lights on main street are set to YELLOW FLASH and all others are set to RED FLASH. Remember, you must be able to go back and forth: AND If you have added up all the different lights, there are 5 different states: RED, YELLOW, GREEN, RED FLASH, YELLOW FLASH. We will assume that GREEN and GREEN ARROW are the same. Five states means three lines of encoded controls into the individual traffic lights: To make the problem even more interesting, there is a constraint on the way that the lights may be sequenced (remember that you are learning how to implement under constraints - this is a given constraint). Basically, the sequence must be a grey code, ie., only one signal line may change per clock step per light. #### SAMPLE SEQUENCE | 12 | 1 | 0 | | |----|---|---|--------------| | 0 | 0 | 0 | RED | | 0 | 1 | 0 | RED | | 1 | 0 | 0 | RED | | 0 | 0 | 1 | YELLOW | | 0 | 1 | 1 | GREEN | | 1 | 0 | 1 | YELLOW FLASH | | 1 | 1 | 0 | RED FLASH | This is an example and happens to be what the code that is shown in the next pages was written to support. You can modify this slightly and reduce your code (the record so far is 27 microinstructions). This is the stable-state diagram (does not show transitions). There is a subtle error or two here - you find them! #### BASIC CONTROLLER HARDWARE The output enable of the pipeline register is grounded. The output enables generated by the Am2910 are unused. #### THE MICROPROGRAM (Draft version) | | | SEQUE | NCE CONTRO | L | | LIGHT CONTROL | | | | |-------------|--------|---------------|-------------|-------------------|-----|---------------|------|------|------------------| | DE C<br>ADR | LABEL | 2910<br>INSTR | HUX<br>TEST | COUNTER<br>Branch | s | HLT | \$LT | н | COMMENT | | 0 | HAIN | LOCT | | 15 | RO | RO | RQ | R2 | LOAD CNTR | | 1 | HLP | RPCT | | HLP | RO | RO | RO | G | LOOP PL-MAIN | | 2 | | CONT | - | | RO | RO | RÓ | Y | | | 3 | | CJP | HLT 7 | MLT | RO | RO | RO | Y | MAIN LT TEST | | 4 | | LOCT | | 7 | R2 | RO | R O | γ | | | 5 | SIDE | RPCT | | SIDE | G | ŔŌ | RO | RÔ | LOGP PL- SIDE | | 6 | | CJP | MANUAL? | MANUAL | Y | RO | RD | RO | MANUAL OVERRIDE | | 7 | | CJP | NIGHT? | NIGHT | Y | RO | RO | RO | NIGHT TEST? | | . 8 | | CJP | SLT? | MAIN | Y | RO | RO | R O | SIDE LT TEST | | 9 | SLT | LDCT | | 7 | RO | RO | R 2 | RO | SIDE LT LOOP | | 10 | SLTLP | RPCT | | SLTLP | RO | 80 | G | RO | LOOP PL | | 11 | | CONT | | | RO | RO | Υ. | RO | | | 12 | | JHAP | | MAIN | RO | R0 | Y | RO | MAP TIED TO PL | | 13 | MLT | LOCT | | 7 | RO | R2 | RO | Y | HAIN LT LOOP | | 14 | HLTLP | RPCT | | HLTLP | RO | G | RO | RO | LOOP PL | | 15 | | LDCT | | 7 | RO | Y | RO | RO | 1 | | 16 | L | JHAP | | SIDE | R2 | Υ | RO | R0 | | | 17 | NIGHT | CONT | | | Y | RO | RO | R'O | NIGHT LOOP | | 18 | | CONT | | | R0 | R O | RÔ | R 4 | | | 19 | | LOCT | | 16 | R4 | R 4 | R4 | ΥF | | | 20 | NITLP | RPCT | | NITLP | RF | RF | RF | YF | LOOP PL | | 2.1 | | LDCT | | 16 | RF | RF | RF | ΥF | | | 22 | | CJP | HANUAL? | FIX | RF | RF | RF | ΥF | MANUAL OVERRIDE? | | 23 | 1 | CJP | NIGHT? | NITLP | RF | RF | RF | ΥF | CONTINUE NIGHT? | | 24 | | CONT | | | 84 | R 4 | R4 | , R4 | | | 25 | | JMAP | | MAIN | RO. | RO | RO | RO | | | 26 | MANUAL | CONT | | | Y | R O | RO | R0 | MANUAL | | 2 7 | ] | CONT | : | | Y | RO. | RO | RO | - | | 28 | | CONT | | | RO | R D | RO | RO | | | 29 | | LDCT | | 16 | R4 | R4 | R 4 | R 4 | İ | | 30 | ENTRY | RPCT | | ENTRY | RF | RF | RF | RF | LDOP PL | | 31 | 1 | LOCT | | 16 | RF | RF | RF | RF | | | 32 | | CJP | HANUAL? | ENTRY | RF | RF | RF | RF | CONTINUE MANUAL? | | 33 | | CONT | | | R 4 | R4 | R 4 | R 4 | | | 34 | ٠. | JMAP | | MAIN | RO | R O | RO | RO | | | 35 | FIX | JMAP | | ENTRY | RF | RF | RF | R 4 | ADJUST SEQ FOR | | • | | | | | | • | | | MANUAL | | • | | | | | | • | | | | | • | | | | | | • | | | EMPTY AREA | | • | | | | | | | | | | | 63 | | JZ | | MAIN | RO | RO | RO | 80 | JUMP ZERO AND | | | · | <del></del> | | <u> </u> | | | | | RESET | Review the preceeding microcode carefully and note the following. - a. The actual numerical address is given, in this case in decimal but HEX would have been even better. Whichever you use, note that you label it. - b. Labels are used and they have some relevancy to what is happening in the program. MLT refers to main left turn; NITLP is the RPCT loop for nighttime operation; SIDE is the normal, straight traffic, side street operation, etc. - c. All sequence control (microprogram sequence) fields are grouped together and characterize the individual microinstructions. The Am2910 instruction is given first, followed by the conditional MUX select field (to select which signal line is to be tested), and then the branch address field. - d. The branch address field is an overlay field whose meaning at any particular time is controlled by the Am2910 instruction. This is called "bit steering". The values for the cases when this field is a branch address field are labels. The values for the cases when this field is a counter field are given a decimal numerics. If this field were also a status-mask field for the Am2914, which is possible, those values might be given as HEX values or even better in mnemonics unique to the usage. The point is, when a field serves more than one purpose, make sure that the code is clear as to the usage in any given microinstruction. - e. The controls for the traffic lights are grouped and it is assumed that each field controls two lights. The mnemonics go with the light sequence diagram (R0 = 000 which is RED, R2 = 010 which is also RED, RF and YF are the flashing lights, etc.). - f. Note the comment field. This is important! Comments help someone else read your program and they help you to remember the program when updates, enhancements are being made. - g. Also make note of the vertical and horizontal lines that have been drawn throughout the microprogram. The horizontal lines group the various operations together and each group has a meaningful label. The various vertical lines delineate each field but also group the fields into the microprogram sequence control and light control functions. The vertical lines are not hard to add into the microprogram as you would write it on a AMC SYS/29 (use TAB to alligh the fields). The horizontal lines can be easily achieved by using a comment-only line (a semicolon and \*s). Whatever you use, the point is to visually separate the code into the different functions for the benefit of the humans who must read it. - h. Examine the testing that occurs following the side street green cycles. There are three tests being made: 1) is there an emergency condition (MANUAL?); 2) is it time to switch to night operation (NIGHT?); and 3) is a protected left turn requested (SLT?). These three tests are being done in the proper priority order, i.e., most important tested first. This is a good example of "polled interrupt" where the microprogram must test for each condition, one at a time. As an exercise, correct the "errors" that you detect but also reduce the microprogram to fit into three 32x8 PROMS. ### DESIGNATIONE ## THE FAMOUS COFFEE MACHINE 2900 FAMILY STUDY GUIDE SIMPLE PROBLEMS FOR BEGINNERS THE FAMOUS COFFEE MACHINE You are to design a coffee machine controller that will handle a simple, non-fault diagnostic coffee dispenser. It will work as follows: - Do nothing until a coin is detected. - On coin detection, turn on the busy light and drop a cup. - The cup has 1.5 seconds to get into place. - There is no way to know if the cup is correctly positioned or if it even is there. - Water is turned on for 1.0 second prior to the release of powders (so it isn't unsightly in the bottom of the cup). - Water will remain on continuously for a total of 10 seconds. - The busy light will remain on until the seguence is completed. - Depending upon the selection, either coffee, soup, or chocolate will be dispenced. coffee 2.5 seconds soup 2.0 seconds chocolate 2.0 seconds If coffee was selected, when the coffee is finished, sugar or cream is dispensed. sugar 1.5 seconds cream 2.0 seconds - If sugar and cream was the selection, when the sugar is finished, start cream. - 11. After the water has completed filling the cup, allow 3.5 seconds for cup removal before testing for the presence of the next coin. - 12. You have a 0.5 second clock pulse. There are six possible sequences: COFFEE, BLACK COFFEE, CREAM COFFEE, SUGAR COFFEE, CREAM AND SUGAR CHOCOLATE SOUP #### HARDWARE CONFIGURATION #### MULTIPLEXER A = COFFEE B = CREAM C = SUGAR MUX INPUT: COFFEE-ON <=> A + AB + AC + ABC CREAM-ON <=> AB + ABC SUGAR-ON <=> AC + ABC 2900 FAMILY STUDY GUIDE SIMPLE PROBLEMS FOR BEGINNERS THE FAMOUS COFFEE MACHINE #### THE MICROPROGRAM | LABEL | ADDR | Am2910 <br>INSTR. | COND. | BRANCH <br>COUNTER | MACHINE<br>CONTROL | |----------------|----------------------------|-------------------------------------------|--------------------------------|-------------------------------------|---------------------------------------------------------------------------------| | ZERO | 0<br>1<br>2<br>3<br>4<br>5 | CJP<br>CONT<br>CONT<br>CONT<br>CJP<br>CJP | COIN<br>#<br>#<br>CHOC<br>SOUP | ZERO<br>#<br>#<br>#<br>CHOC<br>SOUP | OFF CUP-BUSY BUSY BUSY WATER-BUSY WATER-BUSY | | COFFEE | 6<br>7<br>8<br>9 | LDCT<br>CONT<br>CONT<br>CJP<br>CJP | #<br>#<br>SUGAR<br>CREAM | 12<br>#<br>#<br>SUGAR<br>CRE-2 | COFFEE-WTR-BUSY COFFEE-WTR-BUSY COFFEE-WTR-BUSY COFFEE-WTR-BUSY COFFEE-WTR-BUSY | | LOOP | 11<br>12 | RPCT<br>LDCT | # | LOOP<br>4 | WATER-BUSY<br>BUSY | | BUSY | 13<br>14 | RPCT<br>JZ | # | BUSY<br>ZERO | BUSY<br>BUSY | | SUGAR | 15<br>16<br>17<br>18 | CONT<br>LDCT<br>CJP<br>CJP | #<br>#<br>CREAM<br>PASS | #<br>9<br>CREAM<br>LOOP | COFFEE-WTR-BUSY<br>SUGAR-WTR-BUSY<br>SUGAR-WTR-BUSY<br>SUGAR-WTR-BUSY | | CREAM<br>ENTRY | 19<br>20<br>21<br>22<br>23 | LDCT<br>CONT<br>CONT<br>CONT<br>CJP | #<br>#<br>#<br>PASS | 5<br>#<br>#<br>£ | SUGAR-WTR-BUSY CREAM-WTR-BUSY CREAM-WTR-BUSY CREAM-WTR-BUSY CREAM-WTR-BUSY | | CRE-2 | 24<br>25 | LDCT<br>CJP | #<br>PASS | 8<br>ENTRY | CREAM-WTR-BUSY<br>CREAM-WTR-BUSY | | CHOCLP | 26<br>27<br>28<br>29<br>30 | CONT<br>LDCT<br>RPCT<br>LDCT<br>CJP | #<br>#<br>#<br>PASS | #<br>5<br>CHOCLP<br>8<br>LOOP | WATER-BUSY<br>CHOC-WTR-BUSY<br>CHOC-WTR-BUSY<br>WATER-BUSY<br>WATER-BUSY | |--------|----------------------------|-------------------------------------|---------------------|-------------------------------|--------------------------------------------------------------------------| | SOUP | 31<br>32<br>33<br>34 | CONT<br>CONT<br>LDCT<br>CJP | #<br>#<br>#<br>PASS | #<br>#<br>13<br>LOOP | SOUP-WTR-BUSY<br>SOUP-WTR-BUSY<br>SOUP-WTR-BUSY<br>SOUP-WTR-BUSY | | | : | | | | | | | 63 | J2 | # | # | OFF | ### Design, Probley: ## A very simple computer 2900 FAMILY STUDY GUIDE SIMPLE PROBLEMS FOR BEGINNERS A VERY SIMPLE COMPUTER Assume that you have a simple computer such as is shown in the figure on the following page. It consists of an elementary control unit which receives as input: the op code from the instruction the result of a test on the contents of the ACC $\langle ACC \rangle = 0$ and which generates as output: the function select control for the ALU the carry-in for the ALU the load and enable controls for the MAR memory address register PC program counter ACC accumulator the read/write controls for the memory the enable for the memory controls for all of the bus signals the R bus data-in bus; also to ALU R port the D bus data-out bus; also to ALU D port the F bus accumulator output #### HARDWARE CONFIGURATION AND CONTROLS 2900 FAMILY STUDY GUIDE SIMPLE PROBLEMS FOR BEGINNERS A VERY SIMPLE COMPUTER #### BASIC COMPUTER INSTRUCTION SET The following assembly-level single address instructions are to be supported by the hardware through microprogramming. You are to assign the opcode and the starting address for the supporting microroutine (assume a memory map). | SYNTAX | SEMANTICS | |-----------|----------------------------------------------------------------------------------------------| | LDA, addr | <acc> &lt; <addr></addr></acc> | | STO, addr | <addr> &lt; <acc></acc></addr> | | ADD, addr | <acc> &lt; <acc> + <addr></addr></acc></acc> | | SUB, addr | <acc> &lt; <addr> - <acc></acc></addr></acc> | | OR, addr | <acc> &lt; <acc> .OR. <addr></addr></acc></acc> | | AND, addr | <acc> &lt; <acc> .AND. <addr></addr></acc></acc> | | XOR, addr | <acc> &lt; <acc> .EXOR. <addr></addr></acc></acc> | | INA | <acc> &lt; <di bus=""></di></acc> | | OUT | <do bus=""> &lt; <acc></acc></do> | | JMP, addr | <pc> &lt; addr jump immediate</pc> | | JMP, addr | <pc> &lt; <addr> jump indirect</addr></pc> | | JMZ, addr | IF $\langle ACC \rangle = 0$ THEN $\langle PC \rangle \langle$ addr immediate | | JMZ, addr | IF $\langle ACC \rangle = 0$ THEN $\langle PC \rangle \langle \langle addr \rangle$ indirect | You may choose to do either immediate or indirect jump instructions (not both) The entire microprogram should not exceed 16 microinstructions 2900 FAMILY STUDY GUIDE SIMPLE PROBLEMS FOR BEGINNERS A VERY SIMPLE COMPUTER #### MICROROUTINE FOR THE ADD INSTRUCTION START: <PC> --> <MAR> <<MAR>> --> <IR>, <MAR> GOTO ADD <ACC> <-- <ACC> + <<MAR>> <PC> <-- <PC> + 1 GOTO START Contents of PC register to MAR $\,$ Fetch instruc. to IR (opcode) and MAR (addr) Case jump on opcode Fetch data and add Increment PC register This is a conventional flow for a CPU The following is one solution for the simple computer design. Step one: define all of the controls NEXT ADDR INSTR: CONT JMP JIFO (CJP) JOPC (JMAP) ALU FUNCTIONS: ADD SUB AND OR XOR ONE (D+1 --> F) RFT (PASS R) DTF (PASS D) R BUS CONTROL: DIR (D-IN TO R-PORT) MDOR (MEMORY TO R-PORT) F BUS CONTROL: FACC (F TO ACC) FPC (F TO PC) FMAR (F TO MAR) NFD (NO CONNECTION) D BUS CONTROL: ACCD (ACC TO D) PCD (PC TO D) MEMORY CONTROL: READ WRITE DISABLE INSTR REG CONTROL: RIR (READ OPCODE TO IR) NRIR (NO IR CONNECTION) 2900 FAMILY STUDY GUIDE SIMPLE PROBLEMS FOR BEGINNERS SOLUTION FOR A VERY SIMPLE COMPUTER Step two: design first-draft of microword format | ADDR LABEL | | | MEMORY<br>CONTRL | | | | D BUS | F BUS | |------------|---|---|------------------|---|-------------|---------|-------|-------| | (BITS) | 2 | 4 | 2 | 3 | 1 | 1 | 2 | 4 | | | l | l | l | l | l <u></u> ' | <u></u> | · | ll | Step three: develop a flowchart of the microprogram to see where the microroutines can share microinstructions. Even a crude worksheet is important documentation. The more comments on it, the easier it is for a stranger to follow. 2900 FAMILY STUDY GUIDE DESIGN EXAMPLES SOLUTION FOR A SIMPLE COMPUTER Step 4: draft the microprogram from the definition file and the flowchart. | | | NEXT | BRANCH | MEMORY | ALU | SOURCE | IR | | | | |------|-------|------|--------|--------|-----|--------|--------|-------|-------|---------| | ADDR | LABEL | ADDR | ADDR | CONTRL | SEL | R BUS | CONTRL | D BUS | F BUS | COMMENT | | | | 1 | | | | | | | | | | 0 | START | CONT | # | DIS | DTF | # | NRIR | PCD | FMAR | PC->MAR | | 1 | | CONT | # | READ | RTF | MDOR | RIR | # | FMAR | FETCH | | 2 | | JOPC | # | DIS | # | # | NRIR | # | NFD | DECODE | | 3 | LDA | JMP | FETCH | READ | RTF | MIDOR | NRIR | # | FACC | | | 4 | STO | JMP | FETCH | WRITE | # | # | NRIR | ACCD | NFD | | | 5 | ADD | JMP | FETCH | READ | ADD | MDOR | NRIR | ACCD | FACC | | | 6 | SUB | JMP | FETCH | READ | SUB | MDOR | NRIR | ACCD | FACC | | | 7 | OR | JMP | FETCH | READ | QR | MDOR | NRIR | ACCD | FACC | | | 8 | AND | JMP | FETCH | READ | AND | MDOR | NRIR | ACCD | FACC | | | 9 | XOR | JMP | FETCH | READ | XOR | MDOR | NRIR | ACCD | FACC | | | 10 | INA | JMP | FETCH | DIS | RTF | DIR | NRIR | # | FACC | | | 11 | OUT | JMP | FETCH | DIS | # | # | NRIR | ACCD | NFD | | | 12 | COTO | CONT | # | DIS | DTF | # | NRIR | PCD | FMAR | | | 13 | | JMP | START | READ | RTF | MIDOR | NRIR | # | FPC | REFETCH | | 14 | IF | JIF0 | COTO | DIS | # | # | NRIR | # | NFD | | | 15 | FETCH | JMP | START | DIS | ONE | # | NRIR | PCD | FPC | INCR PC | In this program jump direct to address is microprogrammed. Since there is no path from MAR to PC, the instruction must be refetched! ie., the hardware chosen has a more obvious effect on the actual microprogram than it has on the higher level language. The assembly level or the machine level programmer only needs to know the semantics and the syntax of the language. 2900 FAMILY STUDY GUIDE DESIGN EXAMPLES SOLUTION FOR A SIMPLE COMPUTER Step 5: once the microprogram has been written it is possible to establish the memory map which will translate each opcode into the corresponding starting address for its microroutine. | INSTRUCTION | OPC | DDE | ı | ROUTINE | ADDRESS | |-------------|------|-----|-----|---------|---------| | DESCRIPTION | NAME | # | 1 | LABEL | ACTUAL | | | | | - - | 1 | | | LOAD ACC | LDĀ | 0 | | LDÄ | 3 | | STORE ACC | STO | 1 | | STO | 4 | | ADD ACC | ADD | 2 | | ADD | 5 | | SUB ACC | SUB | 3 | | SUB | 6 | | OR ACC | OR | 4 | | OR | 7 | | AND ACC | AND | 5 | | AND | 8 | | XOR ACC | XOR | 6 | | XOR | 9 | | INPUT ACC | INA | 7 | | INA | A | | OUTPUT ACC | OUT | 8 | | OUT | В | | JUMP addr | JMP | 9 | | GOTO | С | | JMP addr IF | JMZ | A | | IF | D | The actual opcode assignment is unimportant in this case. 2900 FAMILY STUDY GUIDE DESIGN EXAMPLES SOLUTION FOR A SIMPLE COMPUTER # INDIRECT JUMP SOLUTION | | | NEXT | BRANCH | MEMORY | ALU | SOURCE | IR | | | | |------|-------|------|--------|--------|-----|--------|--------|-------|-------|---------| | ADDR | LABEL | ADDR | ADDR | CONTRL | SEL | R BUS | CONTRL | D BUS | F BUS | COMMENT | | | | | | | | | | | | | | 0 | START | CONT | # | DIS | DTF | # | NRIR | PCD | FMAR | PC->MAR | | 1 | | CONT | # | READ | RTF | MDOR | RIR | # | FMAR | FETCH | | 2 | | JOPC | # | DIS | # | # | NRIR | # | NFD | DECODE | | 3 | LDA | JMP | FETCH | READ | RTF | MDOR | NRIR | # | FACC | | | 4 | STO | JMP | FETCH | WRITE | # | # | NRIR | ACCD | NFD | | | 5 | ADD | JMP | FETCH | READ | ADD | MDOR | NRIR | ACCD | FACC | | | 6 | SUB | JMP | FETCH | READ | SUB | MDOR | NRIR | ACCD | FACC | | | 7 | OR | JMP | FETCH | READ | OR | MDOR | NRIR | ACCD | FACC | | | 8 | AND | JMP | FETCH | READ | AND | MDOR | NRIR | ACCD | FACC | | | 9 | XOR | JMP | FETCH | READ | XOR | MDOR | NRIR | ACCD | FACC | | | 10 | INA | JMP | FETCH | DIS | RTF | DIR | NRIR | # | FACC | | | 11 | OUT | JMP | FETCH | DIS | # | # | NRIR | ACCD | NFD | | | 12 | COTO | JMP | START | READ | RTF | MDOR | NRIR | # | FPC | | | 13 | IF | JIF0 | COTO | DIS | # | # | NRIR | # | NFD | | | 14 | FETCH | JMP | START | DIS | ONE | # | NRIR | PCD | FPC | INCR PC | - Q: Could both addressing modes exist in this system? - Q: How many lines of microcode would be needed? # **DESIGN PROBLEM:** # A SIMPLE DATA MONITOR #### PROBLEM: Design a simple data-gatherer such that the data input is read into a 4-bit data-input register. Assume that the data is always ready to be read into the data-in register; we can add a ready-to-receive bit later for "handshaking". When data is output, the monitor waits for an ACK signal before proceeding with its operation. The monitor is to have a 12-bit RALU. A minimum of five registers are to behave as counters. ## **DEVICES:** Use an Am2910 and an ALU made up out of Am2901s. ## DESIGN APPROACH: Use a pipelined PROM control memory, a status register (1-bit) and a memory map to decode the data input. ## MICROPROGRAM DESCRIPTION: START 1. INITIALIZE REGISTERS $$R_0 \leftarrow 0$$ $R_1 \leftarrow 0$ $R_2 \leftarrow 0$ $R_3 \leftarrow 0$ $R_4 \leftarrow 0$ NEXT: 2. LOAD DATA-IN REGISTER 3. IF DATA-IN = 0 THEN $$R_0 < -- R_0 + 1$$ IF $C_{n+4} = 1$ THEN JUMP SUBO ELSE $$R_1 \leftarrow R_1 + 1$$ ALL NUMBERS ARE POSITIVE IF $C_{n+4} = 1$ THEN JUMP SUBO 4. CASE BRANCH IF $$0 < DATA-IN \le 5$$ THEN $$R_2 \leftarrow R_2 + 1$$ THEN $$R_3 \leftarrow R_3 + 1$$ IF 10 < DATA-IN THEN $$R_4 \leftarrow R_4 + 1$$ 5. BRANCH TO NEXT ## 2900 FAMILY STUDY GUIDE A SIMPLE DATA MONITOR PROBLEM SUB0:6. R<sub>2</sub> --> DATA-OUT 7. IF ĀCK THEN WAIT 8. R<sub>3</sub> --> DATA-OUT 9. IF ĀCK THEN WAIT 10. R<sub>4</sub> --> DATA-OUT 11. IF ĀCK THEN WAIT 12. RESET REGISTERS $$R_2 \leftarrow 0$$ $R_3 \leftarrow 0$ $R_4 \leftarrow 0$ 13. RETURN ## BASIC HARDWARE \* CLOCK INTO: Am2910 Am2901s PIPELINE REGISTER DATA REGISTERS (12 BITS AND 4 BITS) STATUS REGISTER (2 BITS) # 2900 FAMILY STUDY GUIDE A SIMPLE DATA MONITOR #### MICROWORD FORMAT [ DRAFT VERSION ] LABEL 2910 COND BR ADDR SRCE FUNC DEST CARRY A B DATA DATA ADDR INSTR MUX COUNTER A L U IN ADDR ADDR IN CTRL OUT CTRL The final number of bits that are required for the microword is a function of the final microprogram. An initial guess can be made by examining what exists so far in the microword format. | 1. | LABEL/ADDR | This | will | be | the | actua. | l ir | 1-p. | lace | |----|------------|------|-------|----|-----|--------|------|------|----------| | | • | | | | | | | | n last. | | | | | Label | s | are | filled | in | as | created. | - 2. 2910 INSTR The 4-bit instruction field for the microprogram controller - 3. COND MUX The conditional MUX select control is 1 bit so far. - 4. BR ADDR/COUNTER The branch address field 4-6 bits is a good guess so far. - ALU CONTROL These three fields are each 3 bits. - 6. CARRY IN For the ALU, 1 bit. - 7. A ADDR Selects the ALU registers, need 5 B ADDR registers, so two 3 bit fields. - 8. DATA IN CTRL Load the DATA-IN register, 1 bit. - 9. DATA OUT CTRL Load the DATA-OUT register, 1 bit. Both 8 and 9 will expand to 2 bits if enables are also needed. Total # bits: 28 bits +1 | LABEL<br>/ADDR | 2910<br>INSTE | COND<br>MUX | BP ADDR | SRCE<br>A | FUNC<br>L | DEST<br>U | C | ADDR<br>N A | ADDR<br>B | DATA-IN<br>CONTROL | DATA-OUT<br>CONTROL | MEMORY<br>MAP SEL | |----------------|---------------|-------------|---------|-----------|-----------|-----------|-----|-------------|-----------|--------------------|---------------------|-------------------| | * FIRS | T WRIT | E CODE | TOIN | TIA | LÍZ | E REG | IST | ers | | | - <del></del> | | | START | CONT | # | # | AB | EXOR | RAMF | # | R0 | RO | NOLOAD | NOLOAD | 0 | | ] | CONT | # | # | AB | EXOR | RAMF | # | Rl | Rl | NOLOAD | NOLOAD | 0 | | 2 | CONT | # | ·# | AB | EXCR | RAMF | # | R2 | R2 | NOLOAD | NOLOAD | 0 | | 3 | CONT | # | # | AB. | EXOR | RAME | # | R3 | R3 | NCLCAD | NOLOAD | 0 | | 4 | CONT | # | # | AB | EXOR | RAMF | # | R4 | R4 | NCLOAD | NCLOAD | 0 | | NEXT | CONT | # | # | # | ¥ | NOP | # | # | # | LCAD | NCLOAD | 0 | NOW CONSIDER HOW YOU ARE GOING TO HANDLE THE MULTIPLE BRANCHES? ONE SOLUTION WHICH HAS BEEN STARTED HERE IS TO HAVE A LARGER MEMORY MAP AND AN EXTRA ADDRESS LINE INTO IT SO THAT THE INPUT DATA CAN BE DECODED TWICE USING DIFFERENT PORTIONS OF THE MAP FOR EACH ACCESS. ANOTHER SOLUTION WOULD BE TO READ THE DATA INTO AN ALU REGISTER AND USE THE ZERO TEST STATUS TO MAKE THE FIRST DECISION AND USE THE MEMORY MAP FOR THE CASE BRANCH DECISION. THE MICROWORD WOULD BE THE SAME WIDTH IN BOTH CASES (THE Z STATUS REQUIRES A WIDER STATUS REGISTER AND CONDITION CODE MUX). WE WILL EXAMINE BOTH SOLUTIONS. ## 2900 FAMILY STUDY GUIDE A SIMPLE DATA MONITOR PROBLEM ## THE DOUBLE MAP: | LABEL<br>/ADDR | 2910<br>INSTR | MUX | | A | _ | DEST<br>U | | ADDR<br>NA | ADDR<br>B | DATA-IN<br>CONTROL | DATA-OUT<br>CONTROL | MEMORY<br>MAP SEL | |----------------|---------------|-------|-------|------|-------|-----------|-------|------------|-----------|--------------------|---------------------|-------------------| | 6 | | # | | # | <br># | NOP | <br># | # | # | NOLOAD | | 0 | | DISZ | CONT | # | # | | ÄDD | RAME | H | Ř0 | Ř0 | NOLOAD | NOLOAD | 0 | | 8 | JSUB | Cn+4 | SUB0 | # | # | NOP | # | # | # | NOLOAD | NOLOAD | 0 | | 9 | CONT | # | # | AB | OR | rama | # | R1 | R1 | NOLOAD | LOAD | 0 | | WAITA | CJP | NOACK | WAITA | # | # | NOP | # | #<br># | # | NOLOAD | | 0 | | В | CJP | PASS | CASE | # | # | NOP | # | | # | NOLOAD | | 0 | | DGRZ | CONT | # | # | ΑZ | ADD | RAMF | Н | Rl | R1 | NOLOAD | | 0 | | D | JSUB | Cn+4 | SUB0 | # | # | NOP | # | # | # | NOLOAD | | 0 | | E | COMI | # | # | AB | OR | RAMA | # | R0 | R0 | NOLOAD | LOAD | 0 | | WAITB | CJP | NOACK | WAITB | # | # | NOP | # | # | # | NOLOAD | | 1 | | CASE | JMAP | # | # | # | # | NOP | # | # | # | NOLOAD | | 1 | | L5 | CJP | PASS | NEXT | AZ | ADD | RAME | Н | R2 | R2 | NOLOAD | | 0 | | GR5L10 | | PASS | NEXT | ΑZ | ADD | RAME | H | R3 | R3 | NOLOAD | | 0 | | GR10 | CJP | PASS | NEXT | AZ . | ADD | RAMF | H | R4 | R4 | NOLOAD | NOLOAD | 0 | | * S U | BRO | וודט | N E | | | | | | | | | | | SUB0 | CONT | # | # | AB | OR | RAMA | # | R2 | R2 | NOLOAD | LOAD | 0 | | WAIT1 | CJP | NOACK | WAIT1 | # | # | NOP | # | # | # | NOLOAD | NOLOAD | 0 | | 16 | CONT | # | # | AB | OR | RAMA | # | R3 | R3 | NOLOAD | LOAD | 0 | | WAIT2 | CJP | NOACK | WAIT2 | # | # | NOP | # | # | # | NOLOAD | NOLOAD | 0 | | 18 | CONT | # | # | AB | OR | RAMA | # | R4 | R4 | NCLOAD | LOAD | 0 | | WAIT3 | CJP | NOACK | WAIT3 | # | # | NOP | # | # | # | NOLOAD | NOLOAD | 0 . | | lA | CONT | # | # | AB | EXOR | RAMF | # | R2 | R2 | NOLOAD | | 0 | | 1B | CONT | # | # | AB | EXOR | RAMF | # | R3 | R3 | NOLOAD | | 0 | | 1C | CONT | # | # | AB | EXOR | RAME | # | R4 | R4 | | NOLOAD | 0 | | 1D | CRTN | PASS | # | # | # | NOP | # | # | # | NOLOAD | NOLOAD | 0 | TOTAL NUMBER OF MICROWORDS = 1D (HEX) = 29 TOTAL NUMBER OF BRANCH ADDRESS LINES = 5 # THE SOLUTION FOR A SINGLE MEMORY MAP WITH A TEST OF THE Z STATUS BIT IS VERY SIMILIAR (ONE MICROWORD LONGER) LABEL 2910 COND BR ADDR SRCE FUNC DEST C ADDR ADDR DATA-IN DATA-OUT MEMORY | /ADDR | INSTR | MUX | COUNTER | A | L | U | IN | A | В | CONTROL | CONTROL | MAP SEL | |---------|-------------|--------|---------|-----|------|-------|------|----|-----|---------|---------|---------| | * FIRS | T WRIT | E CODE | TOINI | ŢIA | LIZ | E REG | ISTE | RS | | | | | | START | CONT | # | # | AB | EXOR | RAMF | # | R0 | R0 | NOLOAD | NOLOAD | NA | | 1 | CONT | # | # | AB | EXOR | RAMF | # | Rl | R1 | NOLOAD | NOLOAD | NA | | 2 | CONT | # | # | AB | EXOR | RAMF | # | R2 | R2 | NOLOAD | NOLOAD | NA | | 3 | CONT | # | # | AB | EXOR | RAMF | # | R3 | R3 | NOLOAD | NOLOAD | N/A | | 4 | CONT | # | # | AB | EXOP | RAME | # | R4 | R4 | NOLOAD | NOLOAD | NA | | NEXT | CONT | # | # | # | # | NOP | # | # | # | LOAD | NOLOAD | N/A | | 6 | CONT | # | # | DZ | OP | RAME | # | # | # | ENABLE | NOLOAD | NA | | 7 | CJP | NOTZ | DNOTZ | # | # | NOP | # | # | # | NOLOAD | NOLOAD | NA | | DISZ | CONT | # | # | ΑZ | ADD | RAME | Н | R0 | R0 | NOLOAD | NOLOAD | N/A | | 9 | <b>JSUB</b> | Cn+4 | SUB0 | # | # | NOP | # | # | # | NOLOAD | | NA | | A | CONT | # | # | AB | OR | RAMA | # | R1 | R1 | NOLOAD | | NA | | WAITA | CJP | NOACK | WAITA | # | # | NOP | # | # | # | NOLOAD | NOLOAD | NA | | C | CJP | PAS\$ | CASE | # - | # | NOP | # | # | # | NOLOAD | | NA. | | DNOTZ | CONT | # ' | # | AZ | ADD | RAMF | H | Rl | R1 | NOLOAD | | NA | | E | J\$UB | Cn+4 | SUB0 | # | # | NOP | # | # | # | NOLOAD | | NA | | F | CONT | # | # | AB | OR | rama | # | R0 | P0 | NOLOAD | | NA | | | CJP | NOACK | | # | # | NOP | # | # | # | NOLOAD | | NA | | CASE | JMAP | # | # | # | # | NOP | # | # | # | NOLOAD | | NA | | L5 | CJP | PASS | NEXT | AZ | ADD | RAME | H | R2 | R2 | NOLOAD | | NA | | GR5L10 | | PASS | NEXT | ΑZ | ADD | RAMF | H | R3 | R3 | NOLOAD | | NA | | GR10 | CJP | PASS | NEXT | AZ | ADD | RAME | H | R4 | P.4 | NOLOAD | NOLOAD | NA | | * S U E | BRO | ITU | 1 E | | | | | | | | | | | SUB0 | CONT | # | # | AB | OR | RAMA | # | R2 | R2 | NOLCAD | LOAD | NA | | WAIT1 | CJP | NOACK | WAITI | # | # | NOP | # | # | # | NOLOAD | | NA | | 17 | CONT | # | # | AB | OP. | rama | # | P3 | P3 | NOLOAD | | NA | | WAIT2 | CJP | NOACK | | # | # | NOP | # | # | # | NOLOAD | | NA | | 19 | CONT | # | # | AB | OR | rama | # | P4 | R4 | NOLOAD | LOAD | NA | | | CJP | NOACK | | # | # | NOP | # | # | # | NOLOAD | | NA | | 1B | CONT | # | # | AB | EXOR | RAMF | # | R2 | R2 | NOLOAD | NOLOAD | NA | | 1C | COMI | # | # | AB | EXOR | RAME | # | R3 | R3 | NOLOAD | MOLOAD | NA | | 1D | CONT | # | # | AB | EXOR | RAMF | # | R4 | R4 | NOLOAD | NOLOAD | NA | | 1E | CRTN | PASS | # | # | # | NOP | # | # | # | NOLOAD | NOLOAD | N/A | TOTAL NUMBER OF MICROWORDS = 1E (HEX) = 30 TOTAL NUMBER OF BRANCH ADDRESS LINES = 5 FOR BOTH OF THE MICROPROGRAMS, IF THE SYSTEM IS TO BE RESET OR INITIALIZED BY PULL-UP RESISTORS ON THE PROM ADDRESS LINES [THE 2910 IS OUTPUT-DISABLED; THE PULL-UPS SHOULD BE 10K EACH LINE], THEN ADD ONE MICROWORD FOR THE "JZ" INSTRUCTION (JZ=0000). PULL-DOWNS COULD BE USED AT THE INSTRUCTION LINE INPUT TO THE AM2910 (SEE HOTBACS CHAPTER 9; SUPER-16 COMPUTER). A RESET ON THE PROM PIPELINE REGISTER TO START THE REGISTER WITH ALL ZEROS COULD BE USED. AS AN EXERCISE, COMPLETE THE HARDWARE CONFIGURATION FOR THE VERSION OF THE MICROPROGRAM WHICH YOU CHOSE TO EXAMINE AND CONFIRM THAT THE MICROPROGRAM CANNOT BE FURTHER REDUCED. # SUMMARY OF THE TWO SOLUTIONS: Using two maps requires a larger mapping PROM. It also requires one more bit in microword width. Using the 2 status as a test requires a larger status register and a larger conditional test multiplexer. It also requires one more bit in the microword to select the larger multiplexer. 2900 FAMILY STUDY GUIDE A SIMPLE DATA MONITOR PROBLEM EXERCISE #### EXERCISE Redesign the data monitor, replacing the Am2901s with $\mbox{\bf Am29203s.}$ Everything else remains unchanged. # TEXT BOOK EXERCISES 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN:CONTROLLERS AND ALUS CHAPTER EXERCISES The following exercises are coordinated with the Chapters in <u>Bit Slice Design: Controllers and ALUs</u> (White; Garland Press; NY:1980) They are also sequenced on ED2900A, "Introduction to the 2900 Family", one of the seminars offered by the Customer Education Center of Advanced Micro Devices, Inc., Sunnyvale, CA. #### EXERCISES - CHAPTER ONE - 1. Obtain a current Am2900 Family Data Book and obtain a copy of the HOTBAC series. (This is the 9-chapter "How to Build a Computer" application note series produced by the Bipolar Applications Department of Advanced Micro Devices, Inc.) - 2. List five disadvantages of using bit-slice versus an MOS FIS microprocessor. - 3. List five advantages of using bit-slice versus an MOS FIS microprocessor. #### EXERCISES - CHAPTER TWO - 1. Using some typical devices, sketch the schematic for the improved-architecture CCU as developed in this chapter. - 2. Make up the parts list for the CCU. - 3. Compute the worst-case timing path for your design. This is your minimum clock-cycle time. 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN: CONTROLLERS AND ALUS CHAPTER EXERCISES #### EXERCISES - CHAPTER THREE - 1. For the architecture and the microword defined in section 3.3, write and diagram sample code as was done to demonstrate unconditional and conditional branching. Demonstrate subroutine call and return. - 2. Using the Am29811 (latest data sheet), a condition code multiplexer (MUX), and the Am2909/11 (also the latest data sheet), write microcode to call a subroutine if the test input is true, and call a second subroutine if it is false. The first subroutine contains a five (5) step loop which executes sixteen (16) times. The second subroutine contains a five (5) step loop which repeats until a second test is true. Show how to return to the main program. NOTE: Only the sequence control portion of the microcode is of interest. - 3. Consider using the Am29803 in place of the condition code MUX. Is this reasonable? And, if not, why not? 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN: CONTROLLERS AND ALUS CHAPTER EXERCISES #### EXERCISES - CHAPTER FOUR - 1. Repeat exercise 3.2 using the Am2910 in place of the Am29811 and Am2911. - 2. What are the changes if a microroutine is called on the occurrence of an interrupt (condition tested = true), rather than a subroutine in the above exercise? - Sketch the CCU which uses an Am2914 and a vector mapping PROM in addition to the Am2910, which can support firmware-level interrupts and handle interrupts via subroutines (CJS, etc.) or microroutines (CJV, etc.). - 4. Refer to the latest Am2910 data sheet. a. What is the worst-case delay for data to pass from the D inputs to the Y outputs? - b. From the $\overline{CC}$ input to the Y, outputs? - From the I, inputs to the output-enable controls? - What is the worst case set up and hold time required for the internal register? - e. For the microPC? - For the instruction bits? - If the previous instruction alters the register/counter, what happens in terms of time delay? 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN:CONTROLLERS AND ALUS CHAPTER EXERCISES #### EXERISES - CHAPTER FIVE - 1. Draw the schematic for a 16-bit simple computer as defined in section 5.5, using the Am2901 and Am2910 devices. - 2. Develop all of the microcode required to support the instruction set given in section 5.5 (make simplifying assumptions concerning memory control, external devices, for the time being). - 3. Enhance the schmatic of exercise 5.1 so that the shift and rotate instructions of section 5.7.6 are supported. $\underline{\text{Do}}$ not use register instructions yet. - 4. Supplement the microcode of exercise 5.2 to include shift and rotate instructions. Design those instructions. - 5. Add the necessary hardware to allow register arithmetic to be possible with your computer. Assume both direct operand addressing with a default register used as the accumulator and general register addressing are supported. Assume also that the register addresses may come from the CCU pipeline or from the instruction register (use an AB MUX). - 6. Write the microcode to support the hardware additions made in exercise 5.5. ## EXERCISES - CHAPTER SIX - 1. Repeat exercise 5.3 using the Am2903 in place of the Am2901. - 2. Repeat exercise 5.4 using the Am2903 in place of the $\mbox{Am}\,2901$ . - 3. Repeat exercise 5.5 using the Am2903 in place of the Am2901. - 4. Repeat exercise 5.6 using the Am2903 in place of the Am2901. ## EXERCISES - CHAPTER SEVEN - 1. Replace the status register you should have had in your computer, as well as the four shift-rotate multiplexers, with an Am2904. - 2. Alter your microcode for this change. # EXAM ANSWERS EXERCISE SOLUTIONS | 1. LABEL<br>ADDR | | - | MUX<br>SEL | BR ADDR | 29803<br>INSTR | | |------------------|-----|---------|-------------|----------|----------------------------------------------|--------------------------------------------------------------------------------------------| | i | | CJP | A | - X | NO TEST | | | i + 1 | . | JP | # | 350 | <sup>Т</sup> з <sup>Т</sup> 1 | | | i + 2 | ! | JP | # | 360* | <sup>T</sup> 2 <sup>T</sup> 0 | <ul> <li>* address must have</li> <li>0 as final HEX</li> <li>digit if LSS 2909</li> </ul> | | j | - 1 | CJP | В | j + 2 | NO TEST | attached to 29803 | | j<br>j + 1 | . | | # | 370 | $^{\mathrm{T}}2^{\mathrm{T}}1^{\mathrm{T}}0$ | | | j + 2 | : 1 | JP | # | 380 | <sup>T</sup> 3 <sup>T</sup> 2 <sup>T</sup> 1 | | | 350 | 1 | JP | # | 20 | NO TEST | | | 351 | ļ | JP | #<br># | 200 | NO TEST | | | 352<br>353 | ļ | JP | # | 10<br>20 | NO TEST | | | 353 | 1 | JP | # | 20 | NO IESI | | | 360 | - 1 | JP | # | 10 | NO TEST | | | 361 | | JP | #<br>#<br># | 200 | NO TEST | | | 362 | ļ | JP | # | 30 | NO TEST | | | 363 | ı | JP | # | 40 | NO TEST | | | 370 | ļ | JP | # | 100 | NO TEST | | | 371 | ĺ | JP | # | 200 | NO TEST | | | | | le m | C | | | | | | | ET | ٠. | | | | | 2. | 29 | 10 inst | r. m | ux sel. | br addr. | | | 2. | 2910 | instr. mux | sel. br | addr. | | | | |----|---------|-------------|----------|-------|--------------|----|---| | | LDCT | # | | 5 | LOAD COUNTER | | | | | PUSH | A | | 9 | RELOAD BASED | ON | Α | | | S1:CONT | # | | # | | | | | | S2:CONT | # | | # | | | | | | S3:RFCT | # | | # | | | | | OR | LDCT | # | | 9 | | | | | | | _ | | - | | | | | | PUSH | Ä | | 5 | | | | | | S1:CONT | . # | | # | | | | | | S2:CONT | # | | | | | | | | S3:RFCT | # | | # . | | | | | 3. | PUSH | PA | SS | N | | | | | 4. | CONT | # | | # | | | | | 5. | TWB | TE | ST | 72 | | | | - 6. address 64 - 7. The pipeline register at the output of the PROM allows the FETCH/EXECUTE cycles to overlap and the two longest time paths are as balanced as possible (even length). A register placed at the output of the Am2910 and input to the address lines of the control memory, instead of at the output of the control memory, would allow a shorter microcycle than if no pipeline registers were used but the two time paths thus created are not balanced, resulting in a longer 'critial path'. - 8. 80 85ns - from the Am2910 itself; from special bits in the microword by decoding the instruction lines with SSI - 10. 2910: PASS line on MUX input (grounded) $\overline{C}\overline{C}\overline{E}\overline{N}$ = HIGH - 29811: PASS line on MUX input (tied high) - 11. 16 x 4 - 12. no - 13. 16 x 4 - 14. yes, use the Am29705 to expand the Am2903 - 15. 16 x 4 - 16. yes, use the Am29707 to expand the Am2903 - 17. The A and B RAM ports drive separate 4-bit latches which hold the RAM data while the clock input is low. They pass data while the clock is high. - 18. yes - 19. on the rising edge of the clock - 20. 50pf - 21. no the DA $_{0-3}$ pins are input only on the Am2903 and bidirectional on the Am29203. Z and $\overline{I}_{EN}$ also are slightly different in order to support byte operations better. 22. Am29203 23. Am29203 ## ANSWERS TO TRUE OR FALSE QUESTIONS - TRUE ie. HEX-29's design - 2. TRUE - 3. FALSE look at RPCT, RFCT, TWB - 4. TRUE - 5. TRUE designed that way. Am2901 can do it too. - FALSE however, it may have a higher throughput - 7. TRUE - 8. FALSE it is possible, 50:1 parts ratio with a 2:1 speed improvement, but practical?? - 9. TRUE add a few items to the SUPER-16 and you have it - 10. FALSE it does support real time interrupts, but at a high cost in parts, power, real estate and conceptual simplicity - 11. TRUE connect Vector Map to Data Bus - 12. TRUE connect Vector Map to $D_i$ of the Am2910 - 13. FALSE - 14. TRUE an LS family, it handles I TTL load - 15. TRUE but shaky; requires an extra pipeline register over the typical CCU design AMD usually presents. New parts will be faster and do it easier. - 16. FALSE some disk controllers are computers in their own right 17. TRUE - for subroutine calls drive the output enable lines from the microinstruction rather than the Am2910 pins | <br>2910 | | | | INSTR | | | |----------|-----|---|------|-------|----|--| | CJS | ANY | # | READ | | EN | | - 18. FALSE the 2909 and the 2911 do - 19. FALSE the 29803 attaches to the 2909 - 20. TRUE - 21. FALSE 2909, no; 2911 and 2910, yes 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am29811 Am2909/2911 1. - 2. $\overline{OE} = LOW$ - 3. shared CCUs on executing JZ with pull-ups on address lines (10K) - 4. to drive an external counter for the DO X TIMES loop - 5. - 6. active high | 7. | ADDRESS <br> | 29811<br>INSTR | MUX<br>SEL | BR<br>ADDR | | |------|------------------------------------------|-----------------------------------|---------------------------------------|-------------------------|----------------------------------------| | | 10 <br>11<br>12<br>13<br>14<br>15<br>16 | CONT CONT CJP CONT PUSH CONT RFCT | #<br>#<br>TEST<br>#<br>PASS<br>#<br># | #<br># 40<br># 9<br># # | NOTE: a symbolic label should be used! | | subr | | CONT | #<br>PAS | | unconditional jump to | | | 42<br>60<br>61<br>62<br>63 | CONT CONT CONT CJP CRTN | #<br>#<br>TEST<br>PASS | #<br>#<br>80<br># | | | | 80 | JP | # | 63 | | - 1. I, = 0, all i; or $\overline{OE}_i$ = HIGH - 2. select which of several tests is to be done, the output enables tri-state disable the 29803 - 3. 2 $\uparrow$ 2 = 4; if a 29811 is used, then 5: TEST, and the $T_i$ - 4. C, 9, 6, F | 5. ADDRESS | <br> <br> | 29811<br>INSTR | MUX<br>SEL | BR<br>ADDR | 29803<br>INSTR | | | |-------------------------------------------|-----------|----------------------------------|---------------|-----------------------------------------|-----------------------------------------------------------------|--------|-------| | 11<br>12 | <br> | CONT<br>JP | # | ##0 | NO TEST | | | | ##0<br>##12<br>##43<br>##45<br>##6<br>##7 | | JP<br>JP<br>JP<br>JP<br>JP<br>JP | # # # # # # # | 40<br>60<br>140<br>10<br>33<br>45<br>45 | NO TEST | Branch | Table | NOTE: address ##0 should be a symbolic label whose value after assembly (AMC SYS/29) should be one with zero as the last HEX digit. The 29803 should be tied to the least significant 2909 (LSS). All of the branch table addresses should also be given as symbolic labels. Numerics were shown here for demonstration only. 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am27827 - 1. Worst case shows address = LOW to be a state requiring examination. At 0.5V the Am29ll provides 12mA (Y only) and the 32 loads require -8mA. - 2. no - 3. 5pf/load = 5x32 = 160pfAm2909/2911/2910 rated for 50pf load - 4. (160 50)pf \* 0.lns/pf = llns degredation - nothing, adding a buffer adds its delay. - 6. 4Kx32 bits from 0.5Kx8 = 8x4 array still 32 loads as above - 7. 4kx64 bits = 8x8 array 64 loads is not possible without buffer/drivers on address lines (limit is 12mA on $Y_i$ at $V_{LOW}$ ). 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am 2910 - 1. $\overline{RLD}$ = LOW causes the data on the D<sub>i</sub> lines of the 2910 to be loaded into the register/counter. - 2. $C_{i}$ = HIGH allows the incrementer to increment normally. - 3. $\overline{CCEN}$ = HIGH makes $\overline{CC}$ a don't care and changes all conditional instructions into unconditional instructions. - 4. $\overline{\text{FULL}}$ should be tested during program development and by any debug/diagnostic routines. - 5. Yes but only one may be active on a bus at any one time. - 6. realtime interrupts - 7. a) start up using pull-ups on the Y<sub>i</sub> lines (JZ placed at address FFF) b) switching between microprogram address sources - 8. 5 deep - 9. no - 10. 2909/2911s have 4 deep wrap-around stack - 11. 8 <--- top overridden 4 3 2 1 - 12. same as 29811 exercise #7 - 13. 2910 29811 $\bar{C}\bar{C}\bar{E}\bar{N}$ alters conditional instr. no $\bar{C}\bar{C}\bar{E}\bar{N}$ no TWB, JP instead $\bar{C}\bar{C}$ is active low TEST is active HIGH $\bar{F}\bar{U}\bar{L}\bar{L}$ pin for stack no full pin $\bar{O}\bar{E}_{VFCT}$ output must decode others - 14. CJP (2910) branches on $\overline{CC}$ = LOW - 15. Yes, but it is $\underline{\text{NOT}}$ recommended. Requires some means of selecting the source of the branch address (pipeline register or 29803) - 16. TRUE - 17. RFCT frees the branch address field for other uses RPCT leaves the stack alone - 18. TWB; contains a "dead man timer" to limit loop repetition | | LABEL/ | 2910 | COND | | BR ADDR/ | |-------|--------|-------|-------------|------|----------| | | ADDR | INSTR | MUX SEL | CCEN | COUNTER | | 19. | i | CRTN | TESTA | * | # | | 20. | i | CRTN | PASS | # | # | | 21. | i | CRTN | # | Н | # | | 22. | i | LDCT | # | # | 9 | | | i + 1 | RPCT | # | # | i + 1 | | 23. | i | PUSH | PASS | # | 9 | | | i + 1 | RFCT | # | # | # | | 24. | i | PUSH | # | Н | 9 | | | i + 1 | RFCT | # | # | # | | 25. | i | PUSH | FAIL | * | # | | | i + 1 | LOOP | TESTB | * | # | | 26.a. | i | PUSH | PASS | # | 19 | | | i + 1 | TWB | TESTC | * | FAILADR | | 26.b. | j | PUSH | # | Н | 19 | | | j + 1 | TWB | TESTC | L | FAILADR | | | | | <del></del> | | | ## note 1. <sup>#</sup> means DON'T CARE <sup>\*</sup> means signal either not present in pipeline (tied LOW) or signal must be driven LOW $\,$ | | LABEL/ | 2910 | COND | | BR ADDR/ | | | |-----|----------|-----------------------|----------|-------------|----------|----------------------|-----| | | ADDR | INSTR | MUX SEL | CCEN | COUNTER | | | | 27. | i | LDCT | # | # | ADR1 | | | | | i + 1 | JRP | TESTD | * | ADR2 | _ | | | 28. | i | LDCT | # | # | SUBA | _ | | | | i + 1 | JSRP | TESTD | * | SUBB | - | | | 29. | i | <del></del><br> CJPP | TESTE | | ADR3 | _ | | | | <b>-</b> | <del></del><br> | | | | _ <u>R̃īD_(</u> adde | đ) | | 30. | i | | . note 2 | | SUBA | L | | | | i + 1 | - <b>-</b> | • • | | | Н | | | | i + 2 | | | | | н | | | | i + 3 | <br> JSRP | TESTD | * | SUBB | # | | | 31. | 13 | <br> CJS | TESTC | * | 40 (u | se label) | | | 32. | 13 | <br> CJS | х | н | 40 | • | | | 33. | 13 | CJS | TESTC | * | 40 | . <b>_</b><br>L | | | 34. | 13 | CJS | TESTC | * | 40 | note 1. | | | 35. | 13 | CJS | TESTC | L | 40 | L | | | | | | | <br>ha tast | was dosi | red and th | hat | (The above assumes that the test was desired and that no register load is to occur. The microinstruction will vary with the application.) note 1. C may NOT be controlled from the microinstruction! note 2. no RFCT, LDCT, RPCT, TWB, or PUSH(PASS) may occur in this code section 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am 2910 FLOWS: ## NORMAL CJS EXECUTION: CJS EXECUTION WITH $\overline{CC}\overline{EN}$ = HIGH # CJS EXECUTION WITH $\overline{R}\overline{L}\overline{D}$ = LOW 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am2910 ## CJS EXECUTION WITH Cin SWITCHED: YOU SEE HOW THIS CAN LEAD TO PROBLEMS! TWB FOR EXTERNAL SIGNAL TESTING IS A MUCH BETTER CHOICE. FLOWCHART OF CJS DECISION PROCESS IN THE PRESENCE OF $\bar{C}\bar{C}\bar{E}\bar{N}$ , $\bar{R}\bar{L}\bar{D}$ , $C_{in}$ : - 1. 10 address lines - 2. CS WE - 3. chip is 1Kx4; therefore, 4 rows, 8 cols required for a 4Kx32 bit memory. use decoder to drive chip selects 4. 32 loads: 10µA input load current 5pf input capacitance | per load This puts an llns speed degredation on the $\mbox{Am}\,2910$ timing. - 5. 64 loads, no - 6. must be buffered with drivers on the address lines 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am 2914 - 1. 8 - 2. active low - 3. 1 - 4. yes - 5. Read Vector - 6. used to clear last vector read - 7. when a Master Clear, Clear All Interrupts, or Clear Interrupt Last Vector Read is executed - 8. the binary value indexes the highest priority nonmasked interrupt request currently present - 9. no, one greater - 10. 5, 6, 7 - 11. 1 - 12. No, PASS ALL is an output internally generated by the other signals (you tell that by the absence of a 'o' on the begining of the line). ## 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am2901 - 1. no - 2. no - 3. F, the ALU output - 4. no - 5. 2's Cmpl., can be hooked up for l's Cmpl with extra SSI - 6. no, 2 microcycles - 7. Data Book, edition Jan 1980, pg 2-19 (MPR-020) 2901 | ADDR | 2910 | MUX | BR ADDR | A | L | U | RA | RB | Cin | ROTATE | |-----------|------|-----|---------|----|-----------|------|----|----|--------|------------| | | | | COUNTER | | | | | | | | | 8. | # | # | # | ZA | ADD<br>OR | RAMD | R6 | R6 | L<br># | RAMOTORAM3 | | 9. | # | # | # | AB | ADD | RAMU | R6 | R6 | Cn | RAM3TORAM0 | | <br>10. у | | | | | | | | | | | | | | | # | | | | | | | | | | | | # | | | | | | | | | | | | # | | | | | | | # | | | | | # | | | | | | | # | | i+1 | # | # | # | ZQ | OR | RAM | # | RC | # | # | | | | | | | | | | | | RAM3TORAM0 | | | | | | | | | | | | RAM3TORAM0 | | | | | # | | | | | | | | Which instruction lines provide or do the following? | Am2901 | <sup>1</sup> 8 <sup>1</sup> 7 <sup>1</sup> 6 | <sup>1</sup> 5 <sup>1</sup> 4 <sup>1</sup> 3 | $\frac{{\tt^I2^I1^I}_0}{}$ | |-----------------------------|----------------------------------------------|----------------------------------------------|----------------------------| | Select of MUX at R(ALU) | | | <u> </u> | | Function select of ALU | | <u> </u> | | | Enables the Q register | <u> </u> | | | | Select of Output MUX | <u> </u> | | | | Inhibit at R or S | | | <u> </u> | | Select of MUX at RAM input | <u> x</u> | | | | Select of MUX at QREG input | X | | | | RAM enable | <u> </u> | | | | RAM <sub>0</sub> enable | <u>X</u> | | | | RAM <sub>3</sub> enable | <u>X</u> | | | | Q <sub>0</sub> enable | <u> </u> | | | | Q <sub>3</sub> enable | X | | | | Select of MUX at S(ALU) | | | <u> </u> | 2900 FAMILY STUDY GUIDE EXERCISE SOULTIONS Am2903 - 1. the sign bit is $\underline{\text{NOT}}$ affected during an arithmetic up/down shift - 2. yes - 3. no - 4. yes - 5. 8 at present; more on the 29203; plus space for expansion in the future - 6. yes - 7. yes - 8. yes - 9. yes - 10. yes - 11. ${\rm I_0^{-I}_4}$ all LOW means special functions; the, ${\rm I_5^{-I}_8}$ select which function is to be done - 12. no - 13. no - 14. yes; SLN uses different meanings for C $_{n+4}$ and OVR and you $_{\underline{must}}$ execute SLN with $\overline{\textbf{I}}_{EN}$ disabled before beginning the normalize algorithm. 2900 FAMILY STUDY GUIDE EXERCISE SOULTIONS Am2903 | LABEL 2 | 2910 | MUX | BR ADDI | R A | L | U | RA | RB | Cin | ROTATE | RC | |-----------|------|-----|---------------|-------|------|-------|------|-------|-----|------------|------| | ADDR 1 | INST | SEL | COUNTR | SRCE | FUNC | DEST | ADDR | ADDR | SEL | MUX SEL | ADDR | | 15. il | # | # | # | DADB | R+S | F->Y | # | # | L | # | | | 16. i | # | # | # | RAMAB | R+S | F->RA | M R | A RB | L | # | RC | | | | | | | | | | | | RAM 3TORAM | 10 # | | i+1 RI | PCT | # | i+l | RAMAB | R+S | 2F->R | AM R | A RB | Cn | RAM 3TORAM | | | 18. i ‡ | ‡ | # | # | RAMAB | R+0 | F->RA | M R | 15 R1 | 5 Н | # | | | 19. i ŧ | ŧ | # | | DA# | R+0 | F->Q | # | # | L | # | | | 20. i ‡ | ŧ | # | # . | RAMAB | R+0 | 2F->R | AM R | 2 R2 | Н | AAROTEMAR | 40 # | | 21. i L | | | | | | | | | | | | | i+1 RI | PCT | # | i+l | LOW | LOM | SPF0 | R | 1 R0 | L | # | | | 22. 1 LI | | | - <del></del> | | | | | | | | | | | | | i+l | | | | | | | | | | i+2 # | ŧ | # | # | LOW | LOW | SPF6 | F | 1 RO | | # | | | 23. i # | ŧ | # | # | RAMB | S+0 | FQ/2- | > # | | | RAMOTOQ3 | | | | | | | | | | AM F | 2 R2 | L | RAM3TORAM | # 0M | | i+1 # | # | # | # | | | | | | | # | | | | | | | | | | | | | | | R+0 IS FASTER THAN S+0 AND OR IS FASTER THAN ADD FOR PASSING DATA <sup># =</sup> DON'T CARE 16. is the only microinstruction using three addresses Which group of instruction lines or enables controls the following? | Am2903 | EAIOOEB | <sup>I</sup> 4 <sup>I</sup> 3 <sup>I</sup> 2 <sup>I</sup> 1 | <sup>I</sup> 8 <sup>I</sup> 7 <sup>I</sup> 6 <sup>I</sup> 5 | |------------------------------------------|-------------|-------------------------------------------------------------|-------------------------------------------------------------| | Input MUX at R | Х | | | | RAM enable | | | x | | Switch to special functions | <del></del> | x | | | ALU function | <del></del> | <u> </u> | | | WRITE enable | | | x | | Q <sub>0</sub> enable | | | x | | Q <sub>3</sub> enable | | | x | | SIO <sub>0</sub> enable | | | x | | SIO <sub>3</sub> enable | | | x | | Q Register enable | | | X | | Input MUX at S | X | | | | Chip function (during special functions) | | | x | | DB <sub>0-3</sub> enable | <u> </u> | | | | Status output select | | | <u> </u> | | Inhibit at R and S | <u> </u> | | <del></del> | | Q input MUX | | | x | | RAM input MUX | | | x | # 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am2903 a. $$\bar{G} \oplus PC_n$$ ; $\emptyset$ ; $Q_3 \oplus Q_2$ ; $F_3 \oplus F_2$ b. 5 c. $$\overline{P}$$ ; $\emptyset$ ; $C_{n+3} \oplus C_{n+4}$ ; $Q_2 \oplus Q_1$ ; $F_2 \oplus F_1$ d. 4 f. : g. $$y_i = LOW|_{all\ i} Q_0$$ $Q_i = LOW|_{all\ i}$ Sign compare F/F $y_i ^Q_i = LOW|_{all\ i}$ - h. FALSE not on the Am29203 - i. Yes - j. Sets status register with values relating to functions - k. $ar{ t w}ar{ t R}ar{ t T}ar{ t E}/ t MSSig|_{ t LSS}$ ----> $ar{ t w}ar{ t E}$ on all chips 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am 29705 - 1. 8 - 2. 5 - 3. one connects to a decoder which is connected to the C address line C $_4$ and enabled by the $\overline{W}\overline{R}\overline{I}\overline{T}\overline{E}/\overline{M}\overline{S}\overline{S}$ of the LSS 2903; the other connects to the clock line, C $_p$ . - 4. LE is connected to C also. - 5. yes (watch your timing) - 6. yes, just as 2903 registers are loaded, the only difference is the address line. - 7. a. 6 each for A, B, C addresses b. 4 each for A, B, C addresses plus some PSW bit to control chip select 21. X 2A | | Am2904<br><sup>1</sup> 9 <sup>1</sup> 8 <sup>1</sup> 7 <sup>1</sup> 6 | SĒ | Am2901<br>18 <sup>1</sup> 7 <sup>1</sup> 6 | | |-----------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------|----------------------------------------------------------|--------------------------------------| | 1.<br>2.<br>3.<br>4. | 0<br>6<br>7<br>A | 0<br>0<br>0<br>0 | 5<br>4<br>6<br>7 | | | | | | Am2903<br>8 <sup>I</sup> 7 <sup>I</sup> 6 <sup>I</sup> 5 | | | 5.<br>6.<br>7.<br>8. | 2<br>5<br>E<br>E | 0<br>0<br>0<br>0 | 5<br>3<br>1<br>0 | | | 9. | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | any | of these | | | | ōĒ <sub>y</sub> 1 <sub>5</sub> 1 <sub>4</sub> 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | 2904<br>CĒ <sub>Ų</sub> CĒ <sub>M</sub> | EzEcEnEovr | ŌĒ <sub>CT</sub> | | 10.<br>11.<br>12.<br>13.<br>14.<br>15.<br>16. | | 0 0<br>0 0<br>0 1<br>0 1<br>1 0<br>1 0<br>1 0 | 0<br>0<br>X<br>X<br>B<br>B<br>A | H<br>H<br>H<br>H<br>H<br>H<br>H<br>H | | 18.<br>Y <sub>i</sub> | Perform the test | but also | perform MSR | > usR; | | 19. | X 36 | 1 1 | Х | L | | 20. | Perform the test | but also | perform I | > µSR. | 1 1 X L 2900 FAMILY STUDY GUIDE EXERCISE SOLUTIONS Am2904 | | M | | | | | | | | | | | | |------|--------|-------------|------|------|------|------|------|---------------------------|------------|--------------|------|------------------| | LABL | 2910 U | BR | Α | L | Ū | Α | В | 2 | 90 | - | | | | ADDR | INST X | CNTR | SRCE | FUNC | DEST | ADDR | ADDR | $c_{in}$ | ySR | MSR | TEST | MUXSEL | | 22.i | CONT X | - <u></u> - | ZB | ADD | RAMA | R15_ | R15 | H | - <u>x</u> | - <u>x</u> - | DIS | - <del>-</del> x | | | LDCT X | | AB | ADD | RAMU | R6 | R6 | T_ | X | Х | DIS | RAM3TORAMO | | | RPCT X | _ | AB | ADD | RAMU | R6 | R6 | I <sub>C</sub> | X | Х | DIS | RAM3TORAM0 | | | XX | | DZ | ADD | RAMA | R6 | R6 | $\mathbf{r}_{\mathbf{c}}$ | X | Х | DIS | X | 25. C is replaced by I I + I I I I I I of the Am2904 in 12 11 5 4 3 2 1 0 Status registers added as needed $I_5I_4I_3I_2I_1I_0 + \tilde{E}_i + \tilde{C}\tilde{E}_i$ s Multiplexer selection for shift control done on one part rather than several separate multiplexers and then attempting to encode their controls. Conditional test field added (may overlap MUX SEL field or may even replace it, depending upon the design). - 1. True - 2. False - 3. True byte or word operation all almost every instruction - 4. True using either the instruction lines, $\mathbf{I}_{i}$ , or the $\mathbf{T}_{i}$ lines - 5. True - False use an Am2904 for emulations (bit settable status registers) - 7. True requires two microwords (two microcycles if l microinstruction executes in l microcycle) - 8. True I, ACC, D Latch, or RAM - 9. True control timing and use an external MUX similiar to the procedure used by the $\mbox{Am2903/Am29203}$ - 10. True - 11. False! remember the branch on previous NOP two step required by the double pipelined Am2910 Am2901/2903/29203 "typical" CPU (ED2900B) - 12. True - 13. True - 14. True with reservations the D latch can be used but requires some tricky timing, you could generate a race condition if the D latch is also a source for the operation. The D latch is not intended to be a destination, and its use as such is not recommended. Normal destinations: RAM, ACC or NONE. - 15. True - 16. False $D_{\rm SE}$ (D sign extend with bit 7 extended) is used for Two's complement arithmetic - 17. True - 18. True - 19. True - 20. False also $\rm Q_C$ , $\rm C_N$ $\oplus$ $\rm Q_{OVR}$ ( $\rm Q_i$ is used to indicate the status register contents in the Am29116 literature; not to be confused with the $\rm Q$ register of the RALUs) - 21. True - 22. True - 23. True also goes to Y, - 24. True watch timing - 25. False ACC only, instruction has common source/destination field - 26. True none and 0 15 - 27. True - 28. True - 29. True ~ AMD survey - 30. True - 31. False! - 32. True - 33. True - 34. True - 35. False if you need this use an Am2904 - 36. False this is the one source which <u>disallows</u> loading - the ACC - 37. True - 38. True #### ANSWERS TO FILL IN OR ANSWER SECTION: - 39. Z, C, N, OVR, LINK, FLAG1, FLAG2, FLAG3 - 40. There are 12 condition code test signals: the 8 status bits themselves (one at a time) plus: N. $\Theta$ OVR [N $\Theta$ OVR] + Z Z + $\bar{C}$ LOW - 41. Yes by using the T lines as input. This requires a wider microword so that both the T instruction lines and the $\rm I_i$ instruction lines are present. - 42. lower only - 43. Yes very carefully! Requires a register between the microcontroller and the control storage (usually a PROM memory) as well as the pipeline register at the control storage output. 125ns is more easily achieved. Timing studies will be more detailed when the part is released (end of 1980). - 44. RAM, ACC, D, I, ZERO - 45. NO - 46. RAM-ACC, RAM-I, D-RAM, D-ACC, ACC-I, D-I - 47. Rotate is UP only: 1100 1010 0011 0101 n=2 becomes 0010 1000 1101 0111 - 48. Yes - 49. Yes watch your timing. - 50. 0000 - 51. 0001 - 52. Bit 15 does not participate in the byte mode. - 53. The program space is larger for the faster Am29116. - 54. Yes but it was not intended for this application. - 55. Yes - 56. Yes the barrel shifter works in the byte or word mode. - 57. Yes 16-bit ALU - 58. Yes but it was not intended for this application. - 59. If the mask bit i is zero in a ROTATE-MERGE instruction, the ith bit of the U operand is passed to the destination. - 60. If U = 0011 0001 0101 0110 R = 1010 1010 1010 1010 MASK = 0101 1010 0110 1001 and n = 4 the bit pattern that is produced by a word mode ROTATE-MERGE instruction is 000 111 000 1010. - 61. If the highest bit position with a one (1) is bit position 7, and the mask is $1010_{\rm HEX}$ , $0009_{\rm HEX}$ is produced by a word prioritize instruction. - 62. Repeating for byte mode prioritize, same answer as 61. - 63. For LOAD $\overline{2}^N$ , ZERO --> bit N, ONE --> all other bits in destination. - 64. To do a word rotate down five bit positions, do a rotate up of n = 11 [16 5 = 11]. - Example: 0000 1111 0101 1010 1101 0000 0111 1010 - 65. QLINK is the linkage bit for shift operations; also for CRC instructions (serial input). - 66. You CANNOT set/reset the ALU status bits one by one as with the Am2904 Machine status register. They function more like the microstatus register. - 67. You CAN set/reset the LINK and FLAGi status bits one at a time. - 68. In byte mode, the lower 4 bits of the status register are loaded. - 69. The instructions which do <u>NOT</u> cause the ALU status bits to be updated are: NOP, status register instructions, save status, test status, or any instruction if either SPE or IEN are not LOW. 70. The upper four status bits (LINK, FLAG1, FLAG2, FLAG3) are changed during status set/reset; status load (word mode only); plus QLINK is updated after each shift. 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN:CONTROLLERS AND ALUS CHAPTER EXERCISE SOLUTIONS SELECTED PROBLEMS ONLY ## Chapter 1 1. - larger number of parts hardware more difficult programming more levels of programming more external connections multiple levels of documentation (AMC SYS/29 helps) longer design time - 3. faster can custom tailor to the application via microprogramming emulations are easier - more flexible connectibility interfaces directly to TTL allows wider (>16 modulo 4) data path 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN: CONTROLLERS AND ALUS CHAPTER EXERCISE SOLUTIONS SELECTED PROBLEMS ONLY # Chapter 3 1. ## 2. Sample code: | 1 | | Am29811 | COND | BRANCH | |-------|-----------|---------|------------|---------| | LABEL | ADDRESS | INSTR | MUX | ADDRESS | | | | | | | | | <u>;</u> | CONT | # | SUB1 | | - 1 | a<br>.ı | JSRP | ΤÏ | SUB 2 | | a+ | | | | 5002 | | a+ | | : | | | | CUD 1 | : | PUŚH | PASS | 5 | | SUB1 | b | | | | | b+ | _ | CONT | # | . # | | b+ | | CONT | # | · # | | þ∗ | | CONT | # | #<br># | | þн | | CONT | | # | | þ+ | | RFCT | # | # | | h-d | ⊦6 | CRTN | PASS | # | | | : | | | | | SUB 2 | C | PUSH | FAIL | #<br># | | ¢+ | | CONT | # | # | | ¢+ | • | CONT | # | # | | c+ | ١3 | CONT | # | # | | ¢4 | -4 | CONT | # | # | | c+ | <b>+5</b> | LOOP | <b>T</b> 2 | #<br># | | c+ | ⊦6 | CRTN | PASS | # | | | : | | | | 2900 FAMILY STUDY GUIDE BIT SLICE DESIGN:CONTROLLERS AND ALUS CHAPTER EXERCISE SOLUTIONS SELECTED PROBLEMS ONLY ## Chapter 4 1. Same as 3.2 with the Am2910 instruction field replacing the Am29811 field $\,$ | 2. | Am2910 | CONDI | BRANCH | l Am 2914 | |--------------------------|--------------|---------|-------------|----------------| | LABEL ADDRES | S INSTR | MUX | ADDRESS | INSTR | | : | | | | | | a | CONT | # | # | added field | | a+l | CJV | Tl | # | READVECT < | | a+2 | : | | | | | vecl b | PUSH | PASS | 5 | | | b+l | CONT | # | # | | | b+2 | CONT | # | # | | | b+3 | CONT | # | # | | | b+4 | CONT | # | # | | | b+5 | RFCT | # | #_ | | | b+6 | С <b>Ј</b> Р | PASS | a+2 | < <del>-</del> | | ; | ***** | | | | | VEC2 c | PUSH | FAIL | # * | | | c+1 | CONT | # | | | | c+2<br>c+3 | CONT<br>CONT | # | #<br>#<br># | | | C+3 | CONT | # | #<br># | | | c+5 | LOOP | т2 | . # | | | c+6 | CJP | PASS | a+2 | < <del>-</del> | | 4.a) 20ns | • | | | | | b) 43ns | | | | | | c)51cns | | | | | | d) 24ns | | | | | | e)58ns | | | | | | f)104ns | | | _ | | | g) the C <sub>p</sub> to | Y time | is 25ns | longer | | $\Diamond \Diamond \Diamond \Diamond \Diamond \Diamond \Diamond$ *THE END* $\Diamond \Diamond \Diamond \Diamond \Diamond \Diamond \Diamond$