

## Different types of computers:-

Since their introduction in 1940s, digital computers are of different types that vary widely in size, cost, computational power and intended use.

Modern computers can be divided roughly into the following categories.

- \* Embedded computers
- \* Personal computers
- \* Servers and Enterprise systems
- \* Super computers and Grid computers

### Embedded Computers:-

- \* These are integrated into a large device or system in order to automatically monitor and control a physical process or environment.
- \* They are used for a specific purpose rather than for general tasking/ processing tasks.
- \* Typically applications includes industrial and home automation, appliances, tele communication products, and vehicles
- \* Users may not be even aware of the role that computers play in such "systems"

## Personal Computers:-

- \* Personal computers have achieved widespread use in homes, education and business and engineering office setting primarily for dedicated individual use.
- \* They support a variety of applications such as general computation, document preparation, computer aided design, audio visual entertainment, inter personal communication, internet browsing.
- \* A number of classifications are used for personal computers

### Desktop computers

### Workstation computers

### Portable and Notebook computers

- \* Desktop computers serve general needs and fit within a typical personal workspace
- \* Workstation computers offer higher computational capacity and more powerful graphical display capabilities for engineering and scientific work
- \* Portable and Notebook computers provide the basic features of a personal computer in a smaller light-weight package.
- \* They can operate on batteries to provide mobility.

## Servers and Enterprise systems:-

- \* Large computers that are meant to be shared by a potentially large numbers of users who access them from (e.g.) some form of personal computers over a public or private network.
- \* Such computers may host large databases and provide information processing for a government agency or a commercial organization.

## Supercomputers and Grid computers:-

- \* Normally offer the highest performance.
- \* They are the most expensive and physically the largest category of computers.
- \* Super computers are used for the highly demanding computations needed in weather forecasting, simulation, engineering design and scientific work.
- \* They have high cost.
- \* Grid computers provide most cost-effective alternative.
- \* They combine a large number of personal computers and disc storage units in a physically distributed high speed network, called a grid, which is called as a co-ordinating computing resource.
- \* By evenly distributing the computational workload across the grid, it is possible to achieve high performance on large applications ranging from numerical computation to information searching.

20/01/2021

## Functional units:-



- \* There must be interconnections for data transmission.

### Input unit:-

- \* Computers accept coded information through input units - the computer keyboard.
- \* Whenever a key is pressed, the corresponding letter or digit is automatically translated into its binary code and transmitted to processor.
- \* Some of the input units are: Touch pad, mouse, joystick, trackball, microphone, camera, internet.

### Memory unit:-

- \* Its function is to store programs and data.
- \* There are two classes of storage.

#### Primary storage :-

- \* It is called main memory.
- \* Programs must be stored in memory while they are being executed.
- \* Consists of large number of semiconductor storage cells - capable of storing one bit of information.

- \* They are handled in groups of fixed size called words
- \* The memory is organized so that one word can be stored or retrieved in one basic operation
- \* To provide easy access to any word in the memory, a distinct address is associated with each word location

A particular word is accessed by specifying its address and issuing a control command to the memory that starts the storage or retrieval process.

A memory in which any location can be accessed in a short and fixed amount of time after specifying its address is called a random access memory

The time required to access memory is memory access time.

22/01/20  
Memory hierarchy - cache, main memory

Registers → cache → main memory.



## Arithmetic & Logic Unit

- \* Most computer operations are executed in ALU in the processor.
- \* Load the operands into memory, bring them to the processor - perform operation in ALU, store the result back to memory or retain in the processor.
- \* Registers
- \* Fast control of ALU

Activity

- \* Activity in a computer is governed by instructions.
- \* To perform a task, an appropriate program consisting of a list of instructions is stored in the memory.
- \* Individual instructions are brought from the memory into the processor, which executes the specified operation.
- \* Data to be used as operands and also stored in the memory.

A Typical instruction:-

Add R0, LOCA

Add the operand at memory location LOCA to the operand in a register R0 in the processor.

Every processor has some special purpose and general purpose registers.

The notation to represent general purpose registers is

$R_0, R_1, R_2, \dots, R_n$

The special purpose registers are used to represent as MAR(memory address register), MDR(memory data register), PC(program counter), IR(instruction register) which are used for specific tasks.

