| Name: | KEY | | |-----------|-----|--| | I TWILL . | | | Calculators not allowed. Show your work for any possible partial credit or in some cases for any credit at all (5 pages plus a diagram page and a blank k map page, 100 possible points). ## 1) State Machine State Diagram: a) (10 points) Draw the state diagram for the following speed control system for a Metz to Paris TGV train. There is one input, the train engineer has one switch which she may place in either the faster = 1 or slower = 0 position. (There is no stay at the same speed input switch position). The train has four speeds: not moving, moving forward, moving forward fast, moving forward very fast. There is one output, there is a danger light which is on when the train is in the moving very fast "state". b) (10 points) Show the state table for the system described above. | FASTER/SLOWER | 51 | 50 | NSI | NSO | OUTPUT | |---------------|----|----|-----|-----|--------| | ٥ | 0 | ٥ | 0 | 0 | 0 | | 1 | 0 | 0 | ٥ | 1 | ٥ | | O | 0 | 1 | 0 | 0 | 0 | | 1 | 0 | Į | ı | ۵ | ٥ | | 0 | 1 | ٥ | 0 | Į | 0 | | | } | ٥ | 1 | 1 | 1 | | 0 | l | ( | | 0 | ۵ | | | | | | Ţ. | 1 | | | 1 | ł | | ( | ŧ. | ## 2) State machine hardware a) (10 points) Show the k maps and the resulting Boolean equations to implement the following state table. | input | S0 | NS0 | output | | 5. | 20 | | 50 | 50 | |--------|----|-----|--------|-------|----|----|-------|----|----| | 0 | 0 | 1 | 1 | INPUT | 1 | 0 | IMPLT | | ۵ | | 1<br>1 | 0 | 0 1 | 1<br>1 | LNPUT | 0 | | Input | 0 | D | b) (10 points) Show all the hardware needed in the box below to implement this state machine. Be sure to include any registers you need. | 3) (15 points) SIMM Memory Systems | | |----------------------------------------------------------------------------------------------------|---------------| | Using SIMMs that are 1 GBytes (one billion addresses by eight bit words): | | | Part A Suppose that these SIMMS are used to build a 4 billion address memory system with 3 | 32 | | bit words. Answer the following questions about this memory system: | | | How many address lines does each SIMM require? 230 => 30 | | | How many address lines does the entire memory system require? $+ \times 2^{30} = 2^{230} = 2^{32}$ | => 32 | | How many SIMMS are require for the entire memory system? 32 for each worl × 4 Times | 1 G-BUTE SIMM | | What kind of address decoder is required? 2 To 4 | | | How many memory banks are needed? 4 BANKS | | 4) (15 points) Suppose the following inputs (in hexadecimal) are applied to the 32-bit shift unit used in the single cycle data path shown in the diagram on the last page of the exam. Determine the output of the shift unit (in hexadecimal). You may assume the "su en" is a one to allow the shift unit to output a result. | Shift Type (st) | Input Value | Shift Amount (count) | Output | |-----------------|-------------|----------------------|-------------| | rotate | 0x9B4CEF10 | 0x00000016 | 0X33BC426D | | arithmetic | 0x97D3AB2F | 0x00010000 | OXFFFF FFFF | | logical | 0xFFFFFFF | 0xFFFFFFF | OXFEFFFE | ## Show your work here: indical: SHIFT AMOUNT IS NEGATIVE Regative 0x00000000 The surface 1 SHIFT LEFT AND BIT POSITION RESULTS IN 0x FFFFFFFF - 5) Using the datapath we have been discussing in class and shown on the last page of the exam (you may tear off that last page) write the microcode fragments to accomplish the following procedures. Use an "X" when a value is a don't care. You may assume register 0 contains all zeros. For full credit complete the description field. Less registers used and less steps in your answers earn more credit. Add more step #s if you need more than is drawn below. - a) (10 points) Write a microcode fragment (1 or more microinstructions) that puts the numerical value of the lower 16 bits of register 5 into register 7. | # | X | Y | Z | rwe | im<br>en | im va | au<br>en | -a/s | lu<br>en | If | su<br>en | st | st<br>en | ld<br>en | r/<br>-w | msel | description | |---|---|---|---|-----|----------|-----------|----------|------|----------|------|----------|----|----------|----------|----------|------|------------------------| | 1 | 5 | X | 7 | 1 | 1 | OXOGO FPF | 0 | X | 1 | 1000 | 0 | ×× | 0 | 0 | X | 0 | R7 = R5 AND OX COOFFFF | | 2 | | | | | | | | | | | | | | | | | | | 3 | | | | | | | | | | | | | | | | | | | 4 | | | | | | | | | | | | | | | | | | | 5 | | | | | | | | | | | | | | | | | | b) (20 points) Write a microcode fragment (1 or more microinstructions) that Exclusive ORs memory location 5,233 with memory location 5,500 and puts the result in memory location 6,500 | # | Χ | Υ | Z | rwe | im | im va | au | -a/s | lu | lf | su | st | st | ld | r/ | msel | description | |---|---|---|---|-----|------|-------|----|------|----|------|----|----|----|----|----|------|----------------| | | | | | | en | | en | | en | | en | | en | en | -W | | | | 1 | X | X | | } | 1 | 5233 | * | ٥ | 0 | XXXX | 0 | XX | 0 | 0 | X | 0 | RI= 5233 | | 2 | X | X | 1 | l. | 0 | X | 0 | × | ٥ | XXX | O | XX | 0 | 1 | 1 | l | R1 = M[5233] | | 3 | X | X | 2 | 1 | 1 | 5500 | 1 | 0 | 0 | xxx | 0 | ×X | 0 | 0 | × | 0 | R2= 5500 | | 4 | X | X | 2 | 1 | 0 | X | 0 | X | 0 | XXXX | 0 | XX | 0 | 1 | 1 | 1 | R2= m[5500] | | 5 | ì | 2 | 1 | 1 | 0 | × | 0 | X | 1 | مانه | 0 | XX | 0 | 0 | X | 0 | RI= RI EXUR RZ | | 6 | X | X | 2 | 1 | A Do | 6500 | ı | 0 | 0 | XXXX | 0 | xχ | 0 | ٥ | X | 0 | R2 = 6500 | | 7 | 1 | 2 | X | 0 | ٥ | × | 0 | X | 0 | XXXX | 0 | XX | 1 | ٥ | ٥ | 1 | m[R2]= R1 | | 8 | | | | | | | | | | | | | | | | | | | 9 | | | | | | | | | | | | | | | | | | ## K MAPS: