

## UNIT-1:-

### ASCII encoding System:-

ASCII - American Standard Code for Information Interchange.

Each character in the program written by programmer is encoded into Binary format using ASCII encoding system.

0 - 48

A - ~~48~~ 65

a - 97

### Compilation process:-

#### 1. Preprocessing step:-

[CPP file.c > file.i]

In preprocessing step, the contents of system header file are directly inserted into program text and creates a .i file.

Eg:- #include <stdio.h> // stdio.i

#### 2. Compilation step:-

[gcc -c -S file.i]

In compilation step, <sup>compiler converts</sup> source code is converted into Assembly code and creates a .S file.

### 3. Assembly phase:-

as file.s -o file.o  
Disassembly → objdump -d file.o

In Assembly phase, assembler converts assembly language into machine language and creates a .o file.

### 4. Linking phase:-

ld (locations of ) -o filename  
Runtime libraries

In linking phase, the linker links required Run-time libraries with .o file and forms an executable file.

## Hardware Organisation of a System:-

### i. PSU :- (Power Supply Unit).

It is a hardware component of computer supplies optimal power to all internal components of computer.

### ii. FAN :-

Basically, fan is used in computer for active cooling. Fans expels hot air from inside ~~area~~ increase the So that every component is efficient enough.



### iii. Hard drive :-

Hard drive is non-volatile data storage device.

### iv. CPU :- (Central-Processing unit).

CPU performs all arithmetic, logical and input/output (i/o) operations.

Both are  
storage  
devices

### v. RAM

(Random access memory)

→ RAM is volatile memory and its speed is quite high.

→ Data is present till power is supplied.

### ROM

(Read only memory)

→ ROM is non-volatile

memory and speed is slower than

RAM.

→ Data remains even after power is not supplied.

### vi. Buses :-

Buses are designed to transfer a chunk of bytes of data known as words b/w i/o devices.

size of word → 4 bytes (32-bit) (or)

8 bytes (64-bit).

### vii. Mother board:-

→ The main printed circuit board where all components are plug in is called as 'mother board'.

→ It defines the computer's limits of speed, expandability and memory.

### Cache memory:-

→ Cache memory is located in b/w main memory and CPU.

→ The contents of main memory that are frequently used by CPU are stored in cache memory so that processor can access the data in shorter time.

→ Cache memory is the fastest component in memory hierarchy.

### Memory hierarchy:-



### Threads :-

Threads are ~~has~~ virtual components which divides physical core of CPU into virtual multiple cores.

Multi-threading is one way to make programs run faster when multi-core processor is available.

### Virtual memory :-

→ Virtual memory creates an illusion having a very big memory. This is done by treating some part of secondary memory as the main memory.

→ Due to virtual memory, the degree of multi-programming will be increased so that CPU utilization will be increased.

### Network :-

Two or more computers ~~to~~ are connected each other for the purpose of communication is known as network.

Network adapter connects a system to a network.

## MEASURING PERFORMANCE:-

Computer performance : Time :-

- Response / Elapsed Time :-

→ Individual user concern.

→ It is time taken to run an application written by user.

- Throughput :-

→ System manager concern.

→ It is time taken that how many applications can the machine run at once in parallel.

Definition of Performance :-

$$\text{Performance} = \frac{1}{\text{Execution Time}}$$

Suppose, 'X' is n-times faster than 'Y'.

$$(\text{Performance})_X = n \times (\text{Performance})_Y$$

Clock cycle :-  $\frac{1}{(\text{Cycle time})}$ .

Clock cycle is the time interval b/w two clock ticks in a processor.

Cycle time  $\Rightarrow$  sec/cycle.

Clock rate (freq.): cycles / sec. (or) Hz.

Performance Equation 1 :-

$$\text{CPU time} = \frac{\text{CPU clock cycles}}{\text{cycles/program}} \times \frac{\text{Clock cycle time}}{\text{secs/cycles}}$$

Performance Equation 2 :-

$$\text{CPU time} = \text{IC} \times \text{CPI} \times (\text{clock cycle time})$$

IC  $\Rightarrow$  Instruction count.

CPI  $\Rightarrow$  Clock cycles per instruction. (Avg.)

AMDAHL'S LAW: (Overall Performance gained)

