# Lecture 2: The Instruction Set Architecture

COS / ELE 375

# Computer Architecture and Organization

Princeton University Fall 2015

Prof. David August

# Quiz 0



# Quiz 0

#### Combinational





#### MUX





#### CD



# Pits and Lands



Transition represents a bit state (1/on/red/female/heads) No change represents other state (0/off/white/male/tails)



# Interpretation – ASCII

| ASCII<br>value | Character         | Control<br>character | ASCII<br>value | Character | ASCII<br>value | Character | ASCII<br>value | Character |
|----------------|-------------------|----------------------|----------------|-----------|----------------|-----------|----------------|-----------|
| 000            | (null)            | NUL                  | 032            | (space)   | 064            | æ         | 096            |           |
| 001            | 0                 | SOH                  | 033            | 1         | 065            | A         | 097            | α         |
| 002            | •                 | STX                  | 034            | "         | 066            | В         | 098            | ь         |
| 003            | <b>v</b>          | ETX                  | 035            | #         | 067            | C         | 099            | С         |
| 004            | <b>*</b>          | EOT                  | 036            | \$        | 068            | D         | 100            | d         |
| 005            | *                 | ENO                  | 037            | %         | 069            | E         | 101            | e         |
| 006            | <b>A</b>          | ACK                  | 038            | &r        | 070            | F         | 102            | f         |
| 007            | (beep)            | BEL                  | 039            | 1         | 071            | G         | 103            | g         |
| 800            | 13                | BS                   | 040            | (         | 072            | H         | 104            | h         |
| 009            | (tab)             | HT                   | 041            | )         | 073            | I         | 105            | i         |
| 010            | (line feed)       | LF                   | 042            | •         | 074            | I         | 106            | i         |
| 011            | (home)            | VT                   | 043            | +         | 075            | K         | 107            | k         |
| 012            | (form feed)       | FF                   | 044            | ,         | 076            | L         | 108            | 1         |
| 013            | (carriage return) | CR                   | 045            | -         | 077            | M         | 109            | m         |
| 014            | ມ                 | SO                   | 046            |           | 078            | N         | 110            | n         |
| 015            | ☼                 | SI                   | 047            | /         | 079            | 0         | 111            | 0         |
| 016            | <b>D</b> -        | DLE                  | 048            | 0         | 080            | P         | 112            | Р         |
| 017            |                   | DC1                  | 049            | 1         | 081            | Q         | 113            | q         |
| 018            | <b>1</b>          | DC2                  | 050            | 2         | 082            | R         | 114            | r         |
| 019            | 1]                | DC3                  | 051            | 3         | 083            | S         | 115            | S         |
| 020            | π                 | DC4                  | 052            | 4         | 084            | T         | 116            | t         |
| 021            | §                 | NAK                  | 053            | 5         | 085            | U         | 117            | u         |
| 022            | 4849              | SYN                  | 054            | 6         | 086            | V         | 118            | v         |
| 023            | <u></u>           | ETB                  | 055            | 7         | 087            | W         | 119            | w         |
| 024            | <b>†</b>          | CAN                  | 056            | 8         | 088            | X         | 120            | x         |
| 025            | į.                | EM                   | 057            | 9         | 089            | Y         | 121            | У         |
| 026            | · →               | SUB                  | 058            | :         | 090            | Z         | 122            | z         |
| 027            | ←                 | ESC                  | 059            | ;         | 091            | [         | 123            | {         |
| 028            | (cursor right)    | FS                   | 060            | <         | 092            | \         | 124            | 1         |
| 029            | (cursor left)     | GS                   | 061            | = '       | 093            | 1         | 125            | }         |
| 030            | (cursor up)       | RS                   | 062            | >         | 094            | $\wedge$  | 126            | 12        |
| 031            | (cursor down)     | US                   | 063            | ?         | 095            | _         | 127            |           |

# Interpretation



As Music:

 $01110101_2 = 117/256$  position of speaker

As Number:

 $01110101_2 = 1 + 4 + 16 + 32 + 64 = 117_{10} = 75_{16}$  (Get comfortable with base 2, 8, 10, and 16.)

As Text:

 $01110101_2 = 117$ <sup>th</sup> character in the ASCII codes = "u"

# Princeton Computer Science Building West Wall



# Interpretation



As Music:

 $01110101_2 = 117/256$  position of speaker

As Number:

$$01110101_2 = 1 + 4 + 16 + 32 + 64 = 117_{10} = 75_{16}$$

As Text:

 $01110101_2 = 117^{th}$  character in the ASCII codes = "u"

CAN ALSO BE INTERPRETED AS MACHINE INSTRUCTION!

# Interfaces in Computer Systems

Software: Produce Bits Instructing Machine to Manipulate State or Produce I/O



Hardware: Read and Obey Instruction Bits

# Binary Code and Data (Hello World!)

- Programs consist of Code and Data
- Code and Data are Encoded in Bits

```
00000000: 7f45 4c46 0201 0100 0000 0000 0000 0000 .ELF......
                                                                                               IA-64 Binary (objdump)
00000260: 5002 0000 0000 0000 006c 6962 632e 736f
00000270: 2e36 2e31 0070 7269 6e74 6600 5f5f 6c69
00000280: 6263 5f73 7461 7274 5f6d 6169 6e00 474c
                                                                    P......libc.so
.6.1.printf.__li
bc_start_main.GL
00000290: 4942 435f 322e 3200 0000 0200 0200 0000
00000860: 4865 6c6c 6f20 576f 726c 6421 0d00 0000 Hello world!...
4000000000000690 <main>:
40000000000000690:
                                00 10 15 08 80 05
30 02 30 00 42 20
04 00 c4 00
                                                                 [MII]
                                                                                 alloc_r34=ar.pfs,5,4,0
40000000000000696
                                                                                 mov r35=r12
                                                                                 mov r33=b0
                                0a 20 81 03 00 24
40 02 90 30 20 00
                                                                 [MMI]
400000000000006a0:
                                                                                 add1 r36=96.r1::
400000000000006a6:
                                                                                 1d8 r36=[r36]
                                04 08 00 84
1d 00 00 00 01 00
400000000000006ac
                                                                                 mov r32=r1
[MFB]
                                                                                nop.m 0x0
                                                                                hop.f 0x0
br.call.sptk.many b0=400000000000460;
mov r1=r32
400000000000006b6:
                                00 00 00 02 00 00
b8 fd ff 58
400000000000006bc
                                00 08 00 40 00 21
80 00 00 00 42 00
20 02 aa 00
00 00 00 00 01 00
00 08 05 80 03 80
                                                                 [MII]
400000000000006c6:
                                                                                mov r8=r0
400000000000006cc:
                                                                                mov.i ar.pfs=r34
4000000000000640
                                                                 [MII]
                                                                                 nop.m 0x0
400000000000000dd6:
                                                                                mov b0=r33
                                01 18 01 84
1d 00 00 00 01 00
00 00 00 02 00 80
40000000000006dc
                                                                                 mov r12=r35
                                                                 [MFB]
400000000000006e0:
                                                                                nop.m 0x0
nop.f 0x0
40000000000006ec:
                                08 00 84 00
                                                                                br.ret.sptk.many b0;;
```

#### Instructions



- Instructions instruct processor to manipulate state
- Instructions instruct processor to produce I/O in the same way

Typical modern machine has this architectural state:

- 1. Main Memory
- 2. Registers
- 3. Program Counter

Architectural – Part of the assembly programmer's interface (Implementation has additional microarchitectural state)

Main Memory (AKA: RAM – Random Access Memory)

- Data can be accessed by address (like a big array)
- Large but relatively slow
- Decent desktop machine: 1 Gigabyte, 800MHz

| Address | Data             |
|---------|------------------|
| 0000    | 010110012        |
| 0001    | F5 <sub>16</sub> |
| 0002    | 78 <sub>16</sub> |
| 0003    | 3A <sub>16</sub> |
|         |                  |
| FFFF    | 000000002        |



Byte Addressable

# State - Main Memory

#### Read:

- 1. Indicate READ
- 2. Give Address
- 3. Get Data

| Address | Data             |
|---------|------------------|
| 0000    | 010110012        |
| 0001    | F5 <sub>16</sub> |
| 0002    | 78 <sub>16</sub> |
| 0003    | 3A <sub>16</sub> |
|         |                  |
| FFFF    | 000000002        |



# State - Main Memory

#### Write:

- 1. Indicate WRITE
- 2. Give Address and Data

| Address | Data                    |
|---------|-------------------------|
| 0000    | 01011001 <sub>2</sub>   |
| 0001    | F5 <sub>16</sub>        |
| 0002    | 78 <sub>16</sub>        |
| 0003    | <b>12</b> <sub>16</sub> |
|         |                         |
| FFFF    | 000000002               |



15

# State - Registers

Registers (AKA: Register File)

- Data can be accessed by register number (address)
- Small but relatively fast (typically on processor chip)
- Decent desktop machine: 8 32-bit registers, 3 GHz





| Data in Reg            |
|------------------------|
| 00000000 <sub>16</sub> |
| F629D9B5 <sub>16</sub> |
| 7B2D9D08 <sub>16</sub> |
| 000000116              |
|                        |
| DEADBEEF <sub>16</sub> |
|                        |





# State – Program Counter

Program Counter (AKA: PC, Instruction Pointer, IP)

- Instructions change state, but which instruction now?
- PC holds address of currently executing instruction
- PC is updated after each instruction



# State – Program Counter

Program Counter (AKA: PC, Instruction Pointer, IP)

- Instructions change state, but which instruction now?
- PC holds memory address of currently executing instruction



# State - Summary

Typical modern machine has this architectural state:

- 1. Main Memory Big, Slow
- 2. Registers Small, Fast (always on processor chip)
- 3. Program Counter Address of executing instruction

Architectural – Part of the assembly programmer's interface

(implementation has additional microarchitectural state)

19

- Core Dump: the state of the machine at a given time
- Typically at program failure
- Core dump contains:
  - Register Contents
  - Memory Contents
  - PC Value

| Registers |      |      |      |      |      |      |      |  |
|-----------|------|------|------|------|------|------|------|--|
| 0         | 1    | 2    | 3    | 4    | 5    | 6    | 7    |  |
| 0000      | 0788 | B700 | 0010 | 0401 | 0002 | 0003 | 00A0 |  |
| 8         | 9    | A    | В    | С    | D    | E    | F    |  |
| 0000      | 0788 | в700 | 0010 | 0401 | 0002 | 0003 | 00A0 |  |

|     | Main Memory |      |      |      |      |      |      |      |
|-----|-------------|------|------|------|------|------|------|------|
| 00: | 0000        | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| 08: | 0000        | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| 10: | 9222        | 9120 | 1121 | A120 | 1121 | A121 | 7211 | 0000 |
| 18: | 0000        | 0001 | 0002 | 0003 | 0004 | 0005 | 0006 | 0007 |
| 20: | 0008        | 0009 | 000A | 000B | 000C | 000D | 000E | 000F |
| 28: | 0000        | 0000 | 0000 | FE10 | FACE | CAFE | ACED | CEDE |
|     |             |      |      |      |      |      |      |      |
|     |             |      |      |      |      |      |      |      |
| E8: | 1234        | 5678 | 9ABC | DEF0 | 0000 | 0000 | F00D | 0000 |
| F0: | 0000        | 0000 | EEEE | 1111 | EEEE | 1111 | 0000 | 0000 |
| F8: | B1B2        | F1F5 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |

# Interfaces in Computer Systems

Software: Produce Bits Instructing Machine to Manipulate State or Produce I/O



Hardware: Read and Obey Instruction Bits

#### **Instructions**

21

An ADD Instruction:



10

#### Parts of the Instruction:

- Opcode (verb) what operation to perform
- Operands (noun) what to operate upon
- Source Operands where values come from
- Destination Operand where to deposit data values

#### Instructions

#### **Instructions:**

"The vocabulary of commands" Specify how to operate on state

#### Example:

40: add r1 = r2 + r344: sub r3 = r1 - r048: store M[ r3 ] = r1

52: load r2 = M[2]

Program Counter 40

| Register | Data |
|----------|------|
| 0        | 0    |
| 1        | 15   |
| <u>2</u> | 1    |
| 3        | 2    |
|          |      |
| 31       | 0    |
| <u> </u> |      |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 9    |
|         |      |
| FFFFFFF | 0    |

# **Instructions**

#### **Instructions:**

"The vocabulary of commands" Specify how to operate on state

#### Example:

| 40: add $3 = r2 + r3$  |
|------------------------|
| 44: $sub r3 = r1 - r0$ |
| 48: store M[ r3 ] = r1 |
| 52: load r2 = M[ 2 ]   |

| Program Counter |
|-----------------|
| 40              |

| Register | Data |
|----------|------|
| 0        | 0    |
| 1        | 15   |
| 2        | 1    |
| 3        | 2    |
|          |      |
| 31       | 0    |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 9    |
|         |      |
| FFFFFFF | 0    |

# Instructions

# Example:

40: add r1 = r2 + r3 44: sub r3 = r1 - r0 48: store M[ r3 ] = r1 52: load r2 = M[ 2 ]

| Program Counter |
|-----------------|
| 40              |

| Register | Data |
|----------|------|
| 0        | 0    |
| 1        | 3    |
| 2        | 1    |
| 3        | 2    |
|          | •••  |
| 31       | 0    |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 9    |
| •••     |      |
| FFFFFFF | 0    |

# **Instructions**

# Instructions:

"The vocabulary of commands" Specify how to operate on state

# Example:

| Program Counter |
|-----------------|
| 44              |

# Register Data 0 0 1 3 2 1 3 2 ... ... 31 0

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 9    |
|         |      |
| FFFFFFF | 0    |

# Instructions

#### **Instructions:**

"The vocabulary of commands" Specify how to operate on state

#### Example:

40: add r1 = r2 + r3 44: sub r3 = r1 - r0 48: store M[ r3 ] = 3 52: load r2 = M[ 2 ]

| Program Counter |
|-----------------|
| 48              |

| Register | Data |
|----------|------|
| 0        | 0    |
| 1        | 3    |
| 2        | 1    |
| 3        | 3    |
|          |      |
| 31       | 0    |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 9    |
|         |      |
| FFFFFFF | 0    |

# **Instructions**

#### **Instructions:**

"The vocabulary of commands" Specify how to operate on state

#### Example:

| 40: add $r1 = r2 + r3$     |
|----------------------------|
| 44: $sub r3 = r1 - r0$     |
| 48: store M[ r3 ] = r1     |
| 52: load <b>5</b> = M[ 2 ] |

| Program Counter |
|-----------------|
| 52              |

| Data |
|------|
| 0    |
| 3    |
| 1    |
| 3    |
|      |
| 0    |
|      |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 3    |
|         |      |
| FFFFFFF | 0    |

# **Instructions**

#### Instructions:

"The vocabulary of commands" Specify how to operate on state

#### Example:

| Program Counter |
|-----------------|
| 52              |

| Register | Data |
|----------|------|
| 0        | 0    |
| 1        | 3    |
| 2        | 5    |
| 3        | 3    |
|          |      |
| 31       | 0    |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 3    |
| •••     |      |
| FFFFFFF | 0    |

# **Instructions**

#### Note:

- 1. Insts Executed in Order
- 2. Addressing Modes

# Example:

| Program Counter |
|-----------------|
| 52              |

| Register | Data |
|----------|------|
| 0        | 0    |
| 1        | 3    |
| 2        | 5    |
| 3        | 3    |
| •••      |      |
| 31       | 0    |

| Address | Data |
|---------|------|
| 0       | 0    |
| 1       | 25   |
| 2       | 5    |
| 3       | 3    |
|         |      |
| FFFFFFF | 0    |

# Assembly Instructions and C



# **Branching**

Suppose we could only execute instructions in sequence.

Recall from our example:

- In a decent desktop machine, how long would the longest program stored in main memory take?
- Assume:
  - 1 instruction per cycle
  - An instruction is encoded in 4 bytes (32 bits)

# Therefore...

- Some instructions must execute more than once
- PC must be updated

# Example:



# **Unconditional Branches**

- Unconditional branches always update the PC
- AKA: Jump instructions

# Example:

How long with the program take?

35

# **Conditional Branch**

- Conditional Branch sometimes updates PC
- AKA: Branch, Conditional Jump
- Example

40: r1 = 10

44: r1 = r1 - 1

48: branch r1 > 0, 44  $\leftarrow$  if r1 is greater than 0, PC = 44

52: halt

How long will this program take?

# **Indirect Branches**

- Branch address may also come from a register
- AKA: Indirect Jump

# Example:

40: add r1 = r2 + r344: sub r3 = r1 - r048: store M[ r3 ] = r1

52: load r2 = M[2]

56: jump r4

60: halt

# **Conditional Branch**

What does this look like in C?

Example

10: "Hello\n"; data in memory

36: arg1 = 10; argument memory address is 10

40: r1 = 10

44: r1 = r1 - 1

48: call printf ; printf(arg1)

52: branch r1 > 0, 44

56: halt

Details about red instructions/data next time...

# **Branch Summary**

- Reduce, Reuse, Recycle (instructions)
- Branch instructions update state

|    |      | Registers |      |      |      |      |      |      |  |
|----|------|-----------|------|------|------|------|------|------|--|
|    | 0    | 1         | 2    | 3    | 4    | 5    | 6    | 7    |  |
|    | 0000 | 0788      | в700 | 0010 | 0401 | 0002 | 0003 | 00A0 |  |
| PC | 8    | 9         | A    | В    | С    | D    | E    | F    |  |
| 10 | 0000 | 0788      | B700 | 0010 | 0401 | 0002 | 0003 | 00A0 |  |

| Main Memory |      |      |      |      |      |      |      |      |
|-------------|------|------|------|------|------|------|------|------|
| 00:         | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| 08:         | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| 10:         | 9222 | 9120 | 1121 | A120 | 1121 | A121 | 7211 | 0000 |
| 18:         | 0000 | 0001 | 0002 | 0003 | 0004 | 0005 | 0006 | 0007 |
| 20:         | 0008 | 0009 | 000A | 000B | 000C | 000D | 000E | 000F |
| 28:         | 0000 | 0000 | 0000 | FE10 | FACE | CAFE | ACED | CEDE |
|             |      |      |      |      |      |      |      |      |
|             |      |      |      |      |      |      |      |      |
| E8:         | 1234 | 5678 | 9ABC | DEF0 | 0000 | 0000 | F00D | 0000 |
| F0:         | 0000 | 0000 | EEEE | 1111 | EEEE | 1111 | 0000 | 0000 |
|             |      |      |      |      |      |      |      |      |

B1B2 F1F5 0000 0000 0000 0000 0000 0000



# Specific Instance: MIPS Instruction Set

MIPS – SGI Workstations, Nintendo, Sony...

#### State:

- 32-bit addresses to memory (32-bit PC)
- 32 32-bit Registers
- A "word" is 32-bits on MIPS
- Register \$0 (\$zero) always has the value 0
- By convention, certain registers are used for certain things more next time...

# A Note on Notation...

- Assembly syntax is somewhat arbitrary
- Equivalent "Add" Instructions

```
• add r1, r2, r3
```

• add 
$$r1 = r2, r3$$

• 
$$r1 = r2 + r3$$

• add 
$$r1 = r2 + r3$$

• ..

• Equivalent "Store Word" Instructions

```
• sw $1, 10($2)
```

• 
$$M[r2 + 10] = r1$$

• st.w 
$$M[r2 + 10] = r1$$

• ..

42

# MIPS Usage in Course

- Used throughout book
- We will use it on homework and exams
- For clarity of lecture, MIPS not always used
- Refer to book for all instructions discussed

43

# Specific Instance: MIPS Instruction Set

# Some Arithmetic Instructions:

- Add:
  - Assembly Format: add <dest>, <src1>, <src2>
  - Example: add \$1, \$2, \$3
  - Example Meaning: r1 = r2 + r3
- Subtract:
  - Same as add, except "sub" instead of "add"

# Specific Instance: MIPS Instruction Set

#### Some Branch Instructions:

- Branch Equal:
  - Assembly Format: beq <src1>, <src2>, <target immediate>
  - Example: beq \$1, \$2, 100
  - Example Meaning: branch r1 == r2, 100
    - If r1 is equal to r2, PC = 100
- Branch Not Equal: Same except beq -> bne
- Jump:
  - Assembly Format: j <target immediate>
  - Example: j 100
  - Example Meaning: jump 100

$$PC = 100$$

# Specific Instance: MIPS Instruction Set

#### Some Memory Instructions:

- Load Word:
  - Assembly Format: lw <dest>, <offset immediate> (<src1>)
  - Example: lw \$1, 100 (\$2)
  - Example Meaning: r1 = M[r2 + 100]
- Store Word:
  - Assembly Format: sw <src1>, <offset immediate> (<src2>)
  - Example: sw \$1, 100 (\$2)
  - Example Meaning: M[r2 + 100] = r1

#### How are MIPS Instructions Encoded?



# MIPS Encodings

# 32-bits/Instruction

|    | 6 bits | 5 bits | 5 bits | 5 bits              | 5 bits | 6 bits |
|----|--------|--------|--------|---------------------|--------|--------|
| R: | op     | rs     | rt     | rd                  | shamt  | funct  |
|    |        |        |        |                     |        |        |
| I: | op     | rs     | rt     | address / immediate |        |        |
|    |        |        |        |                     |        |        |
| J: | op     |        | t      | arget addre         | ess    |        |

op: basic operation of the instruction (opcode)

rs: first source operand register rt: second source operand register rd: destination operand register

shamt: shift amount

funct: selects the specific variant of the opcode (function code)

address: offset for load/store instructions (+/-215) immediate: constants for immediate instructions

# MIPS Add Instruction Encoding



# MIPS Add Instruction Encoding



# Add and Subtract

A little foreshadowing...





# **Memory Addressing**

| ^ |                |
|---|----------------|
| 0 | 8 bits of data |
| 1 | 8 bits of data |
| 2 | 8 bits of data |
| 3 | 8 bits of data |
| 4 | 8 bits of data |
| 5 | 8 bits of data |
| 6 | 8 bits of data |

View memory as a single-dimensional array

Since 1980: Elements of array are 8-bits

We say "byte addressable"

Assuming 32-bit words:

1. How are bytes laid out in word read?

2. Can a word start at any address?

# **Memory Organization**

- Bytes are nice, but most data items use larger "words"
- For MIPS, a word is 32 bits or 4 bytes.

| 0       | 32 bits of data |
|---------|-----------------|
| 4       | 32 bits of data |
| 8       | 32 bits of data |
| 12      | 32 bits of data |
| 8<br>12 |                 |

Registers hold 32 bits of data

2<sup>32</sup> bytes with byte addresses from 0 to 2<sup>32</sup>-1

2<sup>30</sup> words with byte addresses 0, 4, 8, ... 2<sup>32</sup>-4

Words are aligned

i.e., what are the least 2 significant bits of a word address?

# Addressing Modes

| Addressing mod     | le Example        | <u>Meaning</u>                  |
|--------------------|-------------------|---------------------------------|
| Register           | Add R4,R3         | R4← R4+R3                       |
| Immediate          | Add R4,#3         | R4 ← R4+3                       |
| Displacement       | Add R4,100(R1)    | R4 ← R4+Mem[100+R1]             |
| Register indirect  | Add R4,(R1)       | R4 ← R4+Mem[R1]                 |
| Indexed / Base     | Add R3,(R1+R2)    | R3 ← R3+Mem[R1+R2]              |
| Direct or absolute | Add R1,(1001)     | R1 ← R1+Mem[1001]               |
| Memory indirect    | Add R1,@(R3)      | $R1 \leftarrow R1+Mem[Mem[R3]]$ |
| Auto-increment     | Add R1,(R2)+      | R1 ← R1+Mem[R2]; R2 ← R2+d      |
| Auto-decrement     | Add R1,-(R2)      | R2 ← R2-d; R1 ← R1+Mem[R2]      |
| Scaled A           | dd R1,100(R2)[R3] | R1 ← R1+Mem[100+R2+R3*d]        |

#### Hello World

#### The Hello World Algorithm:

- 1. Emit "Hello World"
- 2. Terminate

```
/*
 * Good programs have meaningful comments
 */
#include <stdio.h>

int main()
{
   printf("Hello World!\n");
   return 0;
}
```

#### Hello World

```
IA-64 Assembly Language
                   "hello.c
         .file
         .pred.safe_across_calls p1-p5,p16-p63
.section .rodata.str1.8,"ams",@progbits,1
         .align 8
 .LC0:
         stringz "Hello World!\n"
 text
         .global main#
         .proc main#
main:
         .prologue 12, 33
         .save ar.pfs, r34
         alloc r34 = ar.pfs, 0, 3, 1, 0
         add1 r35 = @ltoff(.Lc0), gp
         .save rp, r33
mov r33 = b0
        ;;
.body
ld8 r35 = [r35]
--11.sptk.ma
         br.call.sptk.many b0 = printf#
         mov r8 = r0
         mov ar.pfs = r34
         mov b0 = r33
         br.ret.sptk.many b0
         .endp main#
          ident "GCC: (GNU) 2.96 20000731 (Red Hat Linux 7.2 2.96-112.7.2)"
```

# Hello World



# Interfaces in Computer Systems



#### Control

# (from the back of a napkin)



#### The Instruction Set Architecture

"The vocabulary of commands"

- Defined by the Architecture (x86)
- Implemented by the Machine (Pentium 4, 3.06 GHz)
- An Abstraction Layer: The Hardware/Software Interface
- Architecture has longevity over implementation
- Example:

add 
$$r1 = r2 + r3$$
 (assembly)

001 001 010 011 (binary)

Opcode (verb) Operands (nouns)

#### The Hardware/Software Interface



# Some Figure and Text Acknowledgements

- Dan Connors
- David Patterson
- The COS126 Team (Wayne, Sedgewick)
- A. Mason
- Intel Corporation
- Amazon.com
- www.uiuc.edu