### The University of North Carolina at Chapel Hill

# Comp 411 Computer Organization Fall 2012

#### **Problem Set #2**

Issued Mon. 10/1/12; Due Mon. 10/8/12 (hardcopy, beginning of class)

**Homework Information**: Late homework will not be accepted. Feel free to get help from others, but the work you hand in should be your own. You may **not** use solutions to a previous year's homework to aid you in completing this assignment. Please **enter your answers in the space provided.** 

#### **Problem 1: Converting Instructions to Assembly Language (35 points)**

The conversion of a mnemonic instruction to its binary representation is called assembly. This tedious process is generally delegated to a computer program for a variety of reasons. In the following exercises, you will get a taste of what the task of translating from assembly to machine language is like.

a) Match the instructions below with their hexadecimal counterparts. Enter your answer as the letter 'A''R' in the blank space to the left of each instruction. NOTE: Do not use the MARS assembler to do this
exercise. Using MARS will not only deprive you of some hand-coding practice, but may also give you
unexpected answers because it has a tendency to modify/rewrite some of these instructions with its
preferred coding templates. However, once you have completed this exercise by hand, feel free to
experiment with MARS.

| <br>addi \$v0,\$zero,0x8009    | A: | 0x000A4A40 |
|--------------------------------|----|------------|
| <br>slti \$t2,\$t1,-1          | в: | 0x21490009 |
| <br>addi \$t1,\$t2,9           | C: | 0x014B4820 |
| <br>loop: bne \$t1,\$t2,loop   | D: | 0x014B4824 |
| <br>loop2: beq \$t2,\$t1,loop2 | E: | 0x000A4A43 |
| <br>sll \$t1,\$t2,9            | G: | 0x3C094809 |
| <br>and \$9,\$10,\$11          | н: | 0x152AFFFF |
| <br>ori \$t1,\$t2,9            | J: | 0x292AFFFF |
| <br>lw \$a1,0x09(\$v0)         | K: | 0x312A4809 |
| <br>add \$t1,\$t2,\$t3         | L: | 0x3C03FFFF |
| <br>andi \$t2,\$t1,0x4809      | M: | 0x20028009 |
| <br>lui \$t1,0x4809            | N: | 0x020A4820 |
| <br>lui \$v1,0xFFFF            | 0: | 0x8C450009 |
| <br>sra \$t1,\$t2,9            | P: | 0x1149FFFF |
| <br>add \$t1,\$s0,\$t2         | R: | 0x35490009 |

## **Problem 1: Converting Instructions to Assembly Language (continued)**

| b)   | The "no-op" instruction consists of all a corresponds to (including registers).    | zeroes: 0x00000000. Write the actual instruction that this                                                                   |
|------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
|      |                                                                                    | Answer:                                                                                                                      |
|      |                                                                                    |                                                                                                                              |
|      |                                                                                    |                                                                                                                              |
| Pro  | oblem 2: Converting pseudo-instruction                                             | ons (35 points)                                                                                                              |
| set  |                                                                                    | mnemonics for instructions that are not part of the instruction eudoinstructions can be generated using a sequence of one or |
| pse  |                                                                                    | h of the following pseudo-instructions (some are official MIPS ach of these can be implemented using only one real MIPS      |
| a) r | nove rA, rB                                                                        | Answer:                                                                                                                      |
| Reg  | $g[rA] \leftarrow Reg[rB]$ ove register rB to rA                                   |                                                                                                                              |
| b) 1 | not rA, rB                                                                         | Answer:                                                                                                                      |
|      | $g[rA] \leftarrow \sim Reg[rB]$<br>the bitwise complement of rB into rA            |                                                                                                                              |
| -    | neg rA, rB                                                                         | Answer:                                                                                                                      |
|      | $g[rA] \leftarrow -Reg[rB]$<br>the 2's complement of rB into rA                    |                                                                                                                              |
| d) ( | dec rA                                                                             | Answer:                                                                                                                      |
|      | $g[rA] \leftarrow Reg[rA] - 1$<br>crement rA by 1 and place result in rA           |                                                                                                                              |
|      |                                                                                    |                                                                                                                              |
|      |                                                                                    | with the value 65535 (0x0000FFFF). Would the instruction on? If not, what would be the value in rA?                          |
| -    | Suppose we wanted to fill a register rA w, \$0,255 perform that operation? If not  | with the value 255 (0x000000FF). Would the instruction original, what would be the value in rA?                              |
| ·    | Suppose we wanted to fill a register rA v, \$0, -1 perform that operation? If not, | with the value -1 (0xFFFFFFFF). Would the instruction oring what would be the value in rA?                                   |

#### Problem 3. "Loading up at the Store" (30 points)

The MIPS ISA provides access to memory exclusively through load (lw) and store (sw) instructions. Both instructions are encoded using the I-format, thus providing three operands, two registers and a 16-bit sign-extended constant. The memory address is computed by adding the contents of the register specified in the rs register field to the <u>sign-extended 16-bit constant</u>. Then either the contents of the specified memory location are loaded in the register specified in rt instruction field (lw), or that register's contents are stored in the indicated memory location (sw).

It is possible to "directly" address a limited range of 32-bit memory locations by encoding the rs field as \$0.

a) How many distinct memory locations can be addressed if rs is \$0? (*Note:* Addresses generated by lw/sw instructions *must* be multiples of 4, i.e., they must be *word* addresses.)



b) MIPS assemblers often provide a pseudoinstruction (see problem 2) for loading an effective address into a register called "la" for load address. The syntax of this pseudoinstruction matches the lw instruction, and an example is shown below:

Give one true instruction (with operands) that can be used to implement this pseudoinstruction:



c) MIPS does not provide any instruction for specifying a memory address with a variable offset from rs (i.e., allows only an immediate constant to be specified as the offset). Fill in the multiple-instruction sequence below to accomplish this type of memory access using available MIPS instructions. Assume the array's base address (i.e., the location of its 0<sup>th</sup> member) is in register \$t0, the *word* index is located in \$t1, and the value in memory is being loaded into \$t2.

Thus, we effectively want to execute an instruction that would look like (but does not exist):

However, the MIPS instruction set does not provide any such instruction. Your task is to use a sequence of actual MIPS instructions to implement the same behavior. Indicate your answer in the table below.

(Hint: it may be helpful to come up with your own solution, then fill in the code below)

| ?   | \$t3 | <b>\$t1</b> | 2 |
|-----|------|-------------|---|
| ADD | \$t4 | \$t3        | ? |
| LW  | \$t2 | ?(?)        |   |