It states that the performance gained from ~~not~~ using some faster mode of execution is limited by the fraction of time.

$$\text{Speed up} = \frac{\text{improved performance}}{\text{old performance.}}$$

$$\text{Execution time after improvement} = \frac{\text{Execution time affected by improvement}}{\text{Amount of improvement}}$$

$$+ \text{Execution time unaffected}$$

Eg:- 75%  $\Rightarrow$  integer operations

25%  $\Rightarrow$  floating pt. operations.  $\Rightarrow$  2x faster.

Overall =  $(\text{Execution time})_{\text{old}}$

Speed up  $\frac{(\text{Execution time})_{\text{new}}}{1}$

=

$$(1 - \frac{\text{fraction}_{\text{enhanced}}}{\text{enhanced}}) + \frac{(\text{fraction})_{\text{enhanced}}}{(\text{Speed up})_{\text{enhanced}}}$$



## UNIT-2 :-

## Encoding byte values:-

$$\underline{1 \text{ Byte} = 8 \text{ bits}}$$

Binary : 0000 0000 to 1111 1111

Hex : 00 to FF

Dec. : 10 to 1955.

## Byte - Oriented Memory Organisation:-

In memory, each block is a byte and has a unique address.

Word-size :-

4 bytes for 32-bit system.

8 bytes for 64-bit system.

## Word - Oriented Memory Organisation :-

|  |      |      |  |      |
|--|------|------|--|------|
|  | 0000 |      |  | 0000 |
|  |      | 0000 |  | 0001 |
|  |      |      |  | 0002 |
|  |      |      |  | 0003 |
|  | 0004 |      |  | 0004 |
|  |      |      |  | 0005 |
|  |      |      |  | 0006 |
|  |      |      |  | 0007 |
|  | 0008 |      |  | 0008 |
|  |      | 0008 |  | 0009 |
|  |      |      |  | 0010 |
|  |      |      |  | 0011 |
|  | 0012 |      |  | 0012 |
|  |      |      |  | 0013 |
|  |      |      |  | 0014 |
|  |      |      |  | 0015 |

### Byte Ordering :-

Eg:- 0x01234567

|            |                     |
|------------|---------------------|
| Big-Endian | Little-Endian (x86) |
| 01234567   | 76543210.           |

→ Strings are not effected by endian forms.

Eg:- char s[6] = "123456";

For this, both endian forms are same  
i.e., Big endian.

### Bit-level Operators :-

& - Bitwise AND

| - Bitwise OR

~ - Bitwise NOT

^ - Bitwise XOR.

### Logical Operators:-

&& - AND

|| - OR

! - NOT

$p \&\& *p \Rightarrow$  avoid Null pointer access

(Segmentation fault is)  
avoided.

Suppose,  $(p \&\& *p) \Rightarrow F.$

↑  
null

(F)

This statement is avoided.

## Shift Operations:-

### Logical left shift :- <<1



### Logical right shift :- >>1



### Arithmetic left shift :- <<1



Arithmetic left shift = Logical left shift

Eg:-  $x \ll 3 \Rightarrow x = x * 2^3$

### Arithmetic right shift :- >>1



Eg:-  $x \gg 3 \Rightarrow x = x / 2^3$

Encoding integers :-Unsigned

$$B_{2U} = \sum_{i=0}^{w-1} x_i \cdot 2^i$$

