*Instructions:* This is a closed book, closed note exam. Calculators are not permitted. If you have a question, raise your hand and I will come to you. Please work the exam in pencil and do not separate the pages of the exam. For maximum credit, show your work. *Good Luck!* Your Name (*please print*) Problem 1 (2 parts, 24 points) Counters Part A (12 points) Design a toggle cell using transparent latches and basic gates. Use an icon for the latch. Your toggle cell should have an active high toggle enable input **TE**, and an active low clear input **CLR**, clock inputs $\Phi_1$ and $\Phi_2$ , and an output **Out**. The **CLR** signal has precedence over **TE**. Label all signals. Also complete the behavior table for the toggle cell. | | | | — Out - | TE | CLR | CLK | Out | |-------|----------------|----------|---------|----|-----|-----------------------|-----| | | | | | 0 | | $\uparrow\downarrow$ | | | TE — | | | | 1 | 0 | $\uparrow \downarrow$ | | | CLR — | $\Phi_1$ | $\Phi_2$ | _ | 0 | 1 | $\uparrow \downarrow$ | | | | $\Psi_{\rm l}$ | $\Psi_2$ | _ | 1 | 1 | $\uparrow\downarrow$ | | Part B (12 points) Now combine these toggle cells to build a **divide by six** counter. Your counter should have an external clear, external count enable, and three count outputs $O_2$ , $O_1$ , $O_0$ . Use any basic gates (AND, OR, NAND, NOR, & NOT) you require. Assume clock inputs to the toggle cells are already connected. *Your design should support multi-digit systems*. Exam Three 8 April 2009 Problem 2 (2 parts, 18 points) **Datapath Elements** Part A (9 points) Consider the following input and output values for a shift operation. Determine the shift *type* and *amount* required to achieve the listed transformation. I/Os are in hexadecimal. | Input Value | Output Value | Shift Type | Shift Amount (signed decimal value) | |-------------|--------------|------------|-------------------------------------| | 87654321 | 43210000 | | | | 87654321 | 76543218 | | | | 87654321 | 00008765 | | | Part B (9 points) Consider the following input and output values for a logical operation. Determine the *logical function* and *function code* (in hexadecimal) required for the operation. | X Input | Y Input | Output | Logical Function | Function Code | |----------|----------|----------|------------------|---------------| | 87654321 | 0000FFFF | 00004321 | | | | 87654321 | 0000FFFF | 8765FFFF | | | | 87654321 | 0000FFFF | 8765BCDE | | | Problem 3 (3 parts, 30 points) Memory Systems Part A (10 points) Consider a DRAM chip organized as **512 million addresses** of **eight bit words**. Assume both the DRAM cell and the DRAM chip is square. The column number and offset concatenate to form the memory address. Using the organization approach discussed in class, answer the following questions about the chip. **Express all answers in decimal**. | column decoder required $(n \text{ to } m)$ | | |--------------------------------------------------------------------------------------------------------------|--------------------------------------------------| | type of mux required $(n \text{ to } m)$ | | | number of muxes required | | | number of address lines in column numb | er | | number of address lines in column offse | t | | Part B (10 points) Consider a <b>4 Gbyte</b> mem | ory system with 256 million addresses of 16 byte | | words using DRAM chips organized as 64 m | • • | | · • | • • | | words using DRAM chips organized as 64 m | • • | | words using DRAM chips organized as 64 m<br>word address lines for memory system | • • | | words using DRAM chips organized as 64 m<br>word address lines for memory system<br>chips needed in one bank | • • | Part C (10 points) Design a 48M address x 4 bit memory system with six 8M address x 4 bit memory chips. Label all busses and indicate bit width. Assume R/W is connected and not 8 April 2009 shown here. Use a decoder if necessary. Place a star on the chip(s) that contain address 26,000,000. Exam Three 8 April 2009 Problem 4 (2 parts, 28 points) Microcode Using the supplied datapath, write microcode fragments to accomplish the following procedures. Express all values in hexadecimal notation. Use 'X' when a value is don't cared. For maximum credit, complete the description field. Part A (14 points) $$R_7 = \frac{3 \times R_5}{16} - 256 \times R_6 \qquad \text{Modify only } \mathbf{R}_5, \mathbf{R}_6 \text{ and } \mathbf{R}_7.$$ | # | X | Y | Z | rwe | im<br>en | im va | au<br>en | -a<br>/s | lu<br>en | lf | su<br>en | st | ld<br>en | st<br>en | r/<br>-w | msel | description | |---|---|---|---|-----|----------|-------|----------|----------|----------|----|----------|----|----------|----------|----------|------|-------------| | 1 | | | | | | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | | | 3 | | | | | | | | | | | | | | | | | | | 4 | | | | | | | | | | | | | | | | | | | 5 | | | | | | | | | | | | | | | | | | | 6 | | | | | | | | | | | | | | | | | | | 7 | | | | | | | | | | | | | | | | | | Part B (14 points) Write a microcode sequence that loads a 32 bit word from memory location 0x4000, unpacks and averages two 15 bit unsigned values (A and B), and then stores the result back to memory location 0x4000. Assume the most significant two bits of the register are zero. **Modify only R<sub>1</sub>, R<sub>2</sub>, and R<sub>3</sub>.** | 0 | 0 | | А | В | |----|----|----|----|------| | 31 | 30 | 29 | 15 | 14 0 | | # | X | Y | Z | rwe | im<br>en | im va | au<br>en | -a<br>/s | lu<br>en | lf | su<br>en | st | ld<br>en | st<br>en | r/<br>-w | msel | description | |---|---|---|---|-----|----------|-------|----------|----------|----------|----|----------|----|----------|----------|----------|------|-------------| | 1 | | | | | | | | | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | | | 3 | | | | | | | | | | | | | | | | | | | 4 | | | | | | | | | | | | | | | | | | | 5 | | | | | | | | | | | | | | | | | | | 6 | | | | | | | | | | | | | | | | | | | 7 | | | | | | | | | | | | | | | | | | | 8 | | | | | | | | | | | | | | | | | |