2/10/2021

Number representations and arithmetic operations:-

Signed Integer:-

there're three major representations

Sign and magnitude

One's complement

Two's complement

\* In all three systems MSB position 0 for positive +1 for negative.

\* Positive values have identical representations in all the systems, but negative values have different representations.

Floating values:-

single precision: 32 bit

|     |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 30 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13       | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| exp |    |    |    |    |    |    |    |    |    |    |    | mantissa |    |    |    |   |   |   |   |   |   |   |   |   |   |

While storing floating point numbers, you have to normalize and store

$$\text{In Ex: } 1001100101 = 1.\underline{001100101} \text{ mantissa}$$

sign = 0 (positive)

exponent = 7

mantissa = 001100101

biased exponent =  $(7+128)_{10 \Rightarrow 2}$

Ex: 10011001.01

(64 bits - double precision)

(1, 11, 58)

sign = 0

exp = 7 + 1024

mantissa = 001100101

ASCII:-

a: 97, A: 965

Sign extension:-

short int x = 15213;

int ix = (int) x;

x = 15213 = 0011101101101101

ix = 15213 = 000000000000001110110110110110

y = -15213 = 1100010010010011

iy = -15213 = 111111111100010010010011

2's complement Addition and subtraction:-

Addition:

(+2) 0010

0100 (+4)

(+3) 0011

1010 (-6) [2's complement]

(+5) 0101

1110 (-2) [2's complement]

(-5) 1011

0111 (+7)

(-2) 1110

1101 (-3)

(-7) 0001

0100 (-4)

subtraction:

$$\begin{array}{r} 1101 (-3) \\ - 1001 (-1) \\ \hline 1101 \\ 0111 \\ \hline 0110 (+4) \end{array}$$

$$\begin{array}{r} 0010 (+2) \\ - 0100 (+4) \\ \hline 0010 \\ 1100 \\ \hline 1110 (-2) \text{ (complement)} \end{array}$$

$$\begin{array}{r} 1001 (+5) \\ - 0011 (-5) \\ \hline 1001 \\ 0101 \\ \hline 0110 (-2) \end{array}$$

$$\begin{array}{r} 1001 (-1) \\ - 0001 (+1) \\ \hline 1001 \\ 1111 \\ \hline 1000 (-8) \end{array}$$

If carry in to high order bit = carry out and ignore

If carry-in differs from carry-out, then overflow

\* Now consider a different representation of the mod-16 circle

We will reinterpret the binary vectors outside the circle to represent the signed integers from -8 through +7 in the 2's complement representation as shown inside the circle

Ex: Add +7 to -3

locate 0111 on circle, move 1101(13) steps in clockwise direction to arrive 0100(+7) which is correct answer

\* To understand 2's complement arithmetic, consider addition modulo N.

A helpful graphical device for the description of addition of unsigned integers mod N is a circle with the values

0 through  $N-1$  marked along its perimeter.

- \* The decimal values 0 through 15 are represented by their 4-bit binary values 0000 through 1111.
- \* To perform addition, locate a, and move b with clockwise to arrive at  $(a+b) \bmod 16$ .



### Memory

Memory locations, addresses and operations:-

- \* Memory is organised as a large array of bytes or words
- \* Word is a group of  $n$  bits, ' $n$ ' is word length
- \* Memory is represented as collection of words
- \* The word length range from 16 to 64 bits
- \* Accessing the memory requires address for each location.
- \* So, use numbers from 0 to  $2^n - 1$  to address the successive memory locations. Have up to  $2^n$  memory locations.

- \* Memory consists of many millions of storage cells each of which can store 1 bit
- \* Data is usually accessed in n-bit groups.

**Big-Endian and Little-Endian Assignments:-**

| Word address | Byte addresses |   |   |   | Word address | Byte addresses |   |   |
|--------------|----------------|---|---|---|--------------|----------------|---|---|
| 0            | 0              | 1 | 2 | 3 | 0            | 3              | 2 | 1 |
| 4            | 4              | 5 | 6 | 7 | 4            | 1              | 6 | 5 |

$2^{k-4}$     $2^{k-4}$     $2^{k-3}$     $2^{k-2}$     $2^{k-1}$     $2^{k-4}$     $2^{k-1}$     $2^{k-2}$     $2^{k-3}$     $2^{k-4}$

a) Big-Endian assignments  
b) Little-Endian assignments