Signed (2's complement)

$$B_{2S} = -x_{w-1} \cdot 2^{w-1} + \sum_{i=0}^{w-2} x_i \cdot 2^i$$

MSB  $\Rightarrow$  sign bit0  $\Rightarrow$  non-negative1  $\Rightarrow$  negative.Ranges :-Unsigned32-bit  $\Rightarrow$  0 to  $2^{32}-1$ Signed-2<sup>31</sup> to  $2^{31}-1$ 

$U_{min} = 0$

$T_{min} = -2^{31}$

$U_{max} = 2^{32}-1$

$T_{max} = 2^{31}-1$

Conversion & Visualisation :-

## Conversion Visualisation :-



Note:- 2's complement Signed integers.

Non-negative Signed no.s have same  
unsigned and signed representation.

Some specific no.s:-

0 : 0000 0000 ---- 0000

-1 : 1111 1111 ---- 1111

Most negative : 1000 0000 ---- 0000

Most positive : 0111 1111 ---- 1111.

2's complement = 1's complement + 1.

## Casting :-

~~int x,y;~~

~~unsigned a,b;~~

int s1,s2;

unsigned u1,u2;

s1 = (int)u1;

u2 = (unsigned)s2;

## Floating Point :-

$$1011.101_2 \rightarrow 1 \times 2^3 + 0 \times 2^2 + 1 \times 2 + 1 \times 2^0 + 0 \times \frac{1}{2} + 0 \times \frac{1}{2^2} + 1 \times \frac{1}{2^3}$$

$$\Rightarrow 8 + 2 + 1. \quad | \quad + \frac{1}{2} + \frac{1}{8}$$

$$\Rightarrow 11.125$$

Binary to Floating pt. :-

$$1011.101_2 \rightarrow 1 \times 2^3 + 0 \times 2^2 + 1 \times 2 + 1 \times 2^0 + 1 \times \frac{1}{2} + 0 \times \frac{1}{2^2} + 1 \times \frac{1}{2^3}$$

$$\Rightarrow 8 + 2 + 1 + \frac{1}{2} + \frac{1}{8}$$

$$\Rightarrow 11 + 5 \quad | \quad \frac{88+5}{8} \Rightarrow \frac{93}{8} \Rightarrow 11.625$$

Decimal

$\Rightarrow 11.625$

Floating pt. to Binary.

$$11.625 \rightarrow 1011.101$$

$$1011.101$$

$$0.625 \times 2 = \underline{\underline{1.25}} \Rightarrow ①$$

$$0.25 \times 2 = 0.5 \Rightarrow ①$$

$$0.5 \times 2 = 1.0 \Rightarrow ①$$

IEEE Floating point :- (Institute of Electrical  
and Electronic Engineers)

Normalised form :-

- Integer part should be zero.
- ~~0.~~ 1.  $d_1 d_2 d_3 \dots$

Single Precision :- (32-bit)

1      8      23



$$X_{FP32} = (-1)^S \times (2)^{e-127} (1.m)$$

Double Precision :- (64-bit)

1      11      52



$$X_{FP64} = (-1)^S \times (2)^{e-1023} (1.m)$$

| e   | m.       |                                     |
|-----|----------|-------------------------------------|
| 255 | 0        | NaN                                 |
| 255 | $\neq 0$ | Infinite no.                        |
| 0   | 0        | $X = (-1)^S \cdot (2)^{-126} (0.m)$ |
| 0   | $\neq 0$ | $+0, -0$                            |

Q) IEEE format to decimal equivalent

Decimal to IEEE format

Eq:-  $404\ 000000H \Rightarrow$  Decimal equivalent of given floating pt. no.

so!  $0|00\ 0000\ 0|00\ 0000\ ..... 0000$

S e m.

$$1 \times 2^{-1} = 0.5$$

$$X_{FP32} = (-1)^s \times (2)^{e-127} \times (1.m)$$

$$=(-1)^0 \times (2)^{128-127} \times (1.5)$$

$$= 1.5 \times 2$$

$$= 3.$$

Eq:- Represent following 4 floating point no.s in single precision format?

|                                | s | e        | m.         |
|--------------------------------|---|----------|------------|
| $0.110111 \times 2^{100101}$   | 0 | 10100101 | 1011100... |
| $0.110111 \times 2^{-100101}$  | 0 | 01011001 | 1011100... |
| $-0.110111 \times 2^{100101}$  | 1 | 10100101 | 1011100... |
| $-0.110111 \times 2^{-100101}$ | 1 | 01011001 | 1011100... |

|              |              |
|--------------|--------------|
| $0010\ 0101$ | $00100101$   |
| $1000\ 0000$ | $1101\ 1000$ |
| $1010\ 0101$ | $+ 1$        |
|              | $1101\ 1001$ |
|              | $1000\ 0000$ |
|              | $0101\ 1001$ |
|              | $\times$     |



Floating point Addition:-

$$1.000 \times 2^{-1} + -1.110 \times 2^{-2}$$

convert smaller

exp to bigger exp  $\rightarrow 1.000 \times 2^{-1} - 0.111 \times 2^{-1}$

