

NAME: \_\_\_\_\_

**SANTA CLARA UNIVERSITY  
Department of Computer Engineering**

COEN 020

Midterm Exam

Spring 2017

(Closed book & notes; No electronic devices)

**Time Allowed: 1 hour**

**SCU's Academic Integrity Pledge**

"I am committed to being a person of integrity. I pledge, as a member of the Santa Clara University community, to abide by and uphold the standards of academic integrity contained in the Student Conduct Code."

Signature:\_\_\_\_\_

|              |                      |
|--------------|----------------------|
| Your Points: | <input type="text"/> |
| Max Points:  | 116                  |
| Your Score:  | %                    |



Points this page: \_\_\_\_\_

1. [4 pts] What is the maximum value that can be represented as an N-bit unsigned number?  
a.  $2^N$       b.  $2^{N-1}$       c.  $2^N - 1$       d.  $2^{N-1} - 1$
2. [4 pts] What is the most negative value that can be represented as an N-bit 2's complement number?  
a.  $-2^N$       b.  $-2^{N-1}$       c.  $-(2^N - 1)$       d.  $-(2^{N-1} - 1)$
3. [5 pts] Convert the unsigned decimal value  $33_{10}$  to radix 7.
4. [5 pts] Convert the unsigned radix 3 value  $212.2_3$  to base 9.
5. [5 pts] Convert signed 2's complement value  $1000.0110_2$  to decimal.
6. [5 pts] Convert  $-20_{10}$  to an 8-bit 2's complement representation.

Points this page: \_\_\_\_\_

7. [5 pts ea] Look at the C code on the left, then circle the assembly language version that is correct.

|                                       |                                     |                        |                                     |
|---------------------------------------|-------------------------------------|------------------------|-------------------------------------|
| <pre>int32_t a, b ; a = b + 5 ;</pre> | LDR R0,a<br>LDR R1,b<br>ADD R0,R1,5 | LDR R0,b+5<br>STR R0,a | LDR R0,b<br>ADD R2,R0,5<br>STR R2,a |
|---------------------------------------|-------------------------------------|------------------------|-------------------------------------|

|                                                                                             |                                                   |                                                                       |                                                                          |
|---------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------|
| <pre>int32_t f1(int32_t s32) {     int32_t f2(int32_t) ;     return s32 + f2(s32) ; }</pre> | f1: LDR R0,s32<br>BL f2<br>ADD R0,R0,s32<br>BX LR | f1: PUSH {R4,LR}<br>MOV R4,R0<br>BL f2<br>ADD R0,R0,R4<br>POP {R4,PC} | f1: PUSH {LR}<br>MOV R1,R0<br>BL f2<br>ADD R0,R0,R1<br>POP {LR}<br>BX LR |
|---------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------|

|                                                         |                                                         |                                          |                                           |
|---------------------------------------------------------|---------------------------------------------------------|------------------------------------------|-------------------------------------------|
| <pre>void f3(int16_t a16[ ]) {     a16[5] = 0 ; }</pre> | f3: LDR R1,=0<br>ADR R0,a16<br>STRH R1,[R0,10]<br>BX LR | f3: LDR R1,=0<br>STRH R1,a16+10<br>BX LR | f3: LDR R1,=0<br>STRH R1,[R0,10]<br>BX LR |
|---------------------------------------------------------|---------------------------------------------------------|------------------------------------------|-------------------------------------------|

|                                                      |                                                |                                                          |                                                         |
|------------------------------------------------------|------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------|
| <pre>void f4(int64_t *p64) {     *p64 = -5 ; }</pre> | f4: LDRD R1,R2,=-5<br>STRD R1,R2,[R0]<br>BX LR | f4: LDR R1,=-5<br>LDR R2,=-1<br>STRD R1,R2,[R0]<br>BX LR | f4: LDR R1,=-5<br>LDR R2,=0<br>STRD R1,R2,[R0]<br>BX LR |
|------------------------------------------------------|------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------|

|                                                                               |                                                    |                                                    |                                                    |
|-------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|
| <pre>uint8_t f5(uint8_t u8) {     if (u8 != 0) --u8 ;     return u8 ; }</pre> | f5: CMP R0,0<br>BNE L1<br>L1: SUB R0,R0,1<br>BX LR | f5: CMP R0,0<br>BNE L1<br>SUB R0,R0,1<br>L1: BX LR | f5: CMP R0,0<br>BEQ L1<br>SUB R0,R0,1<br>L1: BX LR |
|-------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------------------|

|                                                                                                   |                                                               |                                                                  |                                                                   |
|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------|
| <pre>uint8_t f6(uint8_t u8) {     if (u8 != 0) --u8 ;     else u8 = 100 ;     return u8 ; }</pre> | f6: CMP R0,0<br>ITE NE<br>SUB R0,R0,1<br>LDR R0,=100<br>BX LR | f6: CMP R0,0<br>IT NE<br>SUBNE R0,R0,1<br>LDREQ R0,=100<br>BX LR | f6: CMP R0,0<br>ITE NE<br>SUBNE R0,R0,1<br>LDREQ R0,=100<br>BX LR |
|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------|