**Memory Operation:-**

- Both program instruction and data are stored in memory.
- To execute any instruction the processor first takes the instruction from memory.
- The operands and results are also moved between memory and processor.
- Two basic operations are involved in memory.

→ Read Operation

→ To start the read operation the processor sends the address of the memory and a request that its contents to be read.

## Instruction and Instruction Sequencing:-

- Register Transfer notation
- Assembly language notation
- RISC and CISC instruction sets
- Introduction to RISC instruction sets
- Instruction execution and straight line sequencing
- Branching

## Must-Perform Operations:-

- A computer have instructions capable of performing + types of must operations
- Data transfers between the memory and the processor registers
- Arithmetic and logic operations on data
- Program sequencing and control
- I/O transfers.

## Register Transfer notations:-

- We will see the transformation from one location in a computer to the other? Possible locations are memory locations, processor registers, registers in I/O sub systems
  - such locations are assigned with convenient names
  - Eg. LOC, PLACE, A, VAR11 etc
- Predefined names for processor registers may be R0, R1, R2, R3  
→ contents of any location are represented with square brackets

→ Identify a location by a symbolic name standing for its hardware binary address (LOC, RO...)

→ contents of a location are denoted by placing square brackets around the name of the location

$$(R1 \leftarrow [LOC], R3 \leftarrow [R1] + [R2])$$

→ instruction specifies an operation to be performed and the operands involved.

→ In assembly language ADD, Move, Load etc are called mnemonics

→ Mnemonics are the words that describes operations.

Assembly language notation:-

• Represent machine instructions and programs

• Move LOC, RI

$$RI = RI \leftarrow [LOC]$$

• Add R<sub>1</sub>, R<sub>2</sub>, R<sub>3</sub>

$$R_3 = R_3 \leftarrow [R_1] + [R_2]$$

→ To initiate write

→ The processor sends the address of desired location

to the memory along with the data to be written into the location

→ Memory uses the address and data to perform a write

→ store (or Write)

→ Overwrite the content in memory

## RISC and CISC Instruction sets:-

- One of the most important characteristics that distinguish different computers is the nature of their instructions.
- There are two fundamentally different approaches in the design of instruction sets for modern computers.

### Key characteristics of RISC instruction sets:-

- Each instruction fits in a single word.
- A load/store architecture is used, in which memory operands are accessed only using load and store instructions.
  - All operands involved in an arithmetic or logic operation must either be in processor registers, or one of the operands may be given explicitly within the instruction word.

Eg:-  $C = A + B$

load R2, A

load R3, B

Add, R4, R2, R3

store R4, C

RISC: Reduced Instruction set Computer.

CISC: Complex Instruction set computer

## RISC Characteristics:-

- \* Relatively few instructions
- \* Relatively few addressing modes
- \* More accessors are limited to load and store instructions
- \* All operations are done with the registers of CPU
- \* It is designed to reduce the execution time by simplifying the instruction computer.
- \* Each instruction is encoded with fixed length.
- \* Program Counter (PC) always holds the address of the next instruction to be executed
- \* The address is copied to MAR (bus) through buses
- \* The Instruction is copied to IR from memory
- \* which is called fetching (Fetch phase)
- \* Once the instruction is fetched, enters into the execution phase and starts decoding in which, the what the instruction is, operands etc.
- \* If any operands are present, the registers load the operands by get operands and loaded into MDR
- \* Then the execution starts, one after the other sequencing so our instruction execution is straight-line sequencing

- \* Execution of a given instruction is a two-phase procedure
- \* In the first phase, called instruction fetch; the instruction is fetched from the memory location whose address is in PC
- \* This instruction is placed in instruction Register (IR), the processor.
- \* At the start of the second phase, called instruction execute, the instruction in IR is examined to determine which operation is to be performed.
- \* The specified operation is then performed by the processor.
- \* This involves a small number of steps such as fetching operands from the memory or from processor registers, performing an arithmetic or logic operation, and storing the result in the destination location.
- \* Let us consider how this program is executed
- \* The <sup>processor</sup> contains a register called program counter which holds the address of the next instruction to be executed
- \* To begin executing a program, the address of its first instruction must be placed into the PC
- \* The processor control circuits use the information in the PC to fetch and execute instructions, one at a time, in order of increasing addresses
- \* This is called straight-line sequencing. During execution, the PC is incremented by 4 to point to the next instruction