$$\begin{array}{r} 1.000 \\ - 0.111 \\ \hline 0.001 \end{array}$$

$$\rightarrow (1.000 - 0.111) \times 2^{-1}$$

$$\rightarrow 0.001 \times 2^{-1}$$

$$\rightarrow 1.000 \times 2^{-4}$$

Floating point multiplication:-

$$1.000 \times 2^{-1} \times -1.110 \times 2^{-2}$$

Ans

$$\rightarrow 1.000 \times (-1.110) \times 2^{-3}$$

$$\begin{array}{r} 1.11 \\ \times 1 \\ \hline 1.11 \end{array}$$

$$\rightarrow -1.110 \times 2^{-3}$$

## UNIT-3 :- Machine Language :-

Q) What is x86?

- X86 is a processor developed based on 8086 microprocessor and its 8088 variant.
- The term "x86" came because several processors like 8086, 80186, 80286, 80386, 80486 has "86" in end.

Q) CISC, RISC?

Complex Instruction Set Computers:

It has a collection of complex instructions and takes long time to execute those instructions.

Reduced Instruction Set Computers:

It has a collection of simple instructions and takes less time to execute those instructions.

Q) Moore's law:-

No. of transistors per chip are doubled every year. 18 months.

Q) Instruction Set Architecture :-

It is a very important abstraction b/w hardware and low-level software. (Machine language Eg:- X86, Pentium, MIPS, ...  
(or)  
Binary)

## Q) Program Counter (PC):

Stores the address of next instruction.

$\%rip \Rightarrow PC$ .

## ASSEMBLY LANGUAGE:-

### Q) Datatypes:-

char  $\Rightarrow$  Byte (b) - 1 byte.

short  $\Rightarrow$  Word (w) - 2 bytes.

int  $\Rightarrow$  Double word (d) - 4 bytes.

char\*, long  $\Rightarrow$  Quad word (q) - 8 bytes.

float  $\Rightarrow$  4 bytes.

double  $\Rightarrow$  d. - 8 bytes.

### Q) Registers:-

Registers are used to store the data.

|               | 8 bytes (l,q) | 4 bytes (int) | 2 bytes (w) | 1 byte (b) |
|---------------|---------------|---------------|-------------|------------|
| return value  | $\%rax$       | $\%eax$       | $\%ax$      | $\%al$     |
|               | $\%rbx$       | $\%ebx$       | $\%bx$      | $\%bl$     |
|               | $\%rcx$       | $\%ecx$       | $\%cx$      | $\%cl$     |
| params        | $\%rdx$       | $\%edx$       | $\%dx$      | $\%dl$     |
|               | $\%rsi$       | $\%esi$       | $\%si$      | $\%sil$    |
|               | $\%rdi$       | $\%edi$       | $\%di$      | $\%dil$    |
|               | $\%rbp$       | $\%ebp$       | $\%bp$      | $\%bp$     |
| Stack pointer | $\%rsp$       | $\%esp$       | $\%sp$      | $\%spl$    |

|      |       |       |       |
|------|-------|-------|-------|
| %r8  | %r8d  | %r8w  | %r8b  |
| %r9  | %r9d  | %r9w  | %r9b  |
| %r10 | %r10d | %r10w | %r10b |
| %r11 | %r11d | %r11w | %r11b |
| %r12 | %r12d | %r12w | %r12b |
| %r13 | %r13d | %r13w | %r13b |
| %r14 | %r14d | %r14w | %r14b |
| %r15 | %r15d | %r15w | %r15b |

## a) Addressing modes:-

Addressing modes are used to access data stored in registers.

### 1. Immediate Addressing mode:-

Eg:- \$Imm ; \$108

### 2. Register Addressing mode:-

Eg:- %rax, %rbx.

### 3. Absolute Addressing mode:-

Eg/ (0x104)/0x108

Eg:- 0x104, 0x108.

### 4. Indirect Addressing mode:-

Eg:- (%rax).

### 5. Base + displacement Addressing mode:-

Eg:- 4(%rax)  $\Rightarrow$  4 + (%rax)

### 6. Indexed Addressing mode:-

Eg:- (%rax, %rbx).  $\Rightarrow$  (%rax) + (%rbx)

### 7. Indexed Addressing mode:-

