

# Computer Organization

Lab3 MIPS(2)

Details of Data





#### **TOPIC**

- ▶ 1. Data Processing Details
  - Signed vs Unsigned
  - Signed-extended vs Zero-extended
  - Exception while processing signed data
  - Big-endian vs Little-endian

> 2. Logic operation, Shift operation



#### **Identification Numbers**

Run the demo to find the difference between two 'syscall' in the following demo:

```
.include "macro_print_str.asm"
.data
     tdata: .byte 0x0F00F0FF
.text
main:
     lb $a0,tdata
                                                  Code
                                     Service
                                                              Arguments
                                                                                                Result
     li $v0,1
                                                  in Sv0
     syscall
                               print integer
                                                        Sa0 = integer to print
     print_string("\n")
                                print integer as
     lb $a0,tdata
                                                       $a0 = integer to print
                                                                             Displayed as unsigned decimal value.
                                unsigned
     li $v0,36
     syscall
                                                Both "print_string" and "end" are macros which had
                                                been defined in "macro print str.asm" file.
     end
```



#### Signed vs Unsigned (extension)

```
.include "macro_print_str.asm"
.data
    tdata: .byte 0x80
.text
main:
    lb $a0,tdata
    li $v0,1
    syscall
    print string("\n")
    Ib $a0,tdata
    li $v0,36
    syscall
    end
```

```
.include "macro_print_str.asm"
.data
    tdata: .byte 0x80
.text
main:
    Ibu $a0,tdata
    li $v0,1
     syscall
     print_string("\n")
     Ibu $a0,tdata
     li $v0,36
     syscall
     end
```

Q1: Run the two demos, what's the value stored in the register \$a0 after the operation of 'lb' and 'lbu' Q2: using "-1" as initial value of tdata instead of "0x80", answer Q1 again.



#### Signed vs Unsigned (compare)

Run the demo to find the difference between 'slt' and 'sltu'

```
.include "macro_print_str.asm"
.data
.text
main:
     print string("\n -1 less than 1 using slt:")
     li $t0,-1
     li $t1,1
     slt $a0,$t0,$t1
     li $v0,1
     syscall
     print_string("\n -1 less than 1 using sltu:")
     sltu $a0,$t0,$t1
     li $v0,1
     syscall
     end
```

#### TIPS:

1) slt \$t1,\$t2,\$t3

set less than: if \$t2 is less than \$t3, then set \$t1 to 1 else set \$t1 to 0

2) sltu \$t1,\$t2,\$t3

set less than unsigned: if \$t2 is less than \$t3 using unsigned comparision, then set \$t1 to 1 else set \$t1 to 0



### Signed vs Unsigned (caculation)

Run the two demos, which one will invoke the exception (arithmetic overflow), why?

```
.include "macro print str.asm"
.data
    tdata: .word 0x11111111
.text
main:
    lw $t0,tdata
    addu $a0,$t0,$t0
    li $v0,1
    syscall
    print_string("\n")
    add $a0,$t0,$t0
    li $v0,1
    syscall
    end
```

```
.include "macro print str.asm"
.data
    tdata: .word 0x71111111
.text
main:
    lw $t0,tdata
    addu $a0,$t0,$t0
    li $v0,1
    syscall
    print_string("\n")
    add $a0,$t0,$t0
    li $v0,1
    syscall
    end
```



#### Big-endian vs Little-endian(1)

The CPU's **byte ordering scheme** (or **endian issues**) affects memory organization and defines the relationship between address and byte position of data in memory.

- > a **Big-endian** system means byte 0 is always the most-significant (leftmost) byte.
- > a Little-endian system means byte 0 is always the least-significant (rightmost) byte.



Figure 1-1: Big-endian Byte Ordering



Figure 1-2: Little-endian Byte Ordering



#### Big-endian vs Little-endian(2)

Run the demo to anwer the question:

Does your simulator work on big-endian or little-endian, explain the reasons.

print integer in hexadecimal

34

\$a0 = integer to print

Displayed value is 8 hexadecimal digits, left-padding with zeroes if necessary.



#### Big-endian or Little-endian?

```
.include "macro print str.asm"
.data
      tdata0: .word 0x00112233, 0x44556677
.text
main:
      la $t0,tdata0
      lb $a0,($t0)
      li $v0,34
      syscall
      la $t0,tdata0
      lb $a0,1($t0)
      syscall
      lb $a0,2($t0)
      syscall
      lb $a0,3($t0)
      syscall
      lw $a0,4($t0)
      syscall
      end
```

Run the demo to anwer the question:

Q1. What's the output of this demo?

A. **0**x00000033**0**x000000022**0**x00000001**10**x00000000**0**x44556677

