#### Assembly Arithmetic and Logic

Monday, October 19, 2020 12:40 PM

| Data Sizes     |         |   |
|----------------|---------|---|
| Byte I byte    |         | b |
| Word 2 byte    | ىك.     | W |
| Double (dword) | 4 bytes | l |
| Quad (qword)   | 8 bytes | 9 |

## Register Sizes

Larger registers contain smaller registers
(b/c backwards companiously)

Some registers have special responsibilities

#### mov variants

>> Can take optional suffix for cize of data to move movb, movw, movl, movg

> Only up dates specific bytes, except for most which o's

—) Move small to large - mov z fills w/ 0's

movs sign-extends mass

sic mem or register,

dst register

### the lea instruction

lea- Load Effective Address

Copies value of Src to dst Con men addr involved)

Ex. Oy mor lea Copy 6+(1'rax val)
at src to det to .1'relx

# Unary instructions

Operate on single operand (register or nemony)

Can take suffix like nov

inc D D  $\leftarrow$  D+1 incre nem

dec D D  $\leftarrow$  D-1 decrement

leg D D  $\leftarrow$  -D regate

not D D  $\leftarrow$  NP conplement

# Binary instructions

Operate on two operants (register, rumory),

Con take suffix like now

inul on 64-Lit operants will truncate to 64-Lits
inul who one operant will multiply by , l'rax and
put high-order 64-Lits in , l'rdx and low in , l'rax
mul on one operand—unsigned multiply

idive Signet divide ul nobulo dive

Can divide 128 bils by 64 bils  $D \leftarrow D << K \quad \text{left shift}$ Sal K,D  $D \leftarrow D << K \quad \text{left shift}$ ShI K,D  $D \leftarrow D >>_{A}K \quad \text{anthmehic rshift}$ Sar K,D  $D \leftarrow D >>_{L}K \quad \text{legical rshift}$ Shr K,D

K must be immediate, or value in . I'cl if not yeour