

# Tulsiramji Gaikwad-Patil College of Engineering & Technology, Nagpur Department of Information Technology

<u>Notes</u>

# Academic Session: 2018-2019

Subject: CAO

Semester: IV

# <u>Unit – I</u>

# <u>Syllabus</u>

Basic Structure of Computers: Functional Units, Basic Operational Concepts, Bus Structures, Software, Multiprocessors and Multicomputer. Machine Instructions: Memory Locations and Addresses, Memory Operations, Machine program sequencing, addressing modes and encoding of information, Assembly Language, Stacks, Queues and Subroutine.

|       | What is computer? Explain different types of computer.                                                                                                                                                                                                  | 7 <b>M</b> |  |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|--|
| Ans:- | Computer types                                                                                                                                                                                                                                          |            |  |  |  |
|       | <ol> <li>A computer can be defined as a fast electronic calculating machine that<br/>accepts the (data) digitized input information process it as per the list of<br/>internally stored instructions and produces the resulting information.</li> </ol> |            |  |  |  |
|       | <ol> <li>List of instructions are called programs &amp; internal storage is called computer<br/>memory.</li> </ol>                                                                                                                                      |            |  |  |  |
|       | The different types of computers are                                                                                                                                                                                                                    |            |  |  |  |
|       | <b>1. Personal computers:</b> - This is the most common type found in homes, schools, Business offices etc., It is the most common type of desk top computers with processing and storage units along with various input and output devices.            |            |  |  |  |
|       | 2. Note book computers: - These are compact and portable versions of PC                                                                                                                                                                                 |            |  |  |  |
|       |                                                                                                                                                                                                                                                         |            |  |  |  |
|       | 3. Work stations: - These have high resolution input/output (I/O) graphics capability, but with same dimensions as that of desktop computer. These are used in engineering applications of interactive design work.                                     |            |  |  |  |
|       | but with same dimensions as that of desktop computer. These are used in engineering                                                                                                                                                                     |            |  |  |  |





|        | are being executed.                                                                                                                                                                                                                                  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.     | The memory contains a large number of semiconductors storage cells. Each capable of storing one bit of information. These are processed in a group of fixed site called word.                                                                        |
| 3.     | To provide easy access to a word in memory, a distinct address is associated<br>with each word location. Addresses are numbers that identify memory location.                                                                                        |
| 4.     | Number of bits in each word is called word length of the computer. Programs must reside in the memory during execution. Instructions and data can be written into the memory or read out under the control of processor.                             |
| 5.     | Memory in which any location can be reached in a short and fixed amount of time after specifying its address is called random-access memory (RAM).                                                                                                   |
| 6.     | The time required to access one word in called memory access time.<br>Memory which is only readable by the user and contents of which can't be<br>altered is called read only memory (ROM) it contains operating system.                             |
| 7.     | Caches are the small fast RAM units, which are coupled with the processor and are often contained on the same IC chip to achieve high performance. Although primary storage is essential it tends to be expensive.                                   |
| 2 Sec  | ondary memory: -                                                                                                                                                                                                                                     |
| 1.     | Is used where large amounts of data & programs have to be stored, particularly information that is accessed infrequently.                                                                                                                            |
| 2.     | Examples: - Magnetic disks & tapes, optical disks (ie CD-ROM's), floppies etc.,                                                                                                                                                                      |
| Arithr | netic logic unit (ALU):-                                                                                                                                                                                                                             |
| 1.     | Most of the computer operators are executed in ALU of the processor like<br>addition, subtraction, division, multiplication, etc. the operands are brought into<br>the ALU from memory and stored in high speed storage elements called<br>register. |
| 2.     | Then according to the instructions the operation is performed in the required sequence.                                                                                                                                                              |
| 3.     | The control and the ALU are many times faster than other devices connected to a computer system.                                                                                                                                                     |
|        |                                                                                                                                                                                                                                                      |

|       | such as key boards, displays, magnetic and optical disks, sensors and other mechanical controllers.                                                                                                                                                                                                                                     |  |  |  |  |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|       | Output unit:-                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|       | <ol> <li>These actually are the counterparts of input unit. Its basic function is to send<br/>the processed results to the outside world.</li> </ol>                                                                                                                                                                                    |  |  |  |  |  |
|       | 2. Examples: - Printer, speakers, monitor etc.                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|       | Control unit: - It effectively is the nerve center that sends signals to other units and senses their states. The actual timing signals that govern the transfer of data between input unit, processor, memory and output unit are generated by the control unit.                                                                       |  |  |  |  |  |
| Q3)   | Explain Basic operational concepts of computer.                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| Ans:- | Basic operational concepts                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|       | <ol> <li>To perform a given task an appropriate program consisting of a list of<br/>instructions is stored in the memory. Individual instructions are brought from the<br/>memory into the processor, which executes the specified operations. Data to be<br/>stored are also stored in the memory. Examples: - Add LOCA, R0</li> </ol> |  |  |  |  |  |
|       | <ol> <li>This instruction adds the operand at memory location LOCA, to operand in<br/>register R0 &amp; places the sum into register. This instruction requires the<br/>performance of several steps,</li> </ol>                                                                                                                        |  |  |  |  |  |
|       | 1. First the instruction is fetched from the memory into the processor.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|       | 2. The operand at LOCA is fetched and added to the contents of R0                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|       | 3. Finally the resulting sum is stored in the register R0                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|       | <ol> <li>The preceding ads instruction combines a memory access operation with an<br/>ALU Operations. In some other type of computers, these two types of<br/>operations are performed by separate instructions for performance reasons.</li> </ol>                                                                                     |  |  |  |  |  |
|       | 4. Load LOCA, R1 Add R1, R0 Transfers between the memory and the processor<br>are started by sending the address of the memory location to be accessed to<br>the memory unit and issuing the appropriate control signals. The data are then<br>transferred to or from the memory.                                                       |  |  |  |  |  |







|                | sent to the memory.                                                                                                                                                                                                                                                            |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4.             | After the time required to access the memory elapses, the address word is read<br>out of the memory and loaded into the MDR.                                                                                                                                                   |
| 5.             | Now contents of MDR are transferred to the IR & now the instruction is ready to be decoded and executed.                                                                                                                                                                       |
| 6.             | If the instruction involves an operation by the ALU, it is necessary to obtain the required operands.                                                                                                                                                                          |
| 7.             | An operand in the memory is fetched by sending its address to MAR & Initiating a read cycle.                                                                                                                                                                                   |
| 8.             | When the operand has been read from the memory to the MDR, it is transferred from MDR to the ALU.                                                                                                                                                                              |
| 9.             | After one or two such repeated cycles, the ALU can perform the desired operation.                                                                                                                                                                                              |
| 10.            | . If the result of this operation is to be stored in the memory, the result is sent to MDR.                                                                                                                                                                                    |
| 11.            | Address of location where the result is stored is sent to MAR & a write cycle is initiated.                                                                                                                                                                                    |
| 12.            | The contents of PC are incremented so that PC points to the next instruction that is to be executed.                                                                                                                                                                           |
| 1.             | Normal execution of a program may be preempted (temporarily interrupted) if some devices require urgent servicing, to do this one device raises an Interrupt signal.                                                                                                           |
| 2.             | An interrupt is a request signal from an I/O device for service by the processor.<br>The processor provides the requested service by executing an appropriate<br>interrupt service routine.                                                                                    |
| 3.             | The Diversion may change the internal stage of the processor its state must be<br>saved in the memory location before interruption. When the interrupt-routine<br>service is completed the state of the processor is restored so that the<br>interrupted program may continue. |
| Q4) Explain Bu | us structure of computer Ans:-                                                                                                                                                                                                                                                 |
| Bus structure  |                                                                                                                                                                                                                                                                                |
|                | The simplest and most common way of interconnecting various parts of the computer.                                                                                                                                                                                             |
|                | To achieve a reasonable speed of operation, a computer must be organized so that all its units can handle one full word of data at a                                                                                                                                           |



| Q5) | Explain the difference between Multiprocessor & Multicomputer                                                                                                                                                                                                                           |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | 3. Can only be employed where loads can be interrupted or where we have some other supply source                                                                                                                                                                                        |
|     | 2. Failure of bus results in failure of the whole substation                                                                                                                                                                                                                            |
|     | 1. Difficult to do maintenance operations                                                                                                                                                                                                                                               |
|     | Disadvantages:                                                                                                                                                                                                                                                                          |
|     | 2. Simple to operate                                                                                                                                                                                                                                                                    |
|     | 1. Low cost                                                                                                                                                                                                                                                                             |
|     | Advantages:                                                                                                                                                                                                                                                                             |
|     | The instructions from the processor at once are loaded into these buffers and then the complete transfer of data at a fast rate will take place                                                                                                                                         |
|     | 7. All the interconnected devices are not of same speed & time, leads to a bit of<br>a problem. This is solved by using cache registers (ie buffer registers). These<br>buffers are electronic registers of small capacity when compared to the main<br>memory but of comparable speed. |
|     | <ol><li>Multiple bus structure certainly increases the performance but also<br/>increases the cost significantly.</li></ol>                                                                                                                                                             |
|     | Very flexible for attaching peripheral devices                                                                                                                                                                                                                                          |
|     | Low cost                                                                                                                                                                                                                                                                                |
|     | 5. Single bus structure is                                                                                                                                                                                                                                                              |
|     | actively use the bus at any given time. Bus control lines are used to arbitrate multiple requests for use of one bus.                                                                                                                                                                   |
|     | 4. Since the bus can be used for only one transfer at a time, only two units can                                                                                                                                                                                                        |
|     | 3. In addition to the lines that carry the data, the bus must have lines for address and control purpose.                                                                                                                                                                               |
|     | Fig c: Single bus structure                                                                                                                                                                                                                                                             |
|     |                                                                                                                                                                                                                                                                                         |
|     | INPUT MEMORY PROCESSOR OUTPUT                                                                                                                                                                                                                                                           |
|     | given time. A group of lines that serve as a connecting port for several devices is called a bus.                                                                                                                                                                                       |



A Multiprocessor is a computer system with two or more central processing units (CPUs) share full access to a common RAM. The main objective of using a multiprocessor is to boost the system's execution speed, with other objectives being fault tolerance and application matching.

There are two types of multiprocessors, one is called shared memory multiprocessor and another is distributed memory multiprocessor. In shared memory multiprocessors, all the CPUs shares the common memory but in a distributed memory multiprocessor, every CPU has its own private memory.



# Applications of Multiprocessor -

- 1. As a uniprocessor, such as single instruction, single data stream (SISD).
- 2. As a multiprocessor, such as single instruction, multiple data stream (SIMD), which is
- 3. usually used for vector processing.
- 4. Multiple series of instructions in a single perspective, such as multiple instruction, single data stream (MISD), which is used for describing hyper-threading or pipelined processors.
- 5. Inside a single system for executing multiple, individual series of instructions in multiple perspectives, such as multiple instruction, multiple data stream (MIMD).

# Benefits of using a Multiprocessor –

- Enhanced performance.
- Multiple applications.
- Multi-tasking inside an application.
- High throughput and responsiveness.



• Hardware sharing among CPUs.

### 2. Multicomputer:

A multicomputer system is a computer system with multiple processors that are connected together to solve a problem. Each processor has its own memory and it is accessible by that particular processor and those processors can communicate with each other via an interconnection network.



As the multicomputer is capable of messages passing between the processors, it is possible to divide the task between the processors to complete the task. Hence, a multicomputer can be used for distributed computing. It is cost effective and easier to build a multicomputer than a multiprocessor.

# Difference between multiprocessor and Multicomputer:

- 1. Multiprocessor is a system with two or more central processing units (CPUs) that is capable of performing multiple tasks where as a multicomputer is a system with multiple processors that are attached via an interconnection network to perform a computation task.
- 2. A multiprocessor system is a single computer that operates with multiple CPUs where as a multicomputer system is a cluster of computers that operate as a singular computer.
- 3. Construction of multicomputer is easier and cost effective than a multiprocessor.
- 4. In multiprocessor system, program tends to be easier where as in multicomputer system, program tends to be more difficult.
- 5. Multiprocessor supports parallel computing, Multicomputer supports distributed computing.

# Q6) Explain the difference between big-endian and little-endian assignments







#### Instruction Fetch:

The instruction is fetched from the memory location whose address is in PC. This is then placed in IR.

#### Instruction Execution:

Instruction in IR is examined and decoded to determine which operation is to be performed.

#### Program execution Steps:

1. The three instructions of the program are in successive word locations, starting at location i. since each instruction is 4 bytes long, the second and third instructions start at addresses i + 4 and i + 8.



- 2. Let us consider how this program is executed. The processor contains a register called the program counter (PC), which holds the address of the instruction to be executed next. To begin executing a program, the address of its first instruction (I in our example) must be placed into the PC.
- 3. Then, the processor control circuits use the information in the PC to fetch and execute instructions, one at a time, in the order of increasing addresses. This is called straight-line sequencing.
- 4. During the execution of each instruction, the PC is incremented by 4 to point to the next instruction. Thus, after the Move instruction at location i + 8 is executed, the PC contains the value i + 12, which is the address of the first instruction of the next program segment.
- 5. Executing 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 the PC.