Eg:- 9(%rax, %rbx)  $\Rightarrow$  9 + (%rax) + (%rbx)

8. Scale index Addressing mode:-

Eg:-  $C, \%rax, 4) \Rightarrow 4(\%rax)$

9. Scale index Addressing mode:-

Eg:-  $0x0FC C, \%rcx; 4) \Rightarrow FCh + 4(\%rcx)$

10. Scale index Addressing mode:-

Eg:-  $(\%rbx, \%rax; 5) \Rightarrow (\%rbx) + 5(\%rax)$

11. Scale index Addressing mode:-

Eg:-  $0x5 (\%rbx, \%rax, 6) \Rightarrow 5h + (\%rbx)$   
 $+ 6(\%rax)$ .

### Q) Moving data:-

`movq src, dest`

Eg:-

`movq $0x4, (%rax)` ✓

`movq $0x4, %rax.` ✓

`movq %rax, %rbx` ✓

`movq %rax, (%rbx)` ✓

`movq (%rax), %rbx` ✓

`movq (%rax), (%rbx)` X

Note:-

`movabsq` ⇒ unsigned values.

`movq` ⇒ signed or unsigned values.

`movzbaw` ⇒ zero extension from byte to word.

(1 byte to 2 bytes).

AF → 00AF.

0000 0000 AF

Zero extension.

`movsbw`  $\Rightarrow$  sign extension from byte to word.

Eg:- `move $`

`movsbw $1, %al`  $\Rightarrow$  00 01

`movsbw $-1, %al`  $\Rightarrow$  FF FF

`cldq`  $\Rightarrow$  sign extension from %eax to %rax.

### Q) Stack:-

`pushq S`

`popq D`

### Q) Address Computation Instruction:-

`leaq S, D`  $\Rightarrow$  D = In & S.

D  $\Rightarrow$  register

S  $\Rightarrow$  address.

### Q) One Operand Operations

`incq D`  $\Rightarrow$  D++

`decq D`  $\Rightarrow$  D--

`negq D`  $\Rightarrow$  2's complement

`notq D`  $\Rightarrow$  1's complement

### Q) Arithmetic Operations:-

addq, S,D  $\Rightarrow D = S + C.$

subq, S,D  $\Rightarrow D = D - S.$

imulq, S,D  $\Rightarrow D = D * S.$

### Q) Shift Operations:-

salq, S,D  $\Rightarrow D = D \ll S.$

sarq, S,D  $\Rightarrow D = D \gg S \oplus 1$

s.hdq, S,D  $\Rightarrow D = D \ll S.$

shrq, S,D  $\Rightarrow D = D \gg S.$

### Bitwise

### Q) Logical Operations:-

xorq, S,D  $\Rightarrow D = D \wedge S.$

andq, S,D  $\Rightarrow D = D \& S$

orq, S,D  $\Rightarrow D = D \mid S.$



Q) Logical shifts:-

left logical shift :-  $\ll 1$



Right logical shift :-  $\gg 1$



Q) Arithmetic shifts:-

Arithmetic left shift :-  $\ll 1$



Arithmetic right shift :-  $\gg 1$



Eg:-

$$1) x \ll 2, \Rightarrow x = x * 2^2.$$

$$2) x \gg 2 \Rightarrow x = x / 2^2.$$

Note:- Arithmetic left shift and logical left shift operations are same.

## Q) Special Arithmetic Operations:-

~~imulq~~

~~S~~  $\Rightarrow$

~~mulq~~

~~S~~  $\Rightarrow$

~~idivq~~

~~S~~  $\Rightarrow$

~~divq~~

~~S~~  $\Rightarrow$

64-bit  $\Rightarrow$  imulq S  $\Rightarrow$   $[\%rdx]:[\%rax] \leftarrow S * [\%rax]$

mul

mulq S  $\Rightarrow$   $[\%rdx]:[\%rax] \leftarrow S * [\%rax]$

idivq S  $\Rightarrow$   $[\%rdx]:[\%rax]$  / S

$[\%rax] \leftarrow$  Quotient

$[\%rdx] \leftarrow$  Remainder

divq S  $\Rightarrow$   $[\%rdx]:[\%rax]$  / S

$[\%rax] \leftarrow$  Quotient

$[\%rdx] \leftarrow$  Remainder