B.**0**x0000000**0**x00000011**0**x000000022**0**x000000033**0**x44556677

C.**0**x00000044**0**x0000005**50**x0000000<mark>66**0**</mark>x0000000**770**x00112233

D.**0**x0000007**70**x0000006**60**x0000000<u>550</u>x00000004**40**x33221100

Q2. Does your simulator work on big-endian or little-endian, explain the reasons.

| print integer in<br>hexadecimal | 34 | \$a0 = integer to print | Displayed value is 8 hexadecimal digits, left-padding with zeroes if necessary. |
|---------------------------------|----|-------------------------|---------------------------------------------------------------------------------|
|---------------------------------|----|-------------------------|---------------------------------------------------------------------------------|



# **Common Operations**

| Description                     | Op-code | Operand                      |
|---------------------------------|---------|------------------------------|
| Add with Overflow               | add     | destination, src1, src2      |
| Add without Overflow            | addu    | destination, src1, src2      |
| AND                             | and     | destination, src1, immediate |
| Divide Signed                   | div     | destination/src1, immediate  |
| Divide Unsigned                 | divu    |                              |
| Exclusive-OR                    | xor     |                              |
| Multiply                        | mul     |                              |
| Multiply with Overflow          | mulo    |                              |
| Multiply with Overflow Unsigned | mulou   |                              |
| NOT OR                          | nor     |                              |
| OR                              | or      |                              |
| Set Equal                       | seq     |                              |
| Set Greater                     | sgt     |                              |
| Set Greater/Equal               | sge     |                              |
| Set Greater/Equal Unsigned      | sgeu    |                              |
| Set Greater Unsigned            | sgtu    |                              |
| Set Less                        | slt     |                              |
| Set Less/Equal                  | sle     |                              |
| Set Less/Equal Unsigned         | sleu    |                              |
| Set Less Unsigned               | sltu    |                              |
| Set Not Equal                   | sne     |                              |
| Subtract with Overflow          | sub     |                              |
| Subtract without Overflow       | subu    |                              |

| Description             | Op-code | Operand                               |  |
|-------------------------|---------|---------------------------------------|--|
| Rotate Left             | rol     | - 519400-0045000-                     |  |
| Rotate Right            | ror     |                                       |  |
| Shift Right Arithmetic  | sra     |                                       |  |
| Shift Left Logical      | sll     |                                       |  |
| Shift Right Logical     | srl     |                                       |  |
| Absolute Value          | abs     | destination,src1                      |  |
| Negate with Overflow    | neg     | destination/src1                      |  |
| Negate without Overflow | negu    |                                       |  |
| NOT                     | not     |                                       |  |
| Move                    | move    | destination,src1                      |  |
| Multiply                | mult    | src1,src2                             |  |
| Multiply Unsigned       | multu   | STANDER CONTROL OF THE STANDER CO. T. |  |
|                         |         |                                       |  |



# Logic Operation(1)

| Instruction name                                           | description                                                                                                                                                                                                                                                                                    |  |
|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| and<br>(AND)<br>and dst,sr1,sr2(im)                        | Computes the <b>Logical AND</b> of two values. This instruction ANDs (bit-wise) the contents of src1 with the contents of src2, or it can AND the contents of src1 with the immediate value. The immediate value is <b>NOT</b> sig extended. AND puts the result in the destination register.  |  |
| <b>or</b><br>(OR)<br>or dst,sr1,sr2(im)                    | Computes the <b>Logical OR</b> of two values. This instruction ORs (bit-wise) the contents of src1 with the contents of src2, or it can OR the contents of src1 with the immediate value. The immediate value is <b>NOT</b> sign extended OR puts the result in the destination register       |  |
| <b>xor</b><br>(Exclusive-OR)<br><i>xor dst,sr1,sr2(im)</i> | Computes the <b>XOR</b> of two values. This instruction XORs (bit-wise) the contents of src1 with the contents of src2, or it can XOR the contents of src1 with the immediate value. The immediate value is <b>NOT</b> sign extended. Exclusive-OR puts the result in the destination register |  |
| not<br>(NOT)<br>not dst,src1                               | Computes the <b>Logical NOT</b> of a value. This instruction complements (bit-wise) the contents of src1 and puts the result in the destination register.                                                                                                                                      |  |
| <b>nor</b><br>(NOT OR)<br>nor dst,sr1,sr2                  | Computes the <b>NOT OR</b> of two values. This instruction combines the contents of src1 with the contents of src2 (or the immediate value). NOT OR complements the result and puts it in the destination register.                                                                            |  |



#### Logic Operation(2)

Run the demo and answer the question:

.data