|       | <ol><li>This instruction is placed in the instruction register (IR) in the processor. The<br/>instruction in IR is examined to determine which operation is to be performed.</li></ol>                                                                                       |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | The specified operation is then performed by the processor. This often involves fetching operands from the memory or from processor registers, performing an arithmetic or logic operation, and storing the result in the destination location.                              |
| Q8)   | Explain different Addressing modes with example                                                                                                                                                                                                                              |
| Ans:- | Addressing modes:                                                                                                                                                                                                                                                            |
|       | The term addressing modes refers to the way in which the operand of an instruction is specified. The addressing mode specifies a rule for interpreting or modifying the address field of the instruction before the operand is actually executed                             |
|       | Types of Addressing Modes:                                                                                                                                                                                                                                                   |
|       | <ol> <li>Immediate Addressing Mode –<br/>In immediate addressing mode the source operand is always data. If the data is<br/>8-bit, then the instruction will be of 2 bytes, if the data is of 16-bit then the<br/>instruction will be of 3 bytes.</li> </ol>                 |
|       | <b>Examples:</b><br>MVI B 45 (move the data 45H immediately to register B)<br>LXI H 3050 (load the H-L pair with the operand 3050H immediately)<br>JMP address (jump to the operand address immediately)                                                                     |
|       | <ol> <li>Register Addressing Mode –<br/>In register addressing mode, the data to be operated is available inside the<br/>register(s) and register(s) is(are) operands. Therefore the operation is<br/>performed within various registers of the microprocessor.</li> </ol>   |
|       | <b>Examples:</b><br>MOV A, B (move the contents of register B to register A)<br>ADD B (add contents of registers A and B and store the result in register A INR A<br>(increment the contents of register A by one)                                                           |
|       | <ol> <li>Direct Addressing Mode –<br/>In direct addressing mode, the data to be operated is available inside a memory<br/>location and that memory location is directly specified as an operand. The<br/>operand is directly available in the instruction itself.</li> </ol> |
|       | <b>Examples:</b><br>LDA 2050 (load the contents of memory location into accumulator A)<br>LHLD address (load contents of 16-bit memory location into H-L register pair)<br>IN 35 (read the data from port whose address is 01)                                               |
|       | 4. Register Indirect Addressing Mode –                                                                                                                                                                                                                                       |



a memory location and that memory location is indirectly specified b a register pair. Examples: MOV A, M (move the contents of the memory location pointed by the H-L pair to the accumulator) LDAX B (move contains of B-C register to the accumulator) LXIH 9570 (load immediate the H-L pair with the address of the location 9570) 5. Implied/Implicit Addressing Mode -In implied/implicit addressing mode the operand is hidden and the data to be operated is available in the instruction itself. Examples: CMA (finds and stores the 1's complement of the contains of accumulator A in A) RRC (rotate accumulator A right by one bit) RLC (rotate accumulator A left by one bit) 6. Auto-increment mode: Effective address of the operand is the contents of a register specified in the instruction. After accessing the operand, the contents of this register are automatically incremented to point to the next consecutive memory location.(R1)+.Example: Add R1, (R2)+ // OR R1 = R1 + M[R2]R2 = R2 + d7. Auto-decrement mode: Effective address of the operand is the contents of a register specified in the instruction. Before accessing the operand, the contents of this register are automatically decremented to point to the previous consecutive memory location. -(R1)Example: Add R1,-(R2) //OR

IN register indirect addressing mode, the data to be operated is available inside

R2 = R2-d

R1 = R1 + M[R2].



| Name                                                                                                                                                                                                     | Assembler syntax                                                                                                                                                                                                                                       | Addressing function                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Immediate                                                                                                                                                                                                | # Value                                                                                                                                                                                                                                                | Operand = Value                                                                                                                                                                                       |
| Register                                                                                                                                                                                                 | Ri                                                                                                                                                                                                                                                     | EA = Ri                                                                                                                                                                                               |
| Absolute (Direct)                                                                                                                                                                                        | LOC                                                                                                                                                                                                                                                    | EA = LOC                                                                                                                                                                                              |
| Indirect                                                                                                                                                                                                 | (Ri)                                                                                                                                                                                                                                                   | EA = [Ri]                                                                                                                                                                                             |
|                                                                                                                                                                                                          | (LOC)                                                                                                                                                                                                                                                  | EA = [LOC]                                                                                                                                                                                            |
| Index                                                                                                                                                                                                    | X(Ri)                                                                                                                                                                                                                                                  | EA = [Ri] + X                                                                                                                                                                                         |
| Base with index                                                                                                                                                                                          | (Ri, Rj)                                                                                                                                                                                                                                               | EA = [Ri] + [Rj]                                                                                                                                                                                      |
| Base with index                                                                                                                                                                                          | X (Ri, Rj)                                                                                                                                                                                                                                             | EA = [Ri] + [Rj] + X                                                                                                                                                                                  |
| and offset<br>Relative                                                                                                                                                                                   | X(PC)                                                                                                                                                                                                                                                  | EA = [PC] + X                                                                                                                                                                                         |
| Autoincrement                                                                                                                                                                                            |                                                                                                                                                                                                                                                        | EA = [rc] + X<br>EA = [Ri]; Increment Ri                                                                                                                                                              |
| Autodecrement                                                                                                                                                                                            | (Ri)+<br>-(Ri)                                                                                                                                                                                                                                         | EA = [Ri], increment RiDecrement Ri; EA = [Ri]                                                                                                                                                        |
|                                                                                                                                                                                                          | ()                                                                                                                                                                                                                                                     |                                                                                                                                                                                                       |
| EA = effective addre                                                                                                                                                                                     | ess                                                                                                                                                                                                                                                    |                                                                                                                                                                                                       |
| Value = a signed nu                                                                                                                                                                                      | mber                                                                                                                                                                                                                                                   |                                                                                                                                                                                                       |
| ifference betwee<br>Stack:                                                                                                                                                                               | en Stack and Queue                                                                                                                                                                                                                                     | with proper example.                                                                                                                                                                                  |
| Stack:                                                                                                                                                                                                   |                                                                                                                                                                                                                                                        | with proper example.                                                                                                                                                                                  |
| <b>Stack</b> :<br>A stack is a list of                                                                                                                                                                   | f data elements, usua                                                                                                                                                                                                                                  |                                                                                                                                                                                                       |
| <b>Stack</b> :<br>A stack is a list of<br>restriction that ele                                                                                                                                           | f data elements, usua<br>ements can be addeo                                                                                                                                                                                                           | ally words or bytes with the accessing                                                                                                                                                                |
| <b>Stack</b> :<br>A stack is a list of<br>restriction that ele<br>End from which e                                                                                                                       | f data elements, usua<br>ements can be addeo                                                                                                                                                                                                           | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.                                                                      |
| <b>Stack</b> :<br>A stack is a list of<br>restriction that ele<br>End from which e<br>Other end is calle                                                                                                 | f data elements, usua<br>ements can be added<br>elements are added a<br>ed the "bottom" of the                                                                                                                                                         | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.                                                                      |
| Stack:<br>A stack is a list of<br>restriction that ele<br>End from which e<br>Other end is calle<br>Also known as: P                                                                                     | f data elements, usua<br>ements can be added<br>elements are added a<br>ed the "bottom" of the                                                                                                                                                         | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.<br>e stack.<br>Last in first out (LIFO) stack.                       |
| Stack:<br>A stack is a list of<br>restriction that ele<br>End from which e<br>Other end is calle<br>Also known as: P<br>Push - pla                                                                       | f data elements, usua<br>ements can be added<br>elements are added a<br>ed the "bottom" of the<br>Pushdown stack. And                                                                                                                                  | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.<br>e stack.<br>Last in first out (LIFO) stack.<br>he stack.          |
| Stack:<br>A stack is a list of<br>restriction that ele<br>End from which e<br>Other end is calle<br>Also known as: P<br>D Push - pla                                                                     | f data elements, usua<br>ements can be added<br>elements are added a<br>ed the "bottom" of the<br>Pushdown stack. And<br>acing a new item on t                                                                                                         | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.<br>e stack.<br>Last in first out (LIFO) stack.<br>he stack.          |
| Stack:<br>A stack is a list of<br>restriction that ele<br>End from which e<br>Other end is calle<br>Also known as: P<br>Push - pla<br>Pop - Remov<br>Data stored in the                                  | f data elements, usua<br>ements can be added<br>elements are added a<br>ed the "bottom" of the<br>Pushdown stack. And<br>acing a new item on t<br>ving the top item from the s<br>e memory of a compu                                                  | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.<br>e stack.<br>Last in first out (LIFO) stack.<br>he stack.          |
| Stack:<br>A stack is a list of<br>restriction that ele<br>End from which e<br>Other end is calle<br>Also known as: P<br><i>Push</i> - pla<br><i>Pop</i> - Remov<br>Data stored in the<br>Successive elem | f data elements, usua<br>ements can be added<br>elements are added a<br>ed the "bottom" of the<br>Pushdown stack. And<br>acing a new item on t<br>ving the top item from the s<br>e memory of a compu-<br>ents occupy success<br>ents are pushed on to | ally words or bytes with the accessing<br>d or removed at one end of the stack.<br>and removed is called the "top" of the stack.<br>e stack.<br>Last in first out (LIFO) stack.<br>he stack.<br>tack. |



| A gei     | neral purpose register could                                           | serve as a s <sup>t</sup>                                                                                                                                                  | tack pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-----------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SI<br>BOT | 2<br>739                                                               | <ul> <li>Byte ad</li> <li>Word le</li> <li>First ele</li> <li>SP point</li> <li>Push op<br/>Subt</li> <li>Pop op<br/>Mov.</li> <li>Add</li> <li>Push w<br/>Mov.</li> </ul> | sor with 65536 bytes of memory.<br>Idressable memory.<br>Ingth is 4 bytes.<br>Idress a bytes.<br>Idress to the stack is at BOTTOM.<br>Its to the element at the top.<br>Idreation can be implemented as:<br>Idreat H4, SP<br>Idreation can be implemented as:<br>Idreat SP<br>Idreat |  |
| б.        | 5535                                                                   |                                                                                                                                                                            | t <u>h autoincrement:</u><br>e (SP)+, A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Sr.No     | STACK                                                                  |                                                                                                                                                                            | QUEUE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 1         | Objects are inserted and rer<br>the same end.                          | noved at                                                                                                                                                                   | Objects are inserted and removed from different ends.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|           | In stacks only one pointer is<br>points to the top of the stack        |                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 2         | 3 In stacks, the last inserted ob first to come out.                   |                                                                                                                                                                            | ject is In queues, the object inserted first is first deleted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|           | first to come out.                                                     |                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|           | first to come out.<br>Stacks follow Last In First O<br>order.          |                                                                                                                                                                            | Queues following First In First<br>Out (FIFO) order.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 3         | Stacks follow Last In First O                                          | out (LIFO)                                                                                                                                                                 | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 3         | Stacks follow Last In First O<br>order.<br>Stack operations are called | out (LIFO)<br>push and                                                                                                                                                     | Out (FIFO) order.<br>Queue operations are called                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |



| Ans:- |                                                                                                                                                                                                                         |  |  |  |  |  |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|       | Subroutine Linkage:<br>- A subroutine is a self-contained sequence of instructions that performs a given                                                                                                                |  |  |  |  |  |
|       | computational task.                                                                                                                                                                                                     |  |  |  |  |  |
|       | 1) A repeated task is implemented as a subroutine.                                                                                                                                                                      |  |  |  |  |  |
|       | 2) To save space, only one copy of the instruction that constitute the subroutine is placed in the <b>main</b> memory and any program that required the use of the subroutine simply branches to its starting location. |  |  |  |  |  |
|       | 3) When the program branches to a subroutine we say that it is calling the subroutine.                                                                                                                                  |  |  |  |  |  |
|       | 4) The instruction that perform this branch operation is called a call subroutine instruction.                                                                                                                          |  |  |  |  |  |
|       | 5) Since the subroutine may be call from different places in a calling program.                                                                                                                                         |  |  |  |  |  |
|       | Provision must be made for returning to the appropriate location.                                                                                                                                                       |  |  |  |  |  |
|       | 6) The content of the PC must be saved by the call subroutine instruction to enable                                                                                                                                     |  |  |  |  |  |
|       | correct return to the calling program.                                                                                                                                                                                  |  |  |  |  |  |
|       | <ol><li>The way in which computer makes it possible to call and return from subroutine is<br/>referred to as its subroutine linkage method.</li></ol>                                                                   |  |  |  |  |  |
|       | 8) The simplest subroutine linkage method in which the return address is saved in                                                                                                                                       |  |  |  |  |  |
|       | specific location such a register, is called link register call subroutine is a special                                                                                                                                 |  |  |  |  |  |
|       | branch instruction that perform following task.                                                                                                                                                                         |  |  |  |  |  |
|       | 1. Save the contentment of Pc in link register.                                                                                                                                                                         |  |  |  |  |  |
|       | 2. Then jump to the address specified by the instruction.                                                                                                                                                               |  |  |  |  |  |
|       |                                                                                                                                                                                                                         |  |  |  |  |  |
|       | Nemory Calling program Memory Subroutine SUB<br>location                                                                                                                                                                |  |  |  |  |  |
|       | 200 Call subroutine SUB 1000 first instruction                                                                                                                                                                          |  |  |  |  |  |
|       | 201 next instruction Return from subroutine                                                                                                                                                                             |  |  |  |  |  |
|       | 0001                                                                                                                                                                                                                    |  |  |  |  |  |
|       | PC 201                                                                                                                                                                                                                  |  |  |  |  |  |
|       |                                                                                                                                                                                                                         |  |  |  |  |  |
|       | Link Call Return                                                                                                                                                                                                        |  |  |  |  |  |
|       | Stack is most efficient data structure to store return address. The most efficient way is to                                                                                                                            |  |  |  |  |  |
|       | store the return address in a memory stack.                                                                                                                                                                             |  |  |  |  |  |
|       | The advantage of using a stack for the return address is that when a succession of                                                                                                                                      |  |  |  |  |  |
|       | subroutines is called, the sequential return addresses can be pushed into the stack.                                                                                                                                    |  |  |  |  |  |
|       | The return from subroutine instruction causes the stack to pop and the contents of the                                                                                                                                  |  |  |  |  |  |
|       | top of the stack are transferred to the program counter.                                                                                                                                                                |  |  |  |  |  |
|       | - A subroutine call is implemented with the following micro operations:                                                                                                                                                 |  |  |  |  |  |
|       | - If another subroutine is called by the current subroutine, the new return address is                                                                                                                                  |  |  |  |  |  |
|       | pushed into The stack and so on.                                                                                                                                                                                        |  |  |  |  |  |
|       | - The instruction that returns from the last subroutine is implemented by the Micro                                                                                                                                     |  |  |  |  |  |
|       | operations:                                                                                                                                                                                                             |  |  |  |  |  |
|       | $PC \leftarrow M$ [SP] Pop stack and transfer to PC SP $\leftarrow$ SP + 1 Increment stack pointer                                                                                                                      |  |  |  |  |  |
|       | Parameter passing:                                                                                                                                                                                                      |  |  |  |  |  |
|       | A parameter is passed to the subroutine by leaving the data in a register, or                                                                                                                                           |  |  |  |  |  |