06/09/2021

## Register Indirect Addressing mode:-

Register name is specified as part of the instruction. That register contains the address of the operand in the memory. i.e., the registers contains the address of the operand other than the operand.

Load R2, (R3)

## Branch constructions:-

- We now introduce branch instructions. This type of instruction loads a new address into the program counter.
- As a result, the processor fetches and executes the instruction at this new address, called the branch target instead of the one in sequence.
- A conditional branch instruction causes a branch only if a specified condition is satisfied.
- If the condition is not satisfied, the PC is incremented in the normal way, and the next instruction in sequential address order is fetched and executed.

Branch-if-[R2] > 0 LOOP

- One way of implementing conditional branch instructions is to compare the contents of two registers and then branch to the target instruction if the comparison meets the specified

Branch-if-[R4] > [R5] LOOP

Branch-greater-than R4, R5 LOOP

BGT R4, R5, LOOP

## Addressing modes:-

- The way in which memory operand is addressed is called Addressing mode.
- The term addressing modes refers to the way in which the operand of an instruction is specified.

## RISC-type addressing modes:-

| Name              | Assembler syntax | Addressing function     |
|-------------------|------------------|-------------------------|
| Immediate         | #Value           | Operand = value         |
| Register          | Ri               | EA = Ri                 |
| Absolute          | loc              | Effective Address = loc |
| Register indirect | (Ri)             | EA = [Ri]               |
| Index             | x(Ri)            | EA = [Ri] + x           |
| Base with index   | (Ri, Rj)         | EA = [Ri] + [Rj]        |

### Immediate mode:-

Actual data is specified as part of the instruction i.e., instruction as an operand field rather than as address field. The operand field contains the actual operand.

ADD R4, R6, #200

### Register Mode:-

Register mode is specified as part of the instruction i.e., register contains actual data i.e., operands are in registers.

ADD R4, R2, R3

Absolute mode (or) Direct addressing mode:-  
Memory address is specified as a part of the instruction, this memory location contains the actual value i.e; the operand resides in the memory and its address is specified in the address field of the instruction.

load R2, Num.

Subtopic

Indirect addressing:-

The address field of the instruction specifies the address of memory location that contains the effective address of the operand. Two references to text memory are required to fetch the operand

ADD R1, (A)

Register Indirect addressing mode:-

Register name is specified as part of the instruction. That register contains the address of the operand in the memory. i.e; The register contains the address of the operand rather than the operand

Load R2, (R3)

Relative Addressing mode:-

In this, effective address of the operand is obtained by adding the content of PC with address part of the instruction

$$EA = X + (PC)$$

## Indexed Addressing mode:-

- Effective operand is given by..

$$EA = x + [R_i]$$

- In this addressing mode the content of the given register

Load R<sub>2</sub>, 20(R<sub>5</sub>)



## Base with index:-

- Effective address is the sum of the contents of registers R<sub>i</sub> and R<sub>j</sub>
- Second register is called base register

ADD R<sub>2</sub>, [R<sub>i</sub>+R<sub>j</sub>]

## Auto increment and auto decrement:-

- The EA of operand is the contents of a register specified in the instruction.
- After accessing the operand, contents of this register is automatically incremented by 1

Add R<sub>i</sub>, (R<sub>2</sub>)<sup>+</sup>

## Stacks:-

- A stack is a list of data elements, or words.
- LIFO
- Push, Pop, Top
- It is storage structure that stores information in the format of LIFO
- It is a group of memory locations with the register that holds the address of the top of the element
- The register that holds the address of the top element of the stack is called stack pointer (SP)
- Stack can be implemented in two ways
  - memory stack
  - register stack
- Memory stack: code segment, Data segment:

Push:  $SP \leftarrow SP - 4$

$M[SP] \leftarrow DR$  (data register)