dvalue1: .byte 27

dvalue2: .byte 4

.text

lb \$t0,dvalue1

lb \$t1,dvalue2

div \$t0,\$t1 mfhi \$a0

li \$v0,1 syscall

li \$v0,10 syscall .data

dvalue1: .byte 27

dvalue2: .byte 4

.text

lb \$t0,dvalue1

lb \$t1,dvalue2

**sub** \$t1,\$t1,1 **and** \$a0,\$t0,\$t1

li \$v0,1 syscall

li \$v0,10 syscall Q1: Is the output of two demos the same?

Q2: If use 5 instead of 4 as the initial value on dvalue2, is the output of two demos the same?

Q3: On which situation could use 'and' operation to get the remainder instead of division?

Q4: Do the logic operations work quicker than arithmetic operations?



# **Shift Operation**

| Туре   | Instruction name                        | description                                                                                                                                                                        |                                                                                                                                                                                                |  |
|--------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|        | <b>sll</b><br>(Shift Left Logical)      | Shifts the contents of a register left (toward the sign bit) and inserts zeros at the least-significant bit.                                                                       | The contents of src1 specify the value to shift, and the contents of src2 or the immediate value specify the amount to                                                                         |  |
| shift  | <b>sra</b><br>(Shift Right Arithmetic ) | Shifts the contents of a register right (toward the least-significant bit) and inserts the sign bit at the most-significant bit.                                                   | shift.  If src2 (or the immediate value) is greater                                                                                                                                            |  |
|        | <b>srl</b><br>(Shift Right Logical )    | Shifts the contents of a register right (toward the least-significant bit) and inserts zeros at the most-significant bit.                                                          | than 31 or less than 0, src1 shifts by the result of src2 MOD 32.                                                                                                                              |  |
| rotate | <b>rol</b><br>(Rotate Left )            | Rotates the contents of a register left (toward the sign bit).  This instruction inserts in the least-significant bit any bits that were shifted out of the sign bit.              | The contents of src1 specify the value to shift, and the contents of src2 (or the immediate value) specify the amount to shift. Rotate Left/right puts the result in the destination register. |  |
|        | <b>ror</b><br>(Rotate Right )           | Rotates the contents of a register right (toward the least-significant bit). This instruction inserts in the sign bit any bits that were shifted out of the least-significant bit. | If src2 (or the immediate value) is greater than 31, src1 shifts by the result of src2 MOD 32.                                                                                                 |  |



Run the demo to see if the output is same with the sample picture below? if not please find the reason and modify the code.

```
.include "macro_print_str.asm"
.data
.text
main:
    print string("please input an integer : ")
    li $v0,5
    syscall
                                                 please input an integer : 3
                                                 it is an odd number (0: false,1:true) : 1
           $t0, $v0
    move
         $t1, $zero, $zero
    nor
                                                 -- program is finished running --
    sra $t2, $t1, 31
    and $a0, $t2, $t0
    print_string("it is an odd number (0: false,1:true) : ")
    li $v0,1
    syscall
    end
                               CS202 wangw6@sustech.edu.cn
```



#### **Practice**

- 1. The data in a word is 0x12345678, exchange the bytes of this word to get the new value 0x78563412.
- 2. Write 2 demos which trigger overflow exception by using subtraction and multiplication separately, tell the difference between these two overflow exceptions.
- 3. Judge whether the binary representation of a input number is palindrome. for example,  $O(0)_2$ ,  $I(1)_2$ ,  $I(1)_$
- 4. "ror" is a extened(pseudo) instuction. Find the basic instruction set of "ror" and prove that they have the same function.



#### Tips: macro\_print\_str.asm

```
.macro print_string(%str)
    .data
        pstr: .asciiz %str
    .text
        la $a0,pstr
        li $v0,4
        syscall
.end_macro
.macro end
    li $v0,10
    syscall
.end_macro
```

Get help of defination and usage about macro from Mars' help page



### Tips: the data address in Mars



| Data Segment |            |            |            |
|--------------|------------|------------|------------|
| Address      | Value (+0) | Value (+4) | Value (+8) |
| 0x10010000   | 0x33221100 | 0x77685544 | 0x00000000 |

```
.include "macro print str.asm"
.data
      tdata0: .byte
0x00,0x11,0x22,0x33,0x44,0x55,0x66,0x77
.text
main:
      la $t0,tdata0
      lb $a0, ($t0)
      li $v0,34
      syscall
      la $t0,tdata0
      lb $a0, 1($t0)
      syscall
      lb $a0, 2($t0)
      syscall
      lb $a0, 3($t0)
      syscall
      lb $a0, 5($t0)
      syscall
      end
```