|         | <ul> <li>A parameter is passed back to the main program by allowing the subroutine to change the data.</li> <li>This is the way parameters are passed in assembly language.</li> <li>When the parameter being passed to the subroutine is in a register, this is referred to as the call-by-value technique of passing parameters.</li> <li>If the data is in memory and the address is passed to the subroutine, this is called call-by-reference.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| <u></u> | It is important to document all parameter-passing details in subroutines                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| Q11)    | Explain 3-address, 2- address, 1-address and zero- address instruction format with example.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|         | Computers with three-address instruction formats can use each address field to specify either a processor register or a memory operand. The program in assembly language that evaluates $X = (A + B) * (C + D)$ is shown below, together with comments that explain the register transfer operation of each instruction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|         | ADD R1, A, B R1 $\leftarrow$ M [A] + M [B]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|         | ADD R2, C, D R2 $\leftarrow$ M [C] + M [D]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|         | $\begin{array}{c} \text{MUL}  X, \text{R1}, \text{R2}  M\left[X\right] \leftarrow \text{R1}*\text{R2} \end{array}$ It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A. The advantage of the three-address format is that it results in short programs when                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|         | MUL X, R1, R2 $M[X] \leftarrow R1 * R2$<br>It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A.<br>The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses.<br><b>TWO-ADDRESS INSTRUCTIONS</b><br>Two address instructions are the most common in commercial computers. Here again each address field can specify either a processor register or a memory word. The                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|         | MUL X, R1, R2 $M[X] \leftarrow R1 * R2$<br>It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A.<br>The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses.<br><b>TWO-ADDRESS INSTRUCTIONS</b><br>Two address instructions are the most common in commercial computers. Here again                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|         | MUL X, R1, R2 $M[X] \leftarrow R1 * R2$<br>It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A.<br>The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses.<br><b>TWO-ADDRESS INSTRUCTIONS</b><br>Two address instructions are the most common in commercial computers. Here again each address field can specify either a processor register or a memory word. The                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|         | MUL X, R1, R2 $M[X] \leftarrow R1 * R2$<br>It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A.<br>The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses.<br><b>TWO-ADDRESS INSTRUCTIONS</b><br>Two address instructions are the most common in commercial computers. Here again each address field can specify either a processor register or a memory word. The program to evaluate X = (A + B) * (C + D) is as follows                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|         | $MUL  X, R1, R2 \qquad M[X] \leftarrow R1 * R2$ It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A. The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses. <b>TWO-ADDRESS INSTRUCTIONS</b> Two address instructions are the most common in commercial computers. Here again each address field can specify either a processor register or a memory word. The program to evaluate X = (A + B) * (C + D) is as follows $MOV  R1, A \qquad R1 \leftarrow M[A]$                                                                                                                                                                                                                                        |  |  |  |  |  |
|         | $\begin{array}{c} \text{MUL}  X, \text{R1}, \text{R2}  M[X] \leftarrow \text{R1} * \text{R2} \\ \end{array}$ It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A. The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses.<br><b>TWO-ADDRESS INSTRUCTIONS</b> Two address instructions are the most common in commercial computers. Here again each address field can specify either a processor register or a memory word. The program to evaluate X = (A + B) * (C + D) is as follows $\begin{array}{c} \text{MOV}  \text{R1}, \text{A} \qquad \text{R1} \leftarrow \text{M} [\text{A}] \\ \text{ADD}  \text{R1}, \text{B} \qquad \text{R1} \leftarrow \text{R1} + \text{M} [\text{B}] \end{array}$ |  |  |  |  |  |
|         | $\begin{array}{cccc} MUL & X, R1, R2 & M\left[X\right] \leftarrow R1 * R2 \end{array}$ It is assumed that the computer has two processor registers, R1 and R2. The symbol M [A] denotes the operand at memory address symbolized by A. The advantage of the three-address format is that it results in short programs when evaluating arithmetic expressions. The disadvantage is that the binary-coded instructions require too many bits to specify three addresses. <b>TWO-ADDRESS INSTRUCTIONS</b> Two address instructions are the most common in commercial computers. Here again each address field can specify either a processor register or a memory word. The program to evaluate X = (A + B) * (C + D) is as follows $\begin{array}{c} MOV & R1, A & R1 \leftarrow M[A] \\ ADD & R1, B & R1 \leftarrow R1 + M[B] \\ MOV & R2, C & R2 \leftarrow M[C] \end{array}$                                                                                           |  |  |  |  |  |



