CS 61C Midterm #2 — July 30th, 1998 | Your name | | | |-------------|--|--| | | | | | login cs61c | | | This exam is worth 30 points, or 15% of your total course grade. The exam contains six substantive questions, plus the following: Question 0 (1 point): Fill out this front page correctly and put your name and login correctly at the top of each of the following pages. This booklet contains seven numbered pages including the cover page, plus a copy of the back inside cover of Patterson & Henessey. Put all answers on these pages, please; don't hand in stray pieces of paper. This is a closed book exam, calucaltors are allowed. When writing procedures, write straightforward code. Do not try to make your program slightly more efficient at the cost of making it impossible to read and understand. When writing procedures, don't put in error checks. Assume that you will be given arguments of the correct type and specified format. If you find one question especially difficult, leave it for later; start with the ones you find easier. We will use round to even as our rounding mode to round all fractional points to integer values. #### **READ AND SIGN THIS:** I certify that my answers to this exam are all my own work, and that I have not discussed the exam questions or answers with anyone prior to taking this exam. If I am taking this exam late, I certify that I have not discussed the exam questions or answers with anyone who has knowledge of the exam. I also certify that I was not kidnapped by evil two headed alien Elvis clones for use in their diabolical experiments. | 0 | /1 | |-------|-----| | | | | 1 | /5 | | 2 | /6 | | | 70 | | 3 | /6 | | 4 | /6 | | 5 | /6 | | total | /30 | | Your name | $\log in \ cs61c-$ | |-----------|--------------------| |-----------|--------------------| ### Question 1, Deja Vu all over again (5 points): 1 point: Using two's complement, **saturating** arithmetic, add the following 8 bit numbers together. 00110101 00101111 + 01011011 1 point: Which IEEE rounding mode would you like us to use for dealing with fractional points, in order to maximize your score: round to $+\infty$ , round to $-\infty$ , truncate, or round to even? 1 point: Why does this not work as a translation of li \$rd imm? imm is a 32 bit quantity, high is the upper 16 bits of imm, low is the lower 16 bits of imm: lui rd high addiu rd rd low 1 point: What is the value of this 32 bit, two's complement number? 11111111 11111111 11111111 11110011? 1 point: What registers must be restored to their prexisting values when a function returns, according to the MIPS calling convention? | Your name | login cs61c | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------| | Question 2 (6 points): | | | Short questions on performance and I/O. | | | 1 point: How many interrupts will be required to time, using polling based I/O? | read 100 bytes of input, one byte at a | | 1 point: How many interrupts will be required to time, using interrupt driven I/O? | read 100 bytes of input, one byte at a | | 1 point: How many interrupts will be required to transfer? | read 100 bytes of input, using a DMA | | 1 point: Gill Bate's new operating system, Macro to start up. 40% of this time is used to detect an the Department of Justice forces the removal of this is the best time the modified operating system (detects non Macro\$haft programs) requires to book | d remove non Macro\$haft programs. If<br>is portion of the operating system, what<br>the version without the portion which | | 1 point: Inhell computer corporation claims that (MPX instructions) based CPUs perform some of instructions, up to 10 times faster, but all non M programs do not use MPX instructions. What is which a MPX processor offers when running old p | operations, those represented by MPX IPX instructions are unaffected. Older the maximum percentage improvement | 1 point: A RISC machine has an average CPI of 1.5 and a clock rate of 500 MHz. How long will it take to execute a 100,000,000 instruction program? # Question 3 (6 points): Short questions on boolean logic, circuits, computer components, etc. 1 points: Which of the following boolean expressions are true? A or $$0 = 0$$ , A or $0 = 1$ , A and $\tilde{A} = 0$ , A and $\tilde{A} = 1$ 2 points: Give the truth table for the following boolean function and draw a circuit which implements it. $$O = AB$$ or $AC$ or $B^{*}C$ 2 points: A state machine has 3 states, A, B, and C, and one input I. If the machine is in state A and I is true, it transitions to state B, otherwise it stays in state A. If the machine is in state B and I is true, it transitions to state C, otherwise it transitions to state A. If the machine is in state C it will always stay in state C. Draw the state transition diagram for this state machine 1 point: Which of the following tasks does the ALU perform: Store register value, perform arithmetic operations, perform comparisons, load data from memory? | Your name | $_{}$ login cs61c- $_{}$ | | |-----------|--------------------------|--| | | | | ### Question 4 (6 points): Consider this C program definition: ``` struct dispatchElement{ char *name; int value; int (*fn)(int); }; int opcode(int i); int dispatch(struct dispatchElement *table, int operation){ return ((table[opcode(operation)].fn)(operation)); } ``` Translate the function dispatch into MIPS assembly, using the register calling convention. **Hint:**, draw the layout for a struct dispatchElement on the back side to make sure you fetch the correct fields of the structure. dispatch: | Your name | $_{\rm color}$ login cs61c- $_{\rm color}$ | | |-----------|--------------------------------------------|--| | | | | ## Question 5 (6 points): Ben Bitdiddle has written the following faulty interrupt handler. The device in question can have interrupts enabled by writing a 1 to the address 0xffff0010, and disabled by writing a 0 to that address. When this device generates an interrupt, the value 0xf00d is placed in the cause register (coprocessor0 register \$13). No other interrupt will generate this value for the cause register. He wants to allow other interrupts to proceed while his interrupt handler is processing this interrupt, but does not want to receive interrupts from the device in question. Only his interrupt handler manipulates the device's interrupt enable register, so he doesn't have to worry about someone else reenabling the device's interrupt. Unfortunately there are 3 bugs in his code. Identify each bug, correct it in the code, and explain why each bug is a problem. Code written out as . . . is correct. He is allowed to use the stack for storage. His bugs do not involve his enabling and disabling of interrupts or the manipulation of registers to enable or diable interrupts, but involve not correctly saving a register, enabling or disabling interrupts at the wrong time or in the wrong order, and using registers at inappropriate times. All comments correctly describe the behavior of the commented code. ``` .ktext 0x80000080 # Forces interrupt routine below to # be located at the right spot intrp: 1) addi $sp $sp -20 # Get some stack space 2) mfc0 $k0 $13 # See what caused the interrupt 3) li $k1 0xf00d # If it is not ours, skip on 4) bne $k0 $k1 other_interrupt 5) sw $t0 0($sp) # Save $t0 and $t1 6) sw $t1 4($sp) 7) mfc0 $k0 $14 8) sw $k0 8($sp) # Saving exception PC 9) mfc0 $k0 $12 10) sw $k0 12($sp) # saving status register 11) ori $k0 $k0 1 # Set interrupt bit to 1 and relpace 12) mtc0 $k0 $12 # which will reenable interrupts 13) li $t0 0xffff0010 # Turn off the device li $t1 0 14) # so it doesn't send more 15) sw $t1 0($t0) # Interrupts # Continues on next page ``` | Your na | ime | | login cs61c | | |------------------------------------------|--------------------|-------------------------|-----------------|--| | | | | | | | | | # The body of the code | is correct | | | 20) | lw \$k0 12(\$sp) | # Load the status and | | | | 21) | mtc0 \$k0 \$12 | # Disable interrupts | | | | 22) | li \$t0 0xffff0010 | # Reenable the device | | | | 23) | li \$t1 1 | # so it will send inter | rrupts | | | 24) | sw \$t1 0(\$t0) | | <b>-</b> F | | | 25) | lw \$k0 8(\$sp) | # Restore registers | | | | 26) | lw \$t0 0(\$sp) | # And return to \$k0 | | | | 27) | lw \$t1 4(\$sp) | | | | | 28) | rfe | | | | | 29) | | | | | | 29) | jr \$k0 | | | | | other_ | interrupt: # Th | nis code is OK, and wil | 1 | | | # return on its own | | | | | | Bug #1 is around line(s) The problem is: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bug #2 | is around line(s) | | The problem is: | | | | | | | | | | | | | | | | | | | | | | | | | | Bug #3 is around line(s) \_\_\_\_\_\_. The problem is: