

# **CPU Instructions**

CS 154: Computer Architecture Lecture #4 Winter 2020

Ziad Matni, Ph.D. Dept. of Computer Science, UCSB Administrative

- •Lab 01 due today!
- •Lab 02 description will be out soon!

## Lecture Outline

• Instruction Set Architectures (ISA)

- MIPS instruction formats
- Refresher on some other MIPS instructions

*Reference material from CS64 – I'll be going over this a little fast...* 

# Other Factors to CPU Performance: **Power Consumption**

Market trends DEMAND that power consumption of CPUs keep decreasing.

**BUT** Power and Performance DON'T always go together...

- Power = Capacitive Load x Voltage<sup>2</sup> x Clock Frequency
- So:
  - Decreasing Voltage helps to get lower power, but it can make individual logic go slower!
  - Increasing clock frequency helps performance, but increases power!
- It's a dilemma that has contributed to Moore's Law "plateau"

# Other Factors to CPU Performance: Multiple Processors

- Multicore microprocessors
  - More than one processor per chip
- Requires explicitly parallel programming
  - Compare with instruction level parallelism
  - Hardware executes multiple instructions at once
  - Hidden from the programmer
- Hard to do
  - Programming for performance
  - Load balancing
  - Optimizing communication and synchronization

• Improving an aspect of a computer and expecting a proportional improvement in overall performance



• Your benchmark time is 100, 80 of which comes from a part of the CPU that you want to improve by a factor of *n*, so:

 $T_{improved} = (80 / n) + 20$ 

- If you wanted to improve your overall T by a factor of 2 (i.e. drop total from 100 to 50), then you'd need to make n = 2.7 because 50 = (80 / 2.7) + 20 ...ok...
- Keep that up! Let's go for a factor of **n = 5**, so drop total from 100 to 20:
   i.e. 20 ?= (80 / 5) + 20 ...uh... can't do that... 30

#### Pitfalls: Idle Power

- Simply put: CPUs will still draw *disproportionate* power when idling.
- Example, even when operating at 10% load, the i7 will draw 47% of the power
- Becomes a problem when dealing with large scale implementations, like data centers (Google, Facebook, Amazon, etc...)
- Design challenge: design processors to draw power more proportional to load (requires Physics-level approach, tho...)

## Pitfall: MIPS as a Performance Metric

- Note: We're NOT talking about MIPS the processor type !!!!
- **MIPS** (millions of instructions per second) is a popular performance metric, *HOWEVER*...
- Doesn't account for
  - Differences in ISAs between computers

(some ISAs may be more efficient than others)

• Differences in complexity between instructions (weighted CPIs)

## Instruction Set Architecture (ISA)

- The "contract" between software and hardware (hence, it's an abstract model of a computer!)
- Typically described with:
  - programmer-visible states (i.e. registers + memory)
  - the semantics/syntax of the instructions
  - Examples abound in your MIPS Reference Card!

## Instruction Set Architecture (ISA)

#### Many implementations possible for a given ISA

- Most microprocessor families have their own ISA
- Some can be shared across families (b/c they're popular)
  - Example: AMD and Intel processors both run the x86-64 ISA (orig. Intel).
- Some of the same ISAs can be *customized* 
  - Many cellphones use the ARM ISA with specific implementations from many different companies including

Apple, Qualcomm, Samsung, Huawei, etc.

• We'll be using the MIPS ISA in this class.

## Classification of ISAs

- By architectural complexity\*
  - **CISC** (complex instruction set computer) and **RISC** (reduced instruction set computer)

\* Most popular distinction in commercial CPUs

- By instruction-level parallelism
  - VLIW (very long instruction word) and EPIC (explicitly parallel instruction computing)
- By extreme simplification of instructions
  - **MISC** (minimal instruction set computer) and **OISC** (one instruction set computer)

# Intel, AMD (x86)CISCARM, MIPSRISCGPUs (AMD, Nvidia)RISCIntel/HP (IA-86)EPIC

#### CISC vs RISC:

- Higher instruction complexity (and CPI)
- More transistors
- Higher power
- Commercial computers vs. embedded computers

#### EPIC/VLIW:

- Less commercial than CISC/RISC
- Server/supercomputer use mostly

#### MISC/OISC:

- Little to no parallelism
- Mostly in research

## The MIPS ISA

- Developed at Stanford then commercialized by MIPS Technologies, created/led by John Hennessey
  - Stanford CS prof, President (2000-16), author of our textbook...
  - Started multiple important SV companies,

current Chair of Alphabet, Inc.

- Hennessey and Patterson won the 2017 Turing Award for their work in developing RISC architecture
- MIPS still has a large share of embedded core market
  - Consumer electronics, storage peripherals, cameras, printers, ...

## Code on MIPS

| Original   | MIPS                 |
|------------|----------------------|
|            | li \$t0, 5           |
| y = 7;     | li \$t1, 7           |
| z = x + y; | add \$t3, \$t0, \$t1 |

## Available Registers in MIPS

#### 32 registers in all

- Refer to your MIPS Reference Card
- Bring it to class from now on...
- Copy on main webpage

|               |           | NAME      | NUMBER      | USE                                                      |
|---------------|-----------|-----------|-------------|----------------------------------------------------------|
|               |           | \$zero    | 0           | The Constant Value 0                                     |
|               |           | \$at      | 1           | Assembler Temporary                                      |
|               | ata       | \$v0-\$v1 | 2-3         | Values for Function Results<br>and Expression Evaluation |
| Jsed for data | \$a0-\$a3 | 4-7       | Arguments   |                                                          |
|               | \$t0-\$t7 | 8-15      | Temporaries |                                                          |
| I             | Jse       | \$s0-\$s7 | 16-23       | Saved Temporaries                                        |
|               |           | \$t8-\$t9 | 24-25       | Temporaries                                              |
|               |           | \$k0-\$k1 | 26-27       | Reserved for OS Kernel                                   |
|               |           | \$gp      | 28          | Global Pointer                                           |
|               |           | \$sp      | 29          | Stack Pointer                                            |
|               |           | \$fp      | 30          | Frame Pointer                                            |
|               |           | \$ra      | 31          | Return Address                                           |
|               | ,         |           |             |                                                          |

- Each instruction is represented with 32 bits
- There are **three** different *instruction formats*: R, I, J
  - These allow for instructions to take on different roles
  - R-Format is used when it's all about registers
  - I-Format is used when you involve (immediate) numbers
  - J-Format is used when you do code "jumping"

(i.e. branching)



#### Since all instructions are 32-bits, then they each occupy 4 Bytes of memory. Remember: Memory is addressed in Bytes.



# **Registers** \$t0: ? \$t1: ? \$t2: ?



# Arithmetic Logic Unit

?

# Instruction Register ?

# **Registers**\$t0: ? \$t1: ? \$t2: ?



# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1

# Arithmetic Logic Unit

?



# **Registers**\$t0: ? \$t1: ? \$t2: ?



# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1

# Arithmetic Logic Unit ?







#### Memory

0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1

# Arithmetic Logic Unit ------?

# Instruction Register li \$t0, 5

# **Registers** \$t0: 5 \$t1: ? \$t2: ?



# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1









# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1

# Arithmetic Logic Unit ?



# **Registers** \$t0: 5 \$t1: 7 \$t2: ?



#### Memory

0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1

## Arithmetic Logic Unit

?

#### Instruction Register

li \$t1, 7

# **Registers** \$t0: 5 \$t1: 7 \$t2: ?



Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1









# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1

# Arithmetic Logic Unit ?







# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1



# Instruction Register add \$t3, \$t0, \$t1

# **Registers** \$t0: 5 \$t1: 7 \$t2: 12



# Memory 0: li \$t0, 5 4: li \$t1, 7 8: add \$t3, \$t0, \$t1



## Talking to the OS

- We are going to be running on MIPS *emulator* called **SPIM** 
  - Optionally, through a program called **QtSPIM** (GUI based)
  - What is an emulator?
- MIPS features a **syscall** instruction, which triggers a **software** *interrupt*, or *exception*
- Outside of an emulator (i.e. in the real world), these instructions **pause the program** and tell the OS to go do something with I/O
- Inside the emulator, it tells the emulator to go emulate something with I/O

## syscall (for spim use)

- The OS/emulator has access to the CPU registers
- So we have the OS/emulator's attention, but how does it know what we want?
- We put special values (codes) in the registers to indicate what we want
  - These are codes that can't be used for anything else, so they're understood to be just for syscall
  - So... is there a "code book"????

Yes! All CPUs come with manuals. For us, we have the MIPS Ref. Card

| MIPS Syste | em Ser          | rvices           |                                   | em call code:<br>Iment:   | placed in<br>placed in |  |
|------------|-----------------|------------------|-----------------------------------|---------------------------|------------------------|--|
|            | Service         | System Call Code | Arguments                         | Result                    |                        |  |
|            | print_int       | 1                | \$a0 = integer                    |                           |                        |  |
|            | print_float     | 2                | \$f12 = float                     |                           |                        |  |
|            | print_double    | 3                | \$f12 = double                    |                           |                        |  |
|            | print_string    | 4                | \$a0 = string                     |                           | stdout                 |  |
|            | read_int        | 5                |                                   | integer (in \$v0)         |                        |  |
|            | read_float      | 6                |                                   | float (in \$£0)           |                        |  |
|            | read_double     | 7                |                                   | double (in \$f0)          |                        |  |
|            | read_string     | 8                | a0 = buffer, a1 = length          |                           | stdin                  |  |
|            | sbrk            | 9                | \$a0 = amount                     | address (in \$v0)         |                        |  |
|            | exit            | 10               |                                   |                           |                        |  |
|            | print_character | 11               | \$a0 = character                  |                           |                        |  |
|            | read_character  | 12               |                                   | character (in \$v0)       |                        |  |
|            | open            | 13               | \$a0 = filename,                  | file descriptor (in \$v0) |                        |  |
|            |                 |                  | \$a1 = flags, \$a2 = mode         |                           |                        |  |
|            | read            | 14               | \$a0 = file descriptor,           | bytes read (in \$v0)      |                        |  |
|            |                 |                  | \$a1 = buffer, \$a2 = count       |                           |                        |  |
|            | write           | 15               | \$a0 = file descriptor,           | bytes written (in \$v0)   |                        |  |
|            |                 |                  | \$a1 = buffer, \$a2 = count       |                           |                        |  |
|            | close           | 16               | <pre>\$a0 = file descriptor</pre> | 0 (in \$v0)               | File I/O               |  |
| 1/15/20    | exit2           | 17               | \$a0 = value                      |                           | 30                     |  |

# **Bring out your MIPS Reference Cards!**

| CORE INSTRUCTI                 | ON SE |             |                                                       |         | OPCODE                                     |
|--------------------------------|-------|-------------|-------------------------------------------------------|---------|--------------------------------------------|
| NAME MNEMO                     | NIC   | FOR-<br>MAT |                                                       |         | / FUNCT                                    |
| NAME, MNEMO<br>Add             | add   | R           | OPERATION (in Verilog)<br>R[rd] = R[rs] + R[rt]       | m       | (Hex)<br>0/20 <sub>hex</sub>               |
| Add Immediate                  | addi  | I           | R[rt] = R[rs] + SignExtImm                            | (1,2)   | 8 <sub>hex</sub>                           |
| Add Imm. Unsigned              |       |             | () () 0                                               | (1,2)   | 9 <sub>hex</sub>                           |
|                                |       | R           | R[rt] = R[rs] + SignExtImm                            | (2)     | <sup>9</sup> hex<br>0/21 <sub>hex</sub>    |
| Add Unsigned                   | addu  |             | R[rd] = R[rs] + R[rt]                                 |         | 0/21 <sub>hex</sub><br>0/24 <sub>hex</sub> |
| And                            | and   | R           | R[rd] = R[rs] & R[rt]                                 | (2)     |                                            |
| And Immediate                  | andi  | I           | R[rt] = R[rs] & ZeroExtImm                            | (3)     | chex                                       |
| Branch On Equal                | beq   | Ι           | if(R[rs]==R[rt])<br>PC=PC+4+BranchAddr                | (4)     | 4 <sub>hex</sub>                           |
| Branch On Not Equa             | bne   | Ι           | if(R[rs]!=R[rt])<br>PC=PC+4+BranchAddr                | (4)     | 5 <sub>hex</sub>                           |
| Jump                           | t     | J           | PC=JumpAddr                                           | (5)     | 2 <sub>hex</sub>                           |
| Jump And Link                  | jal   | J           | R[31]=PC+8;PC=JumpAddr                                | (5)     | 3 <sub>hex</sub>                           |
| Jump Register                  | jr    | R           | PC=R[rs]                                              |         | 0/08 <sub>hex</sub>                        |
| Load Byte Unsigned             | lbu   | I           | R[rt]={24'b0,M[R[rs]<br>+SignExtImm](7:0)}            | (2)     | 24 <sub>hex</sub>                          |
| Load Halfword<br>Unsigned      | lhu   | I           | R[rt]={16'b0,M[R[rs]<br>+SignExtImm](15:0)}           | (2)     | 25 <sub>hex</sub>                          |
| Load Linked                    | 11    | Ι           | R[rt] = M[R[rs]+SignExtImm]                           | (2,7)   | 30 <sub>hex</sub>                          |
| Load Upper Imm.                | lui   | Ι           | R[rt] = {imm, 16'b0}                                  |         | fhex                                       |
| Load Word                      | lw    | I           | R[rt] = M[R[rs]+SignExtImm]                           | (2)     | 23 <sub>hex</sub>                          |
| Nor                            | nor   | R           | $R[rd] = \sim (R[rs]   R[rt])$                        |         | 0/27 <sub>hex</sub>                        |
| Or                             | or    | R           | R[rd] = R[rs]   R[rt]                                 |         | 0/25 <sub>hex</sub>                        |
| Or Immediate                   | ori   | I           | R[rt] = R[rs]   ZeroExtImm                            | (3)     | dhex                                       |
| Set Less Than                  | slt   | R           | R[rd] = (R[rs] < R[rt]) ? 1 : 0                       |         | 0/2a <sub>hex</sub>                        |
| Set Less Than Imm.             | slti  | I           | R[rt] = (R[rs] < SignExtImm)? 1                       | : 0 (2) | ahex                                       |
| Set Less Than Imm.<br>Unsigned | sltiu | I           | R[rt] = (R[rs] < SignExtImm)<br>? 1 : 0               | (2,6)   | b <sub>hex</sub>                           |
| Set Less Than Unsig.           | sltu  | R           | R[rd] = (R[rs] < R[rt]) ? 1 : 0                       | (6)     | 0 / 2b <sub>hex</sub>                      |
| Shift Left Logical             | s11   | R           | R[rd] = R[rt] << shamt                                |         | 0 / 00 <sub>hex</sub>                      |
| Shift Right Logical            | srl   | R           | R[rd] = R[rt] >> shamt                                |         | 0 / 02 <sub>hex</sub>                      |
| Store Byte                     | sb    | I           | M[R[rs]+SignExtImm](7:0) = R[rt](7:0)                 | (2)     | 28 <sub>hex</sub>                          |
| Store Conditional              | sc    | I           | M[R[rs]+SignExtImm] = R[rt];<br>R[rt] = (atomic)? 1:0 | (2,7)   | 38 <sub>hex</sub>                          |
| Store Halfword                 | sh    | I           | M[R[rs]+SignExtImm](15:0) = R[rt](15:0)               | (2)     | 29 <sub>hex</sub>                          |
| Store Word                     | sw    | I           | M[R[rs]+SignExtImm] = R[rt]                           | (2)     | 2b <sub>hex</sub>                          |
| Subtract                       | sub   | R           | R[rd] = R[rs] - R[rt]                                 | (1)     |                                            |
| Subtract Unsigned              | subu  | R           | R[rd] = R[rs] - R[rt]                                 |         | 0/23 <sub>hex</sub>                        |
| 0                              |       |             |                                                       |         | INCA                                       |

#### **NOTE THE FOLLOWING:**

# Instruction Format Types: **R** vs I vs J

#### 2. OPCODE/FUNCT (Hex)

# Instruction formats: Where the actual bits go

#### **BASIC INSTRUCTION FORMATS**

tni, CS154, Wi20

| R | opco | de | I  | 8  | г  | t  | rd |     | shamt    | fun | ct |
|---|------|----|----|----|----|----|----|-----|----------|-----|----|
|   | 31   | 26 | 25 | 21 | 20 | 16 | 15 | -11 | 10 6     | 5   | 0  |
| I | opco | de | I  | 8  | I  | t  |    |     | immediat | e   |    |
|   | 31   | 26 | 25 | 21 | 20 | 16 | 15 |     |          |     | 0  |
| J | opco | de |    |    |    |    |    | SS  |          |     |    |
|   | 31   | 26 | 25 |    |    |    |    |     |          |     | 0  |

#### PSEUDOINSTRUCTION SET

| NAME                         | MNEMONIC | OPERATION                                    |
|------------------------------|----------|----------------------------------------------|
| Branch Less Than             | blt      | if(R[rs] <r[rt]) pc="Label&lt;/td"></r[rt])> |
| Branch Greater Than          | bgt      | if(R[rs]>R[rt]) PC = Label                   |
| Branch Less Than or Equal    | ble      | if(R[rs]<=R[rt]) PC = Label                  |
| Branch Greater Than or Equal | bge      | if(R[rs]>=R[rt]) PC = Label                  |
| Load Immediate               | 11       | R[rd] = immediate                            |
| Move                         | move     | R[rd] = R[rs]                                |
|                              |          |                                              |

#### **NOTE THE FOLLOWING:**

#### 1. Pseudo-Instructions

 There are more of these, but in this class, you are ONLY allowed to use these + la

#### REGISTER NAME, NUMBER, USE, CALL CONVENTION

| NAME      | NUMBER | USE                                                      | PRESERVED ACROSS<br>A CALL? |
|-----------|--------|----------------------------------------------------------|-----------------------------|
| Szero     | 0      | The Constant Value 0                                     | N.A.                        |
| Şat       | 1      | Assembler Temporary                                      | No                          |
| \$v0-\$v1 | 2-3    | Values for Function Results<br>and Expression Evaluation | No                          |
| \$a0-\$a3 | 4-7    | Arguments                                                | No                          |
| \$t0-\$t7 | 8-15   | Temporaries                                              | No                          |
| \$s0-\$s7 | 16-23  | Saved Temporaries                                        | Yes                         |
| \$t8-\$t9 | 24-25  | Temporaries                                              | No                          |
| \$k0-\$k1 | 26-27  | Reserved for OS Kernel                                   | No                          |
| \$gp      | 28     | Global Pointer                                           | Yes                         |
| \$sp      | 29     | Stack Pointer                                            | Yes                         |
| \$fp      | 30     | Frame Pointer                                            | Yes                         |
| \$ra      | 31     | Return Address                                           | No                          |

- 2. Registers and their numbers
- 3. Registers and their uses
- 4. Registers and their calling convention

= Label = Label



#### **NOTE THE FOLLOWING:**

 This is only part of the 2<sup>nd</sup> page that you need to know

#### DATA ALIGNMENT

| Double Word |      |      |      |                 |      |      |      |  |  |  |
|-------------|------|------|------|-----------------|------|------|------|--|--|--|
|             | Wo   | rd   |      | Word            |      |      |      |  |  |  |
| Halfword    |      | Half | word | Halfword Halfwo |      |      | word |  |  |  |
| Byte        | Byte | Byte | Byte | Byte            | Byte | Byte | Byte |  |  |  |
| 0           | 1    | 2    | 3    | 4               | 5    | 6    | 7    |  |  |  |

Value of three least significant bits of byte address (Big Endian)

#### SIZE PREFIXES (10<sup>x</sup> for Disk, Communication; 2<sup>x</sup> for Memory)

|                                    | PRE-  |                                    | PRE-   |       | PRE-   |       | PRE-   |
|------------------------------------|-------|------------------------------------|--------|-------|--------|-------|--------|
| SIZE                               | FIX   | SIZE                               | FIX    | SIZE  | FIX    | SIZE  | FIX    |
| $10^3, 2^{10}$                     | Kilo- | 10 <sup>15</sup> , 2 <sup>50</sup> | Peta-  | 10-3  | milli- | 10-15 | femto- |
| $10^6, 2^{20}$                     | Mega- | 10 <sup>18</sup> , 2 <sup>60</sup> | Exa-   | 10-6  | micro- | 10-18 | atto-  |
| $10^9, 2^{30}$                     | Giga- | $10^{21}, 2^{70}$                  | Zetta- | 10-9  | nano-  | 10-21 | zepto- |
| 10 <sup>12</sup> , 2 <sup>40</sup> | Tera- | 10 <sup>24</sup> , 2 <sup>80</sup> | Yotta- | 10-12 | pico-  | 10-24 | yocto- |
| <br>                               |       |                                    |        |       |        |       | -      |

The symbol for each prefix is just its first letter, except  $\mu$  is used for micro.

# Bring Out Your MIPS Reference Cards!

#### Look for the following instructions:

- nor
- addi
- beq
- move

# Tell me everything you can about them, based on what you see on the Ref Card!

## Example 1

#### Syntax for "add" add rd, rs, rt destination, source1, source2

$$f = (g + h) - (i + j)$$
  
i.e. \$s0 = (\$s1 + \$s2) - (\$s3 + \$s4)  
add \$t0, \$s1, \$s2  
add \$t1, \$s3, \$s2  
sub \$s0, \$t0, \$t1

## Example 2

f = g \* h - ii.e. \$s0 = (\$s1 \* \$s2) - \$s3

mult \$s1, \$s2
mflo \$t0
# mflo directs where the answer of the
mult should go
sub \$s0, \$t0, \$s3

## Recap: The **mult** instruction

• To multiply 2 integers together:

| li \$t0, 5      | # t0 = 5                      |
|-----------------|-------------------------------|
| li \$t1, 6      | # t1 = 6                      |
| mult \$t1, \$t0 | <pre># multiply t0 * t1</pre> |
| mflo \$t2       | # t2 = t0 * t1                |

- **mult** <u>cannot</u> be used with an 'immediate' value
- Then we multiply our multiplier (\$t0) with our multiplicand (\$t1)
- And we put the result in the destination reg (\$t2) using the **mflo** instruction

#### Memory Operations

#### • Main memory used for composite data

- e.g.: Arrays, structures, dynamic data
- In MIPS, use the **.data declaration** to initialize memory values (must be above **.text declaration**)
- Example:

| .data            |                      |
|------------------|----------------------|
| var1: .word 42   |                      |
| .text            |                      |
| la \$t0, var1    | # t0 = &var1         |
| lw \$t1, 0(\$t0) | # t1 = *(&var1) = 42 |

#### .data

name: .asciiz "Lisa speaks "
rtn: .asciiz " languages!\n"
age: .word 7



| .text |          |      |        |         |         |          |               |             |                    |   |
|-------|----------|------|--------|---------|---------|----------|---------------|-------------|--------------------|---|
| main: | 1: 400   | Л    |        |         |         |          |               | Γ           | Stack              | Γ |
|       | li \$v0, |      |        |         |         |          |               | - F         |                    | L |
|       | la \$a0, | name | # la = | load me | emory a | address  |               |             | $\downarrow$       |   |
|       | syscall  |      |        |         |         |          |               |             | Free Memory        |   |
|       | la \$t2, | age  |        |         |         |          |               |             | Ť                  |   |
|       | lw \$a0, | •    |        |         |         |          |               | Γ           | Heap               | Γ |
|       | -        | • •  |        |         |         |          |               |             | Пеар               |   |
|       | li \$v0, | 1    |        |         |         |          |               |             |                    |   |
|       | syscall  |      |        |         |         | What goe | es in here? 코 | > ∥         | Initialized Data   |   |
|       | li \$v0, | 4    |        |         |         |          |               | ľ           | Uninitialized Data | - |
|       | -        |      |        |         |         |          |               |             | (BSS)              |   |
|       | la \$a0, | rtn  |        |         |         |          |               | ⊢           |                    |   |
|       | syscall  |      |        |         |         | What goe | es in here? 코 | <b>&gt;</b> | Text               |   |
|       | li \$v0, | 10   |        |         |         |          |               | L           |                    |   |
|       | syscall  |      |        |         |         |          |               |             | 40                 |   |
|       |          |      |        |         |         |          |               |             |                    |   |

## .data Declaration Types w/ Examples

| var1: | .byte 9        | <pre># declare a single byte with value 9</pre>     |
|-------|----------------|-----------------------------------------------------|
| var2: | .half 63       | <pre># declare a 16-bit half-word w/ val. 63</pre>  |
| var3: | .word 9433     | <pre># declare a 32-bit word w/ val. 9433</pre>     |
| num1: | .float 3.14    | <pre># declare 32-bit floating point number</pre>   |
| num2: | .double 6.28   | <pre># declare 64-bit floating pointer number</pre> |
| str1: | .ascii "Text"  | <pre># declare a string of chars</pre>              |
| str3: | .asciiz "Text" | <pre># declare a null-terminated string</pre>       |
| str2: | .space 5       | # reserve 5 bytes of space (useful for arrays)      |

These are now reserved in memory and we can call them up by loading their memory address into the appropriate registers.

## YOUR TO-DOs for the Week

- Do your reading for next class (see syllabus)
- Work on Assignment #1 for lab (*lab01*)
  - Meet up in the lab this Friday
  - Do the lab assignment
  - You have to submit it as a **PDF** using *Gradescope*
  - Due on Wednesday, 1/15, by 11:59:59 PM