be both a source and the destination where the result of the operation is transferred.

# **ONE-ADDRESS INSTRUCTIONS:**

One-address instructions use an implied accumulator (AC) register for all data manipulation. For multiplication and division there is a need for a second register. However, here we will neglect the second and assume that the AC contains the result of tall operations. The program to evaluate  $X = (A + B)^* (C + D)$  is

| LOAD  | А | AC ← M [A]                    |
|-------|---|-------------------------------|
| ADD   | В | $AC \leftarrow A [C] + M [B]$ |
| STORE | Т | $M[T] \leftarrow AC$          |
| ADD   | D | $AC \leftarrow AC + M [D]$    |
| MUL   | Т | $AC \leftarrow AC * M [T]$    |
| STORE | Х | $M[x] \leftarrow AC$          |

# ZERO-ADDRESS INSTRUCTIONS:-

A stack-organized computer does not use an address field for the instructions ADD and MUL. The PUSH and POP instructions, however, need an address field to specify the operand that communicates with the stack. The following program shows how X = (A + B) \* (C + D) will be written for a stack organized computer. (TOS stands for top of stack)

To evaluate arithmetic expressions in a stack computer, it is necessary to convert the expression into reverse Polish notation. The name "zero-address" is given to this type of computer because of the absence of an address field in the computational instructions

|        |                                 | PUSH      | А     | $TOS \gets A$                    |
|--------|---------------------------------|-----------|-------|----------------------------------|
|        |                                 | PUSH      | В     | $TOS \gets B$                    |
|        |                                 | ADD       |       | $TOS \gets (A + B)$              |
|        |                                 | PUSH      | С     | $TOS \gets C$                    |
|        |                                 | PUSH      | D     | $TOS \gets D$                    |
|        |                                 | ADD       |       | $TOS \gets (C + D)$              |
|        |                                 | MUL       |       | $TOS \gets (C + D) \ast (A + B)$ |
|        |                                 | POP       | Х     | M [X] ← TOS                      |
| Q12) E | Explain assembly language and e | execution | of pr | ograms in detail.                |



| ASSE | MBLY LANGUAGE                                                                                                                                                                                                                                           |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.   | Machine instructions are represented by patterns of 0s and 1s. Such patterns are awkward to deal with when discussing or preparing programs.                                                                                                            |
| 2.   | Therefore, we use symbolic names to represent the pattern. So far, we have<br>used normal words, such as Move, Add, Increment, and Branch, for the<br>instruction operations to represent the corresponding binary code patterns.                       |
| 3.   | When writing programs for a specific computer, such words are normally replaced by acronyms called mnemonics, such as MOV, ADD, INC, and BR. Similarly, we use the notation R3 to refer to register 3, and LOC to refer to a memory location.           |
| 4.   | A complete set of such symbolic names and rules for their use constitute a programming language, generally referred to as an assembly language.                                                                                                         |
| 5.   | Programs written in an assembly language can be automatically translated into<br>a sequence of machine instructions by a program called an assembler.                                                                                                   |
| 6.   | When the assembler program is executed, it reads the user program, analyzes it, and then generates the desired machine language program.                                                                                                                |
| 7.   | The latter contains patterns of 0s and 1s specifying instructions that will be executed by the computer.                                                                                                                                                |
| 8.   | The user program in its original alphanumeric text format is called a source program, and the assembled machine language program is called an object program.                                                                                           |
| ASSE | MBLER DIRECTIVES:-                                                                                                                                                                                                                                      |
| 1.   | In addition to providing a mechanism for representing instructions in a program,<br>the assembly language allows the programmer to specify other information<br>needed to translate the source program into the object program.                         |
| 2.   | We have already mentioned that we need to assign numerical values to any<br>names used in a program. Suppose that the name SUM is used to represent<br>the value 200. This fact may be conveyed to the assembler program through a<br>statement such as |
|      | SUM EQU 200                                                                                                                                                                                                                                             |
| 3.   | This statement does not denote an instruction that will be executed when the object program is run; in fact, it will not even appear in the                                                                                                             |



object program.

4. It simply informs the assembler that the name SUM should be replaced by the value 200 wherever it appears in the program. Such statements, called assembler directives (or commands), are used by the assembler while it translates a source program into an object program.

#### ASSEMBLY AND EXECUTION OF PRGRAMS:-

- 1. A source program written in an assembly language must be assembled into a machine language object program before it can be executed. This is done by the assembler program, which replaces all symbols denoting operations and addressing modes with the binary codes used in machine instructions, and replaces all names and labels with their actual values.
- 2. The assembler assigns addresses to instructions and data blocks, starting at the address given in the ORIGIN assembler directives. It also inserts constants that may be given in DATAWORD commands and reserves memory space as requested by RESERVE commands.
- 3. As the assembler scans through a source programs, it keeps track of all names and the numerical values that correspond to them in a symbol table.
- 4. Thus, when a name appears a second time, it is replaced with its value from the table. A problem arises when a name appears as an operand before it is given a value. For example, this happens if a forward branch is required.
- 5. A simple solution to this problem is to have the assembler scan through the source program twice. During the first pass, it creates a complete symbol table. At the end of this pass, all names will have been assigned numerical values.
- 6. The assembler then goes through the source program a second time and substitutes values for all names from the symbol table. Such an assembler is called a two-pass assembler.
- 7. The assembler stores the object program on a magnetic disk. The object program must be loaded into the memory of the computer before it is executed. For this to happen, another utility program called a loader must already be in the memory.
- 8. When the object program begins executing, it proceeds to completion unless there are logical errors in the program. The user must be able to find errors easily.
- 9. The assembler can detect and report syntax errors. To help the user find other programming errors, the system software usually includes a



|      | debugger program.                                                                                                                                                                                                                                                                                                                         |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 10. This program enables the user to stop execution of the object program at some<br>points of interest and to examine the contents of various processor registers<br>and memory locations.                                                                                                                                               |
| Q13) | Write a short note on         1. Memory locations and addresses       2. Byte Addressability                                                                                                                                                                                                                                              |
|      | Memory locations and addresses                                                                                                                                                                                                                                                                                                            |
|      | 1. Number and character operands, as well as instructions, are stored in the memory of a computer. The memory consists of many millions of storage cells, each of which can store a bit of information having the value 0 or 1.                                                                                                           |
|      | 2. Because a single bit represents a very small amount of information, bits are seldom handled individually. The usual approach is to deal with them in groups of fixed size.                                                                                                                                                             |
|      | 3. For this purpose, the memory is organized so that a group of n bits can be stored or retrieved in a single, basic operation. Each group of n bits is referred to as a word of information, and n is called the word length. The memory of a computer can be schematically represented as a collection of words as shown in figure (a). |
|      | 4. Modern computers have word lengths that typically range from 16 to 64 bits.                                                                                                                                                                                                                                                            |
|      | <ol> <li>If the word length of a computer is 32 bits, a single word can store a 32-bit 2's complement number or four ASCII characters, each occupying 8 bits. A unit of 8 bits is called a byte.</li> </ol>                                                                                                                               |
|      | <ol> <li>Accessing the memory to store or retrieve a single item of information, either a<br/>word or a byte, requires distinct names or addresses for each item location. It is<br/>customary to use numbers from 0 through 2K-1, for some suitable values of k,<br/>as the addresses of successive locations in the memory.</li> </ol>  |
|      | <ol> <li>The 2k addresses constitute the address space of the computer, and the<br/>memory can have up to 2k addressable locations. 24-bit address generates an<br/>address space of 224 (16,777,216) locations. A 32-bit address creates an<br/>address space of 232 or 4G (4 giga) locations.</li> </ol>                                |
|      | BYTE ADDRESSABILITY:-                                                                                                                                                                                                                                                                                                                     |
|      | 1. We now have three basic information quantities to deal with: the bit, byte and word. A byte is always 8 bits, but the word length typically ranges from 16 to 64 bits. The most practical assignment is to have successive addresses refer to successive byte                                                                          |







Types of software:- computer software can be divided into:

#### **Application software**

which is software that uses the computer system to perform special functions or provide entertainment functions beyond the basic operation of the computer itself. There are many different types of application software, because the range of tasks that can be performed with a modern computer is so large—see list of software.

#### System software

which is software that directly operates the computer hardware, to provide basic functionality needed by users and other software, and to provide a platform for running application software.[5] System software includes:

#### **Operating systems**

which are essential collections of software that manage resources and provides common services for other software that runs "on top" of them. Supervisory programs, boot loaders, shells and window systems are core parts of operating systems. In practice, an operating system comes bundled with additional software (including application software) so that a user can potentially do some work with a computer that only has one operating system.

#### Application of software:

- 1) Scientific Research.
- 2) Business application.
- 3) Banking.
- 4) Education.
- 5) Communication.
- 6) Medicine.
- 7) Space Technology.





Tulsiramji Gaikwad-Patil College of Engineering & Technology, Nagpur Department of Information Technology

> <u>Notes</u> Academic Session: 2017- 2018

Subject:CAO

Semester: IV

#### <u>Unit – II</u>

#### <u>Syllabus</u>

Instruction Sets: Instruction Format, limitations of Short word- length machines, High level language Considerations, Motorola 68000 architecture. Processing Unit: Some fundamental concepts, Execution of a complete instruction, Single, two, three bus organization, Sequencing of control Signals.

#### Q1). Explain the instruction set of 68000.

(7)

Ans:

- 1. The 6800 has 72 documented instruction commands and a number of additional undocumented instructions.
- 2. When all the available valid addressing modes are considered there are a total of 197 valid op-codes for the 6800. Motorola refers to the MS byte of the instruction as the op-code.
- 3. In general instruction execution time is in the range of 2-12 microseconds, depending on instruction and addressing mode used. The 6800 uses internal execution stages to complete instructions in less cycle.
- 4. The instruction can be 8, 16, or 24 bits in length depending on the op-code and type of addressing used/needed. There are no I/O instructions in the 6800 as all I/O devices are mapped to the memory and so reside in memory space.
- 5. The instructions can be grouped into several areas:
- **Memory reference instructions**: These are used for data transfers between either of the two GP registers and the memory. Instructions between the general purpose registers and memory are used for arithmetic and logical instructions. There are some single address instructions which are used to operate on data in memory only.



• Arithmetic and logic operations:-These instructions can be carried out between memory and a general purpose register, or between two general purpose registers. The arithmetic operations supported are added, subtract, increment and decrement. Logical operations which are supported are AND, OR, NOT and XOR.

#### Jumps

Instructions are provided for fourteen conditional jumps and two unconditional jumps. These are single address memory reference instructions, almost all use relative addressing i.e. the jump is to an address given relative to a pointer, usually the index pointer.

#### • Subroutine Entry and Exit

- 1. The subroutine entry instruction is a single address, memory reference instruction. When used the subroutine entry instruction causes the content of the program counter to be pushed onto the stack.
- 2. On return from the sub-routine the program counter is popped from the stack back to the SP register.
- 3. As the stack is held in memory it can be as large as the memory itself. Then using the STS (store stack pointer) and LDS (load stack pointer) instructions a program can have multiple stacks.
- 4. As the stack is used to store the program counter during sub routine calls, this allows almost unlimited subroutine nesting. Push and Pull instructions are provided for both A and B accumulators.