Subtract  $SP, SP, \#4$

Store  $Rj, (SP)$

New item to be pushed on the stack is in processor register  $Rj$

Pop:  $DR \leftarrow M[SP]$

Load  $Rj, (SP)$

$SP \leftarrow SP + 4$

Add  $SP, SP, \#4$

load the top value from the stack into register  $Rj$

and increment the  $SP$  by 4

- Most of the computers do not provide hardware to check stack full or empty
- The stack limits can be checked by using two processor registers. One to hold the upper limit and other to hold lower limit
- Before push, SP is compared with upper limit
- After pop, SP is compared with lower limit

10/02

### Subroutines:-

- It is a set of instructions which are used repeatedly in a program is called subroutine
- The block of instructions which carries out a specific and well defined task is called subroutine
- Some space is allocated for subroutines
- When a subroutine is called, PC jumps to the starting address of the subroutine
- Before it jumps the present PC value is stored in a link register
- After execution of subroutine, when a return statement appears the link register's value is placed in PC.

### Subroutine calls and returns

- The call instruction is just a special branch instruction that performs the following instructions
  - store the contents of PC in link register
  - Branch to the target address specified by the call instruction
- The return instruction is a special branch instruction

that performs the following operations,

→ load the contents of link register in PC

\* the way in which a computer makes it possible to call and return from subroutines is referred to as its subroutine linking method

\* the simplest subroutine linkage method to save the return address in a specific location, which may be a register dedicated to this function, such a register is link register.

subroutine Nesting:-

. the one subroutine calls another

. The nested calls the link register will be overriden, so stack is used for this purpose

Parameter Passing:-

. When calling a subroutine, the program must provide parameters to the subroutine to be used in the computation

. later, the subroutine returns other parameters, which are the results of the computation

. This exchange of information between a calling program and a subroutine is referred to as parameter passing

. Parameter passing can be accomplished in several ways

. The parameters may be placed in registers or in memory location, where they can be accessed by the subroutine

. Alternatively, the memory may be placed in the processor's stack

- Passing the parameter through processor registers is straight toward

Worked

calling program

|       |           |                            |
|-------|-----------|----------------------------|
| Load  | R2, N     | Parameter 1 is list size   |
| Move  | R1, #Numb | Parameter 2 is list length |
| Call  | LIST ADD  | call subroutine            |
| Store | R3, SUM   | save result                |

subroutine:-

|           |            |                                      |
|-----------|------------|--------------------------------------|
| LISATADD: | subtract   |                                      |
| Subtract  | SP, SP, #4 | save the contents of R5 on the stack |
| store     | R5, (SP)   |                                      |
| clear     | R3         | Initialize sum to zero               |

loop:

|          |            |                        |
|----------|------------|------------------------|
| load     | R5, (R4)   | Get the next number    |
| Add      | R3, R3, R5 | Add the number to sum  |
| Add      | R4, R4, #4 | Increment pointer by 4 |
| subtract | R2, R2, #1 | Decrement the counter  |

Branch-if-[R2]>0      loop

|        |            |                           |
|--------|------------|---------------------------|
| load   | R5, (SP)   | Restore contents of R5    |
| Add    | SP, SP, #4 |                           |
| return |            | Return to calling program |

parameter parsing through registers

- If many parameters are involved, there may not be enough general purpose registers available for passing them to the subroutine
- The parameter stack provides a convenient and flexible

mechanism for passing an arbitrary number of parameters

- Assume that before the subroutine is called, the top of the stack is at level 1.
- The calling program pushes the address Num1 and the value n onto the stack and call LISTADD
- The top of the stack is now at level 2

parameters passed on stack:



stack contents for the below program

More R2, #Num1 push parameters onto stack

subtract SP, SP, #4

store R2, (SP)

load R2, N

subtract SP, SP, #4

store R2, (SP)

call LISTADD call subroutine

(top of stack is at level 2)

load R2, 4(SP) Get result from stack, save it in R2

|                  |             |                                              |
|------------------|-------------|----------------------------------------------|
| store            | R2, SUM     | save it in stack                             |
| Add              | SP, SP, #8  | Restore top of stack<br>(top of stack is at) |
| <u>LISTADD:</u>  |             | saves registers                              |
| Subtract         | SP, SP, #16 |                                              |
| store            | R2, 12(SP)  |                                              |
| store            | R3, 8(SP)   |                                              |
| store            | R4, 4(SP)   |                                              |
| store            | R5, (SP)    | (top of stack is at)                         |
| Load             | R2, 16(SP)  | Initialize counter                           |
| Load             | R4, 20(SP)  | Initialize pointer to list                   |
| clear            | R3          | Initialize sum to 0                          |
| <u>LOOP :-</u>   |             |                                              |
| Load             | R5, (R4)    | Get the next number                          |
| Add              | R3, R3, R5  | Add this number to our                       |
| Add              | R1, R4, #4  | Increment pointer by 4                       |
| Subtract         | R2, R2, #1  | Decrement the counter                        |
| Branch-if-[R2]>0 | LOOP        | -                                            |
| store            | R3, 20(SP)  | Put result in stack                          |
| load             | R5, (SP)    | Restore registers                            |
| load             | R4, 4(SP)   | -                                            |
| load             | R3, 8(SP)   | -                                            |
| load             | R2, 12(SP)  | -                                            |
| Add              | SP, SP, #16 | (top of stack is at)                         |
| Return           | -           | Return to calling program                    |

15b2p02

## Stack frame :-

- During execution of the subroutine, six locations at the top of the stack contain entries that are needed by the subroutine.
- These locations constitute a private work space for the subroutines, allocated at the time the subroutine is entered and deallocated when the subroutine returns control to the calling program.
- Such space is called a stack frame.
- If the subroutine requires more space for local memory variables, the space for these variables can also be allocated on the stack.



subroutine stack frame example

Shows an example for a commonly used layout of information in a stack frame.

In addition to the stack pointer SP, it is desirable to have another pointer register, called the frame pointer (FP), for convenient access to the parameters passed to the subroutine and the local memory variables used by the subroutine.

Additional instructions:-

Logical shifts:-

Shifting Left (LshiftL | LSHL):-

LshiftL #2, R0

Actual: 0110...011

0110...0110

After : 10....01100

Shifting Right (RshiftR | LSHR):-

R LshiftR #2, R0

Actual : 0110...011

0011...01

After shifting: 0001...0

Arithmetic shifts:-

A shiftR #2, R0

Actual : 10011...010

110011...01

After : 1100...0

Rotate :-

a) Rotate without carry to left

RotateL #2, R0

Actual: 0 1 1 1 0 ... 0 1 1

1 1 1 0 ... 0 1 0

After: 1 1 0 ... 0 1 1 0 1



b) Rotate left with carry

RotateLC #2, R0

Actual: 0 1 1 1 0 ... 0 1 1

1 1 1 0 ... 0 1 0

After: 1 1 0 ... 0 1 1 0 0



c) Rotate right without carry

RotateR #2, R0

Actual: 0 1 1 1 0 ... 0 1 1 c=0

1 0 1 1 1 0 ... 0 1 c=1

After: 1 1 0 1 1 1 ... 0



d) Rotate right with carry

Rotater #2, R0

Actual: 0 1 1 1 0 ... 0 1 1

0 0 1 1 1 0 ... 0 1

1 0 0 1 1 1 0 ... 0

After:



These are some of the state instructions

## Encoding of machine instructions

|       |       |       |         |   |   |   |   |   |   |   |
|-------|-------|-------|---------|---|---|---|---|---|---|---|
| 31    | 27 26 | 22 21 | 17 16   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Rsrel | Rsrc2 | Rdst  | OP code |   |   |   |   |   |   |   |

Register - operand format

|      |       |                   |         |   |   |   |   |   |   |
|------|-------|-------------------|---------|---|---|---|---|---|---|
| 31   | 27 26 | 22 21             | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
| Rsre | Rdst  | Immediate operand | OP code |   |   |   |   |   |   |

Immediate - operand format

|                 |   |         |   |   |   |   |   |
|-----------------|---|---------|---|---|---|---|---|
| 31              | 6 | 5       | 4 | 3 | 2 | 1 | 0 |
| Immediate value |   | OP code |   |   |   |   |   |

Call format

16 to 32 bit