Points this page: \_\_\_\_\_

8. [5 pts ea] Look at the C code on the left, then circle the assembly language version that is correct.

|                                                                    |                                                |                                                                     |                                                                                            |
|--------------------------------------------------------------------|------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| <pre>int64_t f7(int64_t a, int32_t b) {     return a - b ; }</pre> | <pre>f7: SUB    R0,R0,R2       BX     LR</pre> | <pre>f7: SUBS   R0,R0,R2       SBC    R1,R1,0       BX     LR</pre> | <pre>f7: ASR    R3,R2,31       SUBS   R0,R0,R2       SBC    R1,R1,R3       BX     LR</pre> |
|--------------------------------------------------------------------|------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------|

|                                                                 |                                                                                                                   |                                                                                                               |                                                                                            |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| <pre>void f8(int16_t a[], int32_t k) {     a[k+1] = 0 ; }</pre> | <pre>f8: LDR    R2,=0       ADD    R1,R1,1       ADD    R0,R0,R1       STRH   R2,[R0,LSL 1]       BX     LR</pre> | <pre>f8: LDR    R2,=0       LSL    R1,R1,1       ADD    R1,R1,2       STRH   R2,[R0,R1]       BX     LR</pre> | <pre>f8: LDR    R2,=0       LSL    R1,R1,1       STRH   R2,[R0,R1,2]       BX     LR</pre> |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|

|                                                              |                                                                                             |                                                                                             |                                                                                             |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| <pre>int32_t f9(int32_t a32) {     return a32 % 10 ; }</pre> | <pre>f9: LDR    R1,=10       SDIV   R2,R0,R1       MLS    R0,R0,R1,R2       BX     LR</pre> | <pre>f9: LDR    R1,=10       SDIV   R2,R0,R1       MLS    R0,R2,R1,R0       BX     LR</pre> | <pre>f9: LDR    R1,=10       SDIV   R2,R0,R1       MLS    R0,R0,R2,R1       BX     LR</pre> |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|

|                                                                |                                                                         |                                                                                            |                                                                                         |
|----------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| <pre>int64_t f10(int32_t a32) {     return 100 * a32 ; }</pre> | <pre>f10: LDR    R1,=100       SMULL  R0,R1,R0,R1       BX     LR</pre> | <pre>f10: LDR    R1,=100       MUL    R0,R0,R1       ASR    R1,R0,31       BX     LR</pre> | <pre>f10: LDR    R1,=100       MUL    R0,R0,R1       LDR    R1,=0       BX     LR</pre> |
|----------------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|

|                                                                                        |                                                                                                       |                                                                                                       |                                                                                                       |
|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <pre>int64_t f11(int64_t a64) {     if (a64 &lt; 0) a64 = 0 ;     return a64 ; }</pre> | <pre>F11: CMP   R1,0       BLT    L1       LDR    R0,=0       LDR    R1,=0       L1:  BX     LR</pre> | <pre>F11: CMP   R1,0       BGT    L1       LDR    R0,=0       LDR    R1,=0       L1:  BX     LR</pre> | <pre>F11: CMP   R1,0       BGE    L1       LDR    R0,=0       LDR    R1,=0       L1:  BX     LR</pre> |
|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|

|                                                                     |                                                                                            |                                                                                            |                                                                                            |
|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| <pre>void f12(int16_t **pp16) {     *((pp16 + 1) + 1) = 0 ; }</pre> | <pre>f12: LDR    R1,=0       LDR    R2,[R0,4]       STRH   R1,[R2,2]       BX     LR</pre> | <pre>f12: LDR    R1,=0       LDR    R2,[R0,1]       STRH   R1,[R2,2]       BX     LR</pre> | <pre>f12: LDR    R1,=0       LDR    R2,[R0,4]       STRH   R1,[R2,1]       BX     LR</pre> |
|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|

Points this page: \_\_\_\_\_

9. [4 pts ea] In each of the two code fragments below, is the compound conditional a logical **AND** or a logical **OR**? (Circle one of the two words in each comment line.)

|                                                                                                                  |                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| LDR R0,x // <b>AND</b> or <b>OR</b> ?<br>CMP R0,10<br>BLT L1<br>CMP R0,20<br>BLE L2<br>L1: LDR R0,=0<br>STR R0,x | LDR R0,x // <b>AND</b> or <b>OR</b> ?<br>CMP R0,10<br>BGE L2<br>CMP R0,20<br>BGT L2<br>L1: LDR R0,=0<br>STR R0,x |
| L2:                                                                                                              | L2:                                                                                                              |

10. [10 pts ea] Translate the following C into ARM assembly:

| C Function                                                                                                                                                                                       | ARM Assembly           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Int64_t Choose(int64_t a64, int64_t b64)<br>{<br>return (a64 < b64) ? (b64 + 1) : (b64 - 1);<br>}                                                                                                | // Use an IT block     |
| int32_t Usable(int32_t min, int32_t max)<br>{<br>int32_t random(void);<br>int32_t temp;<br><br>temp = random();<br><br>if (temp >= min && temp <= max)<br>return temp;<br>else<br>return 0;<br>} | // Do NOT use IT block |