#### **Register-Register instructions**

1. There are a limited number of instructions that operate on the contents of the general purpose registers. These allow for movement of the contents of the stack pointer and index pointer registers, and incrementing and decrementing of these as well.

#### Shift instructions

1. Right, left and circular shifts are provided. These are of one position only.

#### Flag instructions



1. There a series of instructions provided to set or clear flags. Flag values can be moved to the GP registers for program analysis or alteration. The branch instructions can test four of the flags; carry, sign, overflow and zero.

#### **Other Instructions**

The 6800 also has a 'no-operation' instruction which advances the program counter and a wait instruction which works by extending the length of the clock pulses.

#### Q2) Explain condition code flag of 68000.

(3)

Ans:

This final register contains six flags which are set or cleared in response to how the program executes. These flags are:

- C Carry, for arithmetic operations which result in a carry.
- V Overflow, set to 1 when a 2's complement overflow results from an arithmetic operation.
- Z Zero, set to 1 if result of an operation is 0, otherwise is set to 0.
- N Negative, is set to indicate a negative number
- I Interrupt mask, when this bit is set then interrupts are inhibited. Otherwise set to 0 and the processor may be interrupted by IRQ (the Interrupt Request Pin) being in a low state.
- H Half carry auxiliary flag, set when there is a carry from bit 3 to 4 in some of the arithmetic operations.
- The two remaining bits 7 and 8 are permanently set to 1.

# Q3) What is meant by system buses? Explain different bus architecture in computer system.

Ans:

- 1. The simplest and most common way of interconnecting various parts of the computer.
- 2. To achieve a reasonable speed of operation, a computer must be organized so that all its units can handle one full word of data at a given time.



- 3. A group of lines that serve as a connecting port for several devices is called a bus.
- 4. In addition to the lines that carry the data, the bus must have lines for address and control purpose.
- 5. Simplest way to interconnect is to use the single bus as shown Since the bus can be used for only one transfer at a time, only two units can actively use the bus at any given time. Bus control lines are used to arbitrate multiple requests for use of one bus.
- 6. Single bus structure is Low cost Very flexible for attaching peripheral devices.
- 7. Multiple bus structure certainly increases the performance but also increases the cost significantly.
- 8. All the interconnected devices are not of same speed & time leads to a bit of a problem. This is solved by using cache registers (i.e. buffer registers). These buffers are electronic registers of small capacity when compared to the main memory but of comparable speed.
- 9. The instructions from the processor at once are loaded into these buffers and then the complete transfer of data at a fast rate will take place.

# Q4). Explain Straight line sequencing in detail

Ans:

- In the preceding discussion of instruction formats, we used to task C [A] +
   [B]. Shows a possible program segment for this task as it appears in the memory of a computer.
- 2. We have assumed that the computer allows one memory operand per instruction and has a number of processor registers.
- 3. The three instructions of the program are in successive word locations, starting at location i. since each instruction is 4 bytes long, the second and third instructions start at addresses i + 4 and i + 8.
- 4. Let us consider how this program is executed. The processor contains a register called the program counter (PC), which holds the address of the instruction to be executed next.



- 5. To begin executing a program, the address of its first instruction (I in our example) must be placed into the PC. Then, the processor control circuits use the information in the PC to fetch and execute instructions, one at a time, in the order of increasing addresses. This is called straight-line sequencing.
- 6. During the execution of each instruction, the PC is incremented by 4 to point to the next instruction. Thus, after the Move instruction at location i + 8 is executed, the PC contains the value i + 12, which is the address of the first instruction of the next program segment.
- 7. Executing 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 the PC.
- 8. This instruction is placed in the instruction register (IR) in the processor. The instruction in IR is examined to determine which operation is to be performed. The specified operation is then performed by the processor.
- 9. This often involves fetching operands from the memory or from processor registers, performing an arithmetic or logic operation, and storing the result in the destination location.

# Q5). Draw and explain register structure of 68000.

Ans:

# **Register Set and Programmers Model**

1. The 6800 has six internaly accessible registers. These are two 8-bit accumulators or general purpose register (A and B), three 16-bit registers PC, SP, and Index register - X) and an 8-bit condition code or status register which has 6 flags in total. These can be viewed as follows:

The function of the registers is as follows.

- The Accumulators A and B:Each stores and manipulates one 8-bit word under program control.
- The Index register X is a 2-byte register. It holds memory addresses when using indexed-addressing mode instructions.
- The Program Counter PCIs a 2-byte register which contains the address of the next byte of the instruction to be fetched from memory (instructions can be from one to 3 bytes in length). When the current value



of the program counter is placed on the address bus, the PC is updated to the value of the next instruction for execution.

• Stack pointer - SPA 2-byte register which holds the starting address of sequential memory locations in RAM where the contents of the CPU registers may be stored and retrieved. The 6800 uses RAM for its stack, this has some advantages that are outlined in the section of the 6800



Instruction set.

#### **Status Register or Condition Codes Register**

This final register contains six flags which are set or cleared in response to how the program executes. These flags are:

- C Carry, for arithmetic operations which result in a carry.
- V Overflow, set to 1 when a 2's complement overflow results from an arithmetic operation.
- Z Zero, set to 1 if result of an operation is 0, otherwise is set to 0.
- N Negative, is set to indicate a negative number
- I Interrupt mask, when this bit is set then interrupts are inhibited. Otherwise set to 0 and the processor may be interrupted by IRQ (the Interrupt Request Pin) being in a low state.
- H Half carry auxiliary flag, set when there is a carry from bit 3 to 4 in some of the arithmetic operations.
- The two remaining bits 7 and 8 are permanently set to 1.

# Q6). Explain branching instruction in 68000 with respect to program flow control.

Ans



Page 6 of 12

- 1. The 6800 has 72 documented instruction commands and a number of additional undocumented instructions.
- 2. When all the available valid addressing modes are considered there are a total of 197 valid op-codes for the 6800.
- 3. Motorola refers to the MS byte of the instruction as the op-code. In general instruction execution time is in the range of 2-12 microseconds, depending on instruction and addressing mode used. The 6800 uses internal execution stages to complete instructions in less cycle.
- 4. The instruction can be 8, 16, or 24 bits in length depending on the op-code and type of addressing used/needed.
- 5. There are no I/O instructions in the 6800 as all I/O devices are mapped to the memory and so reside in memory space.

#### Q. Explain storing a word in memory:

- 1. In particular, when we fetch the operands (i.e., the registers) we want to send the source and destination registers bits to a device called the **register file**.]
- 2. For example, if **IR25-21** has value 00111, this means we want register **\$r7** from the register file. We sent in 00111 to this circuit, and it returns the contents back to us.
- 3. If we are executing an I-type instruction, then typically, we'll sign-extend (or zero-extend, depending on the instruction) the immediate part (i.e., **IR15-0**) to 32 bits.
- 4. Fetching a word from memory:

At this point, the output of the ALU is written back to the register file. For example, if the instruction was: **add \$r2, \$r3, \$r4** then the *result* of adding the contents of **\$r3** to the contents of **\$r4** would be stored back into **\$r2**.

The result could also be due to a **load** from memory.

Some instructions don't have results to store. For example, branch and jump instructions do not have any results to store.

# Q7). Define and Explain

1. Control memory.



Ans: The 6800 has six internaly accessible registers. These are two 8-bit accumulators or general purpose register (A and B), three 16-bit registers PC, SP, and Index register - X) and an 8-bit condition code or status register which has 6 flags in total. These can be viewed as follows:

The function of the registers is as follows.

The Accumulators A and B: Each stores and manipulates one 8-bit word under program control.

# The Index register - X

It is a 2-byte register. It holds memory addresses when using indexed-addressing mode instructions.

The Program Counter - PCIs a 2-byte register which contains the address of the next byte of the instruction to be fetched from memory (instructions can be from one to 3 bytes in length). When the current value of the program counter is placed on the address bus, the PC is updated to the value of the next instruction for execution.

#### **Stack pointer - SP**

A 2-byte register which holds the starting address of sequential memory locations in RAM where the contents of the CPU registers may be stored and retrieved. The 6800 uses RAM for its stack, this has some advantages that are outlined in the



section of the 6800 Instruction set.

# 2. Status Flag:

Ans: Status Register or Condition Codes Register



Page 8 of 12

This final register contains six flags which are set or cleared in response to how the program executes. These flags are:

- C Carry, for arithmetic operations which result in a carry.
- V Overflow, set to 1 when a 2's complement overflow results from an arithmetic operation.
- Z Zero, set to 1 if result of an operation is 0, otherwise is set to 0.
- N Negative, is set to indicate a negative number
- I Interrupt mask, when this bit is set then interrupts are inhibited. Otherwise set to 0 and the processor may be interrupted by IRQ (the Interrupt Request Pin) being in a low state.
- H Half carry auxiliary flag, set when there is a carry from bit 3 to 4 in some of the arithmetic operations.
- The two remaining bits 7 and 8 are permanently set to 1.

#### Or

#### **Q8).** Explain the basic organization of power PC

Ans: PowerPC is a microprocessor architecture that was developed jointly by Apple, IBM, and Motorola. The PowerPC employs reduced instruction-set computing (RISC). The three developing companies have made the PowerPC architecture an open standard, inviting other companies to build on it.

Developed at IBM, reduced instruction-set computing (RISC) is based on studies showing that the simplest computer instructions are the ones most frequently performed. Traditionally, processors have been designed to accommodate the more complex instructions as well. RISC performs the more complex instructions using combinations of simple instructions. The timing for the processor can then be based on simpler and faster operations, enabling the microprocessor to perform more instructions for a given clock speed.

The PowerPC architecture provides an alternative to the popular processor architectures from Intel, including the Pentium. (Microsoft builds its Windows operating system offerings to run on Intel processors, and this widely-sold combination is sometimes called "Wintel".) The PowerPC was first used in IBM's RS/6000 workstation with its UNIX-based operating system, AIX, and in Apple Computer's Macintosh personal computers. Today, PowerPC chips are also used in diverse applications including internetworking equipment, routers, telecom switches, interactive multimedia, automotive control, and industrial robotics.



Page 9 of 12

# Q9). Explain the role of multiple condition register in power PC

Ans: PowerPC Registers:

#### **PowerPC's application-level registers are broken into three categories:**

General purpose, floating point and special purpose registers.

#### • General-purpose registers (GPRs) - r0 to r31

- Flat-scheme of 32 general purpose registers.
- Source and destination for all integer operations
- Address source for all load/store operations.
- They also provide access to SPRs.
  - All GPRs are available for use with one exception: in certain instructions, GPR0 simply means the value 0, and no lookup is done for GPR0's contents.

#### • Some of these registers have special tasks assigned to them:

- r0 Volatile register which may be modified during function linkage
- r1 Stack frame pointer, always valid
- r2 System-reserved register
- r3-r4 Volatile registers used for parameter passing and return values
- r5-r10 Volatile registers used for parameter passing
- r11-r12 Volatile registers which may be modified during function linkage
- r13 Small data area pointer register
- r14-r30 Registers used for local variables
- r31 Used for local variables or "environment pointers"

Floating point registers

#### • Floating-point registers (FPRs)- fr0 to fr31

- 32 floating-point registers with 64-bit precision.
- source and destination operands of all floating-point operations
- can contain 32-bit and 64-bit signed and unsigned integer values, as well as single-precision and double-precision floating-point values.

FPR's also provide access to the FPSCR(Floating-Point Status and Control Register)

FPSCR captures status and exceptions resulting from floating-point operations, and also provides control bits for enabling specific exception types.

Instructions to load and store double precision floating point numbers transfers 64-bit of data without conversion.

- Instructions to load from memory single precision floating point numbers convert to double precision format before storing them in the register.
- f0 Volatile register
- f1 Volatile register used for parameter passing and return values
- f2-f8 Volatile registers used for parameter passing



f9-f13 Volatile registers

f14-f31 Registers used for local variables Special-purpose registers (SPRs)

- The Fixed-Point Exception Register (XER)- used for indicating conditions for integer operations, such as carries and overflows.
- The Floating-Point Status and Control Register (FPSCR)- 32-bit register used to store the status and control of the floating-point operations.
- **The Count Register (CTR)-** used to hold a loop count that can be decremented during the execution of branch instructions.
- The Condition Register (CR)-32-bit register grouped into eight fields, where each field is 4 bits that signify the result of an instruction's operation: Equal (EQ), Greater Than (GT), Less Than (LT), and Summary Overflow (SO).
- The Link Register (LR) contains the address to return to at the end of a function call.

#### Q10). Compare hardwired and micro-controlled control unit

#### Ans: Hardwird Control

The control units use fixed logic circuits to interpret instructions and generate control signals from them. The fixed logic circuit block includes combinational circuit that generates the required control outputs for decoding and encoding functions.

Every instruction in a processor is implemented by a sequence of one or more sets of concurrent micro operations. Each micro operation is associated with a specific set of control lines which, when activated, causes that micro operation to take place. Since the number of instructions and control lines is often in the hundreds, the complexity of hardwired control unit is very high. Thus, it is costly and difficult to design. The hardwired control unit is relatively inflexible because it is difficult to change the design, if one wishes to correct design error or modify the instruction set Microprogramming is a method of control unit design in which the control signal memory CM.

The control signals to be activated at any time are specified by a microinstruction, which is fetched from CM.

A sequence of one or more micro operations designed to control specific operation, such as addition, multiplication is called a micro program.

The address where these microinstructions are stored in CM is generated by micro program sequencer/micro program controller.

The micro program sequencer generates the address for microinstruction according to the instruction stored in the IR.

The micro programmed control unit,



Page **11** of **12** 

- control memory
- control address register
- Micro instruction register
- Micro program sequencer

#### Q11). Explain micro programmed control unit

Ans: Every instruction in a processor is implemented by a sequence of one or more sets of concurrent micro operations. Each micro operation is associated with a specific set of control lines which, when activated, causes that micro operation to take place. Since the number of instructions and control lines is often in the hundreds, the complexity of hardwired control unit is very high. Thus, it is costly and difficult to design. The hardwired control unit is relatively inflexible because it is difficult to change the design, if one wishes to correct design error or modify the instruction set

Microprogramming is a method of control unit design in which the control signals memory CM.

The control signals to be activated at any time are specified by a microinstruction, which is fetched from CM.

A sequence of one or more micro operations designed to control specific operation, such as addition, multiplication is called a micro program.

The address where these microinstructions are stored in CM is generated by micro program sequencer/micro program controller.

The micro program sequencer generates the address for microinstruction according to the instruction stored in the IR.

The micro programmed control unit,

- control memory
- control address register
- Micro instruction register
- Micro program sequencer

