

## System Programming



## Machine structure



# SIC Machine structure:

- 1) Memory
- 2) Registers
- 3) Data formats
- 4) Instruction formats
- 5) Addressing modes
- 6) Instruction set
- 7) Input / output

## Desc structures:

- 1) 8 bits = a byte, 3 byte = 1 word
- 2) A, X, L, PC, SW
- 3) Integer - binary  
-ve number - 2's complement  
character - ASCII  $\rightarrow$  floating point X
- 4) 3 bytes (24 bits)
 

|        |       |              |
|--------|-------|--------------|
| opcode | x     | displacement |
| 8 bits | 1 bit | 15 bits      |
- 5)  $x=0$  direct  $TA = \text{displacement}$   
 $x=1$  indirect  $TA = (x) + \text{displacement}$
- 6) Data movement  
eg: LDA, LDX, STA, STX
- 7) Input / output:  
TD RD WD

- Arithmetic operation  
ADD, SUB, MUL
- Branching operation  
JLT, JEQ, JNL
- Sub-routine linkage instruction  
JSUB, RSUB

## SIC/XE Architecture:

- 1) Memory : bit, 8 bits = byte, 3 byte = word  
 $2^{20}$  memory (2 mb)
- 2) Registers : A, X, L, PC, SW, B, T, S, F  
→ general purpose
- 3) Data format
- 4) Instruction format
- 5) Addressing modes

6) Instructions

7) Input and output (I/O)

3) Data format : integer  
 ↓  
 binary  
 floating point  
 (single precision)  
 double precision

, -ve integer , character  
 ↓ 2's complement  
 ↓ ASCII

| S | exponent | fraction |
|---|----------|----------|
|---|----------|----------|

 $\rightarrow R \ 0-1$ 

$$1 \quad 21 \quad 36 = f \times 2^{e-2024}$$

4) Instruction format:

1 byte instruction (format 1) [opcode(8)]

eg: RSUB

2 byte instruction (format 2)

| opcode | operands |
|--------|----------|
|--------|----------|

|       |                |                |
|-------|----------------|----------------|
| 8     | r <sub>1</sub> | r <sub>2</sub> |
| 4 bit | 4 bit          |                |

comp A, S  
 converted to 4 bit hexa dec

format 3 : 24 bits

| 6  | 1 | 1 | 1 | 1 | 1 | 1 |
|----|---|---|---|---|---|---|
| OP | n | i | x | b | P | e |

disp(12)

format 4 : 32 bits

| 6  | 1 | 1 | 1 | 1 | 1 | 1 | 20   |
|----|---|---|---|---|---|---|------|
| OP | n | i | x | b | p | e | disp |
| ↓  | ↓ |   |   |   |   |   |      |
| 0  | 1 |   |   |   |   |   |      |
| 1  | 0 |   |   |   |   |   |      |
| 1  | 1 |   |   |   |   |   |      |

 $e=1 \Rightarrow$  format 4 is used

eg: +JSUB RDREC  
 ↓  
 ReadRecord

## 5) Addressing modes:

$b=1$   $n=0$  and  $i=1 \rightarrow$  immediate addressing (no memory reference)

$x=1$   $n=1$  and  $i=0 \rightarrow$  indirect addressing

$pc=1$   $n=0$  and  $i=0 \rightarrow$  simple addressing  $TA$  is the location of the operand

$e=1$   $n=1$  and  $i=1 \rightarrow$  simple addressing

|        |        |                 |
|--------|--------|-----------------|
|        |        |                 |
| 3030   | 003600 | $(B) = 006000$  |
|        |        | $(PC) = 003000$ |
| 3600   | 103000 | $X = 000090$    |
|        |        |                 |
| 6390   | 00C303 |                 |
|        |        |                 |
| C303   | 003030 |                 |
| Memory |        |                 |

$n=0$  and  $i=1 = TA = \text{displacement} = (B) + \text{disp(12)}$

$n=1$  and  $i=0 \Rightarrow X \cdot b_{PC} \Rightarrow$  search in ref of this bit

$$X=1 \Rightarrow TA = X + \text{disp}$$

$$PC=1 \Rightarrow TA = (PC) + \text{disp(12)}$$

$$e=1$$

$$\hookrightarrow TA = \text{disp(20)}$$

?

$X=1, P=1$  then

$$TA = (X) + (B) + \text{disp}$$



We have to calculate the final address

$$\begin{aligned} TA &= (PC) + \text{disp} \\ &= 003000 + 600 \\ &= 003600 \end{aligned}$$

The value in accumulator (A) = 103000

# 003600 (Hex)

And final address (TA), Accumulator value (A) = ?



$$\begin{aligned} TA &= (PC) + \text{disp}(20) \\ &= 003000 + 00600 \\ &= 003600 \end{aligned}$$

$$\therefore TA = 003600$$

$$A = 103000$$

## # SIC / XE

- Instruction sets :
  - Load / store  $\rightarrow$  LDA, LDB, LDT, STA, STB
  - Integer arithmetic operation  $\rightarrow$  ADD, MUL, DIV, SUB
  - Floating point arithmetic operation  $\rightarrow$  ADDF, MULF
  - Compare  $\rightarrow$  COMP A, S
  - Conditional jump  $\rightarrow$  JLT, JEQ, JGT
  - Sub-routine linkage  $\rightarrow$  JSUB, RSUB
  - Register manipulation, operands - from - registers, register to register arithmetics

## Input / output (I/O)

- $2^8$  I/O devices
- 2 byte will be transfer

|    |     |       |
|----|-----|-------|
| TD | SIO | start |
| RD | HIO | Halt  |
| WD | TIO | Test  |

## Programming examples:

| SIC                       | SIC / XE             |
|---------------------------|----------------------|
| Instruction               |                      |
| variable :                |                      |
| int c                     | resource             |
| byte num1                 | NUM1 RESB 1          |
| DEVICE BYTE = x'F1'       |                      |
|                           | Hex const      value |
| String BYTE = C' TESTING' |                      |
| NUM2 RESW 1               |                      |
| Four word '4'             |                      |
| ↑      ↑      ↑           |                      |
| variable datatype         |                      |

# Write a program to add two numbers.

```

START 1000
ADDNUM    LDA FOUR
           ADD FIVE      A=4
           STA RESULT    A=A+FIVE=9
                           RESULT=9
FOUR      WORD 4
FIVE      WORD 5
RESULT    RESW 1
END      ADDNUM

```

In SIC / XE :

```

ADDNUM    START 1000
           LDA #4
           ADD #5
           STA RESULT
           RESULT RESW 1
END      ADDNUM

```

Assignment -1

(g) write a SIC and SIC / XE program to find the sum  
of array having 5 different numbers.

→ SIC assembly language program:

```

START 1000
LDA zero
LD X zero
Loop   ADD Address, X
       TIX count
       JLT Loop
       STA RESULT

```

|         |      |   |
|---------|------|---|
| zero    | WORD | 0 |
| Address | RESW | 5 |
| count   | WORD | 5 |
| Result  | RESW | 1 |

⇒ SIC/XE Assembly language program :

```

LDT #5
LDX #0
LDA #0
Loop ADD Address, X
TIXR T
JLT Loop
STA Result
    
```

|         |      |      |
|---------|------|------|
| Address | WORD | 1000 |
| Result  | RESW | 1    |



# VAX architecture :

1) Memory :

8-bit = bytes, byte addressing, 2 bytes - word  
 four bytes - longword, 8 bytes form quadword  
 - operates in virtual address space → system space  
 $2^{32}$  bits → process space

## 2) Registers:

26 Cnprs - 32 bit each

PC (R<sub>15</sub>), SP (R<sub>14</sub>), FP (R<sub>13</sub>), AP (R<sub>12</sub>)

- PSL for flag.

## 3) Data format:

integer - binary in byte, word, longword, octaword

-ve integer - 2's complement

character - 8 bit ASCII

4 different floating point.

## 4) Instruction formats:

variable length instruction format 1 to 6 operand.

## 5) Addressing modes:

Register mode, register direct mode, autoincrement, autodecrement, base relative, PC relative, indexed, indirect and immediate.

## 6) Instruction sets:

Instruction are symmetric w.r.t datatype. The instruction mnemonics are formed by

- a prefix that specifies the datatype of the operands.
- suffix that specifies the datatype of the operand.
- a modifier that gives the number of operands involved.

Eg: ADDW2, MULB3

## 7) Input / output:

use I/O device controller

- device control registers are mapped to separate I/O space.

- software and MMR are used for I/O operation.

## Pentium Pro Architecture :

- 1995
- intel x86 family
- vast amt of software.
- different implementation details.

### Memory :

physical level : byte, 2byte-word, long word

logical level : segments + offset

Registers : 32 bit 8 CPRS, EAX, EBX, ECX, EDX, ESI, EDI,  
EBP, ESP

Flags : flag bit register CS, SS, DS, ES, FS, GS

### Data formats :

integer - 8, 16, 32 binary nos

ove - 2's complements

BCD - packed and unpacked

character(s) - ASCII code

Instruction formats : instructions uses prefixes to specify repetition count, segment registers, following prefix (if present) an opcode (1 or 2 bytes) and no of bytes to specify operands, addressing modes.

- varies in length from 1 to 20 bytes or more.

Addressing modes : large no. of addressing modes

Immediate mode, register mode, direct, relative base, index with displacement.

$$TA = (b) + (\text{index}) * \text{scalefactor} + \text{disp}$$

Instruction set: large and complex,  $\approx 100$ , may have 1 to 3 operand R-R, R-M, M-M, string manipulation, immediate value.

Input / output: Input is from an I/O port into Registers EAX output EAX to I/O port.

BCD: eg 487

Packed: 0100 1000 0111 0000  
↓ byte      ↓ 1 byte      ↓

Unpacked: 0000 0100 0000 1000 0000 0111  
↓ 4      ↓ 8      ↓ 7

$$Fp \rightarrow \text{single } 32 = 24 + 7 + 1$$

$$64 = 53 + 10 + 1$$

$$80 = 64 + 15 + 1$$

logical level:



Assignment 2:

RISC Architecture:

Ultra sparc  $\rightarrow$  presentation

## I) UltraSPARC Architecture

→ Memory : 2<sup>34</sup> bytes in virtual address space

- consists of 8-bit bytes; halfword : 2 bytes

- word : 4 bytes

- doubleword : 8 bytes

- can be divided into pages

- virtual address is automatically translated into a physical address by the ultraSPARC Memory Management Unit.

→ A large register file (>100 general-purpose registers)

- 32 bits for original SPARC, 64 bits for ultraSPARC

- Each procedure can access only 32 registers

- : 8 global registers and 24 registers in overlapped window

- Floating point computations are performed using a special floating-point unit.

- Program counter PC

→ Data formats:

- characters : 8-bit ASCII codes

- integers : 1, 2, 4, 8-byte binary numbers

- 2's complement for negative values

- floating-point numbers: single-precision : 32 bits

- double-precision : 64 bits

- quad-precision : 80 bits

→ Instruction formats:

- fix-length instruction format (32 bits long)

- 3 basic instruction formats : call, branch, load

- Each instruction consists of : first 2 bits → identify formats

- op code

- operands

## → Addressing modes; Immediate mode

Register direct mode

PC relative mode only for branch instruction

Register indirect with displacement

Register indirect indexed

## → Instruction set

- less than 100 instructions
- Instruction execution is pipelined.
- Branch instructions are delayed branches
  - Instructions immediately following the branch instruction is actually executed before the branch is taken.

## → Input and output

- A range of memory locations is logically replaced by device registers.
- Device driver read/write values into these registers.
- Software routines read/write values in this area using standard instructions.

## 2) PowerPC Architecture

- Developed by IBM in 1990
- POWER  $\rightarrow$  Performance optimization with Enhanced RISC.
- Memory : 8 bit bytes
  - 2 bytes - half word
  - 4 bytes - word
  - 8 bytes - double word
  - 16 bytes - quad word

Programs can be written using virtual memory address  
of  $2^{64}$  bytes.

- Register: 32 general purpose
  - 32 bit
    - full power PC - 64 bit
    - 32 floating point register - 32 bit
    - control register
    - Link register
    - status register
- Data format & integer : 8, 16, 32, 64 bit binary numbers.
  - ve numbers  $\rightarrow$  2's complement.
  - floating point numbers
  - characters - 8 bit ASCII code
- Instruction format:
  - $\rightarrow$  7 instruction format
- Addressing modes:
  - Immediate
  - Register direct

- Register indirect
  - Register Indirect with index
  - Indirect with immediate index
  - Absolute
  - Relative
- 
- Instruction sets:
    - Approximately 200
    - floating point, multiply and add instructions
- 
- I/O:
    - Direct store segments.
    - Normal virtual memory address.

### 3) CRAY T3E Arch

- announced by Cray Research, Inc (1995)
- Massively parallel processing system (MPP)
- Scientific computing
- T3E
  - 16 to 2048 processing element (PE)
  - three-dimensional network
  - each PE consists of a DEC Alpha EV5 RISC microprocessor, local memory and performance accelerating control logic.

### Memory:

- 64 MB to 2GB
- physically distributed, logically shared memory.
- byte, longword, quadword
- 64 bit virtual addresses

## # Register

- 32 general purpose register designated R0 through R31; R31 always contains the value zero.
- 32 floating point register F0 to F31. F31 always contains the value zero.
- program counter (PC)
- other status and control register.

## # Data formats

- two different types of floating point data formats.
- one for compatibility with VAX.
- the other is for IEEE standard formats.
- characters are stored using 8-bit ASCII codes.
- Since there are no byte or store operations, characters that are to be manipulated separately are usually stored one per longword.

## # Instructions format

- Five Basic Instruction formats
- 32 bit long
- The first 6 bit identify specify the opcode.
- Some instructions have an additional function field.

## # Addressing modes

- immediate mode, register direct mode.
- memory addressing

| Mode        | Target address calculation                        |
|-------------|---------------------------------------------------|
| Pc-relative | $TA = (PC) + displacement$<br>{ 23 bits, signed } |

Register indirect  
with displacement

TA = (register) + displacement  
{ 16 ~~big~~ bits, signed }

- register indirect with displacement mode is used for load and store operations and for subroutine jumps.
- PC relative mode is used for conditional and unconditional branches.

#### # Instruction set

- 130 machine instructions, no byte or word load and store in instruction.

#### Assignment:

- flowchart pass1, pass2 assembler
- SIC/XE object code

## # Pass1 and Pass2 flowchart



fig: Detailed Pass1 flowchart



## # SIC/XE assembly with object code

| LOC  | LABEL  | opcode     | operand | obj. code |
|------|--------|------------|---------|-----------|
| 0000 | COPY   | START      | 0       |           |
| 0000 | FIRST  | STL        | RETADR  | 17202D    |
| 0003 |        | LDB        | #LENGTH |           |
|      |        | BASE       | LENGTH  |           |
| 0006 | CLoop  | +JSUB      | RDREC   | 4B101036  |
| 000A |        | LDA        | LENGTH  | 032026    |
| 000D |        | COMP       | #0      | 290000    |
| 0010 |        | JEQ        | ENDFIL  | 332007    |
| 0013 |        | +JSUB      | WRREC   | 4B10105D  |
| 0017 |        | J          | CLoop   | 3F2FEC    |
| 001A | ENDFIL | LDA        | EOF     | 032010    |
| 001D |        | STA<br>LDA | BUFFER  | 0F2016    |
| 0020 |        | +JSUB      | #3      | 010003    |
| 0023 |        | STA        | LENGTH  | 0F200D    |
| 0026 |        | +JSUB      | WRREC   | 4B10105D  |
| 002A |        | J          | @RETADR | 3E2003    |
| 002D | EOF    | BYTE       | C'EOF'  | 454F46    |
| 0030 | RETADR | RESW       | 1       |           |
| 0033 | LENGTH | RESW       | 1       |           |
| 0036 | BUFFER | RESB       | 4096    |           |

## Machine dependent Assembler features

- a) Instruction formats and addressing modes
- b) Program relocation

- a) Instruction formats and addressing modes

1) PC - relative or base relative op m

2) Indirect addressing op @m

3) Immediate addressing op #c

4) Extended format +op m

5) Register to Register op Reg1, Reg2

6) index addressing op m

### SIC Machine

SUM START 4000

FIRST LDX ZERO

LDA ZERO

LOOP ADD TABLE,X

TIX COUNT

JLT LOOP

STA TOTAL

RSUB

TABLE RESW 2000

COUNT RESW 1

ZERO WORD 1

TOTAL RESW 1

END FIRST

### SIC/XE Machine

SUM START 4000

FIRST LDX #0

LDA #0

LOOP ADD TABLE,X

TIX COUNT

JLT LOOP

STA TOTAL

RSUB

TABLE RESW 2000

COUNT RESW 1

TOTAL RESW 1

END FIRST

### XE

| opcode | n | i | x | b | p | e | disp |                                                                       |
|--------|---|---|---|---|---|---|------|-----------------------------------------------------------------------|
| 6      | 1 | 1 | 1 | 1 | 1 | 1 | 12   | FIRST LDX #0 050000<br>→ 04 → 0000 0101 0000 0000 0000 0000 0000 0000 |

PC relative :

$$TA = (PC) + dPS(12)$$

$$\approx -2048 + 2047$$

BASE RELATIVE  $TA = (B) + disp(12)$  ] LDB and NO BASE  
value = 0 or 4095 ]

1) PC-relative

e.g.: (a) 10 000 FIRST STL RETADR 17202D  
(b) 40 0017 J CLOOP 3F2FEC

2) indirect addressing

002A J (a) RETADR 3E2003

Registers to Registers, COMPR A, X

Assignment:

## Chapter-3 Loaders and linkers



### Basic loader functions

- A loader brings an object program into memory and starting its execution.
- A linker performs the linking operations and a separate loader to handle relocation and loading.

## Machine dependent Loaders features :

- Relocation
- Programming linking
- Algorithm and Data structure for a linking loader.

## Machine Independent Loader feature :

a) Automatic library search

b) Loader options

a) Automatic library search

b) Loader options

- INCLUDE prog-name (library name)

- DELETE (sect-name)

- CHANGE Name1, Name2

Include READ (UTLIB)

Include WRITE (UTLIB)

DELETE RDREC, WRREC

CHANGE RDREC, READ

CHANGE WRREC, WRITE

' LIBRARY MYLIB

NOCALL STDDEV, PLOT

ADDNUM C,D,E,F

STA R

ADD B1

LDA A2

ADDNUM A1,B1,R

ADDUM A1,B1,R

MEN1

STA RESULT

ADD Num2

LDA Num1

ADDNUM Macro num1, num2, RESULT

MEN1

body

Name Macro Parameters

SIC

b) Macro processor algorithm and data structures

a) Macro definition and expansion

Basic Macro processor function

Macroprocessor

Macros

Macro Processors

Data structure:

NAMTAB

ADDNUM, 1, 1

DEFTAB

→ ADDNUM macro num1, num2, Rest

LDA ?1

ADD ?2

STA ?3

→ MEND

Avg.tab

|   |                |
|---|----------------|
| 2 | A <sub>i</sub> |
| 2 | B <sub>i</sub> |
| 3 | R              |

functions:

GetLine

ProcessLine

Define

expand

Macro / time variable:  
RD BUFF

RDBUFF F<sub>1</sub>, BUF, LEN, (00, 03, 04)

CLEAR X

CLEAR A

+ LD T #U096

\$AALoop TD = x'F<sub>1</sub>'

JEG \$AALoop

RD = x'F<sub>1</sub>'

COMP = x'000000'

END JEG \$AAExit

COMP = x'000003'

# JEG \$AAEXIT  
COMP = X'000004'  
JER \$AAEXIT  
STCH BUF, X  
TIXR T  
JLT \$AALOOP  
\$AAEXIT STX LEN

# RDBUFF F1, BUF, LEN  
CLEAR X  
CLEAR A  
+ LDT #4096  
\$ABLoop TD = X'F'  
JEG \$ABLoop  
RD = X'F'  
STCH BUF, X  
TIXR T  
JLT \$ABLoop  
\$ABExit SIX LEN

#

Keyword Macro Examples

CLASSMATE

Date \_\_\_\_\_

Page \_\_\_\_\_

RDBUFF BUFADR = BUFFER, RECLH = LENGTH,  
EOR = 04, ~~MAXRECSIZE~~

CLEAR X  
CLEAR A  
LOCM = x'04'  
RMO A,S  
+ LDJ #4096

\$AALOOP TD = x'F'  
JEQ \$AALOOP  
RD = x'F'  
COMPR A,S  
JEQ \$AAEXIT  
STCH BUFFER, X  
TIXR T  
JLT \$AALOOP  
\$AAEXIT SIX LENGTH

# Macro processor design option

- 1) Recursive macro Expansion
- 2) General purpose macro processors
- 3) Macro processing within language translator

i) ABC Macro A<sub>1</sub>, A<sub>2</sub>

:

XYZ Macro A<sub>4</sub>, A<sub>5</sub>

:

MEND

MEND

|  |  |                                |          |
|--|--|--------------------------------|----------|
|  |  |                                |          |
|  |  |                                | 90000016 |
|  |  | NEG EAX                        |          |
|  |  | JNS 000001                     |          |
|  |  | SUB EAX, N                     |          |
|  |  | MV EAX, M                      |          |
|  |  | While (I == 0)                 |          |
|  |  | While (I <= 0)                 |          |
|  |  | #define EG =                   | *        |
|  |  | ANSI C macro language          |          |
|  |  | 2) ANSI C                      |          |
|  |  | NEA AX                         |          |
|  |  | JNS 2000000                    |          |
|  |  | SUB AX, K                      |          |
|  |  | MV AX, J                       |          |
|  |  | BLANK                          |          |
|  |  | ⇒ Error - size must be a       |          |
|  |  | ABSDEF MN/A                    |          |
|  |  | ABSDEF JK                      | *        |
|  |  | Exit : ENDM                    |          |
|  |  | NEG SIZE AX                    |          |
|  |  | JNS Exit                       |          |
|  |  | SUB SIZE AX, OP2               |          |
|  |  | MV SIZE AX, OP1                |          |
|  |  | END IF                         |          |
|  |  | END IF                         |          |
|  |  | Exit                           |          |
|  |  | • ERR                          |          |
|  |  | ⇒ Error - size must be a blank |          |
|  |  | IPDEF LSIZE, LE                |          |
|  |  | IFNB LSIZE                     |          |
|  |  | LOCAL Exit                     |          |
|  |  | ABSDEF Macro OP1, OP2, SIZE    |          |
|  |  | MASM Macro Processor           |          |
|  |  | Implementation Examples        |          |

# define ABSDIFF (x,y) ((x)>(y)? (x)-(y): (y)-(x))

ABSC ('D', 'A')  
 $\Rightarrow D > A ? D - A : A - D$

# define ABSDIFF (x,y) x>y? x-y: y-x

ABSDIFF (3+1, 10-8)  
 $\Rightarrow 3+1 > 10-8 ? 3+1 - 10-8 : 10-8 - 3+1 = -14$

# define Display (EXPR) printf ("EXPR=%d\n", EXPR)

Display (I \* J + 1)

printf ("#EXPR=%d\n", I \* J + 1)

# define X 1

# if x == 1

printf (

# ENDIF

# ifndef X

# define X 1024

# endif

3) The ELENA Macro processor

%1 = %2 + %3

invoke

ALPHA = BETA + GAMMA

$\%1.2 = \text{ABSDIFF} (\%1.2, \%1.3)$

$\%1.2 = (\%1.2) > (\%1.3) ? (\%1.2) - (\%1.3) : (\%1.3) - (\%1.2)$

$z := \text{ABSDIFF} (x, y)$

↓

MOV EAX, %1.2

SUB EAX, %1.3

JNS & STOR

NEG EAX

& STOR MOV EAX, %1.2

$z := \text{ABSDIFF} (x, y)$

↓

$z = (x) > (y) ? (x) - (y) : (y) - (x)$

MOV EAX, x

SUB EAX, y

JNS STOR 0001

NEG EAX

STOR 0001 MOV EAX, z

Time variable

• SET

while ...

ENDW

Year: 2012

Semester: Spring

1(a) Explain the main purpose of system software in computer?

→ System software is a type of computer program that is designed to run a computer's hardware and application programs. If we think of the computer system as a layered model, the system software is the interface betn the hardware and user applications.

Eg: The programs used to manage a computer, such as installing or removing software and the programs that create the desktop environment.

→ System software includes os such as device drivers, servers, windowing systems and utilities.

The main purpose of system software are:

i) Allocating system resources:

The system resources are time, memory, input and output. The time in the CPU is divided into time slices. The time slices is measured in terms of milliseconds. Based on the priority of tasks the time slices are assigned. Memory is also managed by OS. Disk space is the part of main memory. The data flow is controlled by OS.

ii) Monitoring system activities:

The system security and system performance is monitored by system software. System performance includes response time and CPU utilization. System security is a part of OS. Multiple users can't

access without the security code or password.

### iii) File and disk Management:

The user needs to save, copy, delete, move and rename the files. The system software will handle those functions. Disk and file management is the technical task.

### 1.c) Differentiate the RISC and CISC machine with example.

⇒

RISC

- 1) It stands for Reduced Instruction set computing.
- 2) The microprocessor is designed using hardwired control.
- 3) It executes at least one instruction in a cycle.
- 4) It has several general purpose registers and large cache memory.
- 5) It has a single clock.
- 6) Pipelining is easy.
- 7) Spends more transistors on memory registers.
- 8) LOAD and STORE register-to-register are independent.
- 9) Complexity in compiler.
- 10) Eg: PIC18, ARM

CISC

- 1) It stands for complex Instruction set computing.
- 2) The microprocessor is designed using code control.
- 3) It executes several cycles in one instruction.
- 4) It has a small number of general purpose registers.
- 5) It has multi clock.
- 6) Pipelining is difficult.
- 7) Transistor is used for storing complex instructions
- 8) LOAD and STORE memory-to-memory is induced in Instructions.
- 9) Extensive use of microprogramming
- 10) Eg: 8051, 8086

2(a) Write the algorithm of PASS-1 in assembler.

→ Pass 1:

begin

    read first input line

    if OPCODE = 'START' then

        begin

            save # [OPERAND] as starting address

            initialize LOCCTR to starting address

            write line to intermediate file

            read next input line

        end {if START}

    else

        initialize LOCCTR to 0

    while OPCODE ≠ 'END' do

        begin

            if this is not a comment line then

                begin

                    if there is not a symbol in the LABEL field then

                        begin

                            search SYMTAB for LABEL

                            if found then

                                set error flag (duplicate symbol)

                        else

                                insert (LABEL, LOCCTR) into SYMTAB

                end {if symbol}

            Search OPTAB for OPCODE

            if found then

                add 3 {instruction length} to LOCCTR

            else if OPCODE = 'WORD' then

                add 3 to LOCCTR

            else if OPCODE = 'RESW' then

```

add 3 * # [OPERAND] to LOCCTR
else if OPCODE = 'RESB' then
    add # [OPERAND] to LOCCTR
else if OPCODE = 'BYTE' then
    begin
        find length of # constant in bytes
        add length to LOCCTR
    end { } BYTE
else
    set error flag (invalid operation code)
end { } not a command
write line to intermediate file
read next input line
end { } while not END
write last line to intermediate file
Save (LOCCTR - starting address) as program length
end { } pass 1

```

2-b) Explain how object codes are generated by assembler with example.

- ⇒ In computing object code, or sometimes an object module, is what a compiler produces. In a general sense object code is a sequence of statements or instructions in a computer language, usually a machine code language such as register transfer language.
- ⇒ Object code is a portion of machine code that has not yet been linked in a complete program. It is the machine code for one particular library or module that will make up the completed product. It may also contain placeholders or offsets, not found in the machine code of a completed program, that

the linker will use to connect everything together whereas machine code is binary code that can be executed directly by the CPU, object code has the jumps partially parameterized so that a linker can fill them in.  
 ⇒ An assembler is used to convert assembly code into machine code (object code). A linker links several object files to generate an executable. Assemblers can also assemble directly to machine code.

For example :-

| Line | LOC  | Source statement | Object code |
|------|------|------------------|-------------|
| 10   | 1000 | FIRST STL RETADR | 141033      |

To translate the source code into object code, the assembler converts STL to machine equivalent value 14. The symbolic operand RETADR is translated to 2033.

In the example, the instruction contains a forward reference i.e. reference to label is defined later in the program. It is impossible to process this line as the address that will be assigned to RETADR is not known. So, most assemblers make two passes over source program where the second pass does actual translation.

The assembler must process statements called assembler directives which are not translated into machine instructions but they provide instructions to assembler.

Eg: RESW and RESB instructs assembler to reserve memory locations.

3.a) Explain the use of loader and linker in system software.

→ Loader is program which accepts the object program and prepares it for executions (loads into memory).

Function /use of loader:

- i) Allocation → Allocates space in memory for program
- ii) Linking → Resolves symbolic references between objects codes.
- iii) Relocation → Adjust all the address dependent locations
- iv) Loading → physically place M/c instructions and data into memory

→ Linker is the tool that merges the object files produced by separate compilation or assembly and creates an executable file.

Use of linker:

- i) Searches the program to find library routines used by programs, e.g: printf(), math routines etc.
- ii) Determines the memory locations that code from each module will occupy and relocates its instructions by adjusting absolute references.
- iii) Resolves references among files.

b) How different programs linking is done. Explain with the help of examples.

→ Linking is the process of collecting and combining various pieces of code and data into a single file that can be loaded (copied) into memory and executed. Linking can be performed at compile time,

when the source code is translated into machine code, at load time, when the program is loaded into memory and executed by the loader and even at run time, by application programs. On early computer systems, linking was performed manually. On modern systems, linking is performed automatically by programs called linkers.

→ Linkers play a crucial role in software development because they enable separate compilation. Instead of organizing a large application as one monolithic source file, we can decompose it into smaller, more manageable modules that can be modified and compiled separately. When we change one of these modules, we simply recompile it and relink the application, without having to recompile the other files.

Eg: Let us consider following examples:

| LOC  | Statement |                                            |
|------|-----------|--------------------------------------------|
| 0000 | PROGA     | START D                                    |
|      |           | EXTDEF <del>b</del> <sup>L</sup> STA, ENDA |
|      |           | EXTDEF LIST B, ENDB, LISTC, ENDC           |
| 0020 | REF1      | LDA LIST A                                 |
| 0023 | REF2      | +LDT LIST B+4                              |
| 0027 | REF3      | LDX #END A - LIST A                        |
| 0040 | LISTA     | EQU *                                      |
| 0054 | ENDA      | EQU *                                      |

u-a) Explain the dynamic linking in macro.

- The term 'dynamically linked' means that the program and the particular library it references are not combined together by the linker at link time.
- Instead, the linker places information into the executable that tells the loader which shared object module code is in and which runtime linker should be used to find and bind the references.
- This means that the binding b/w the program and the shared object is done at runtime that is before the program starts, the appropriate shared objects are found and bound.
- This type of program is called a partially bound executable, because it isn't fully resolved. The linker, at link time, didn't cause all the referenced symbols in the program to be associated with specified code from the library.

4b) Explain about macro expansion with an example.

- A macro represents a commonly used group of statements in the source program language.
- Macro expansion means replacing each macro instruction with the corresponding group of source language statements.
- For eg:
  - On SIC/XE requires a sequence of seven instructions to save the contents of all registers.
  - ↳ Then write one statement like SAVEREGS.
- A macro processor is not directly related to the architecture of the computer on which it is run.
- Macro processors can also be used with high level programming languages, OS command languages.



fig: Basic macro processor functions .

|       |        |                    |
|-------|--------|--------------------|
| COPY  | START  | 0                  |
| FIRST | STL    | RETAADR            |
| LOOP  | RDBUFF | F1, BUFFER, LENGTH |
| CLoop | CLEAR  | X                  |
|       | CLEAR  | A                  |

|                             |                  |
|-----------------------------|------------------|
| clear S                     |                  |
| + LDT #4096                 |                  |
| TD =X'F1'                   |                  |
| JEQ *-3                     |                  |
| RD =X'F1'                   |                  |
| COMPR A,S                   |                  |
| JEQ *+11                    |                  |
| STCH BUFFER,X               |                  |
| TIXR T                      |                  |
| JLT *-19                    |                  |
| STX LENGTH                  |                  |
| LDA LENGTH                  |                  |
| COMP #0                     |                  |
| JEQ END FIL                 |                  |
| WRBUFF OS,BUFFER,LENGTH     |                  |
| CLEAR X                     |                  |
| LDT LENGTH                  | TIXR T           |
| LDCH BUFFER,X               | JLT *-14         |
| TD =X'05'                   | I @RETADR        |
| JEQ *-3                     | EOF BYTE C'EOF'  |
| WD =X'05'                   | THREE WORD 3     |
| TIXR T                      | RETADR RESW 1    |
| JLT *-14                    | LENGTH RESW 1    |
| I CLOOP                     | BUFFER RESB 4096 |
| END FIL WRBUFF OS,EOF,THREE | END FIRST        |
| END FIL CLEAR X             |                  |
| LDT THREE                   |                  |
| LDCH EOF,X                  |                  |
| TD =X'05'                   |                  |
| JEQ *-3                     |                  |
| WD =X'05'                   |                  |

Fig: Program with macros expanded

Q. Explain briefly about machine independent loader features.

→ The Machine Independent loader features are:

- i) Automatic library search
- ii) Loader options

i) Automatic library search

→ It is a standard system library and subprogram library.

→ The programmer does not need to take any action beyond mentioning the subroutine names as external references.

→ Linking loaders that support automatic library search must keep track of external symbols that are referred to, but not defined, in the primary input to the loader.

→ Libraries ordinarily contain assembled or compiled versions of subroutines (object programs)

→ Library search by scanning the define records for all of the object programs on the library is quite inefficient.

↳ special file structure is used for the libraries and this structure contains a directory that gives the name of each routine and a pointer to its address within the file.

ii) Loader options

→ Many loaders have a special command language that is used to specify options as - a separate input file to the loader that

contain control statements.

- control statements embedded in the primary input stream beth object programs.
- control statements are included in the source program, and the assembler or compiler retains these commands as a part of the object program.

Commands of loader options.

- \* INCLUDE program-name (Library-name)  
It directs the loader to read the designed object program name specified as a part of input program.
- \* DELETE csect-name  
It deletes the named (control) section(s) from the program loaded when not used.
- \* CHANGE name1, name2  
It changes the external symbol name1 to name2 appeared in the object program.

5.a) Define two different development processes that Booch suggested.

- The Booch method is a method for object oriented software development. It is composed of an object modelling language, an iterative object oriented development process and set of recommended practices.
- There are two different development processes, which he calls micro and macro.

i) Macro process

- Booch's macro process represents the overall activities of the development team on a long-range scale.

Semester - ~~Fall~~ spring

Year - 2012

i) Explain the main purpose of system software in computer?

It includes the following activities:

- Establish the requirements for the software (conceptualization).
- Develop an overall model of the system's behaviour (analysis).
- Create an architecture for the implementation (design).
- Develop the implementation through successive refinements (evolution).
- Manage the continued evolution of a delivered system (maintenance).

This macro process repeats itself after each major release of a software product.

ii) Micro process

→ Booch's micro process essentially represents the daily activities of the system developers. It consists of the following activities:

- Identify the classes and objects of the system.
- Establish the behaviour and other attributes of the classes and objects. For eg: the methods that are applicable to each.
- Analyze the relationships among the classes and objects. For eg: the use of aggregation, inheritance and polymorphism.
- Specify the implementation of the classes and objects.

5-b) Explain the interaction diagram for assembler with example.



Fig: Interaction diagram for assembler

Interaction diagrams make it easier to visualize the sequence of object invocations, and the flow of control between objects.

Consider, for example, the interactions diagram

for assembler in above figure. The primary focus of control is in the object source-program. The assemble method of source-program begins by creating a new instance of source-line for each line in the input file for the assembler. The method Assign-location is then invoked for each source-line object. During its period of control, source-line may invoke Enter to make an entry in the symbol table. If errors are detected, it may invoke the method Record-error on itself.

After the iteration of Assign-location is complete, a second iteration is used to translate each source line. During this process, source-line may invoke methods on several other objects, depending on the conditions encountered.

- 6.a) Explain the advantages and disadvantages of writing a loader using high level programming language.

6. b) Explain about ANSI Macro language.

→ In ANSI C language, definitions and invocations of macros are handled by a preprocessor. The preprocessor is generally not integrated with the rest of the compiler.

For eg: # define NULL  
# define EOF (-1)

These two ANSI C macro definitions means that the every occurrence of NULL will be replaced by 0 and EOF by (-1).

similarly, if the macro # define EQ == is defined then,

while (I EQ 0)  
statement is converted into  
while (I == 0)

by the macro processor.

ANSI C macros can be defined with parameters such as

# define ABSDIFF (x,y) ((x)>(y))?(x)-(y):(y)-(x)

Here, macro name is ABSdif, parameters are x, y.

If  $(x) > (y)$  condition is true, value of the expression is  $(x)-(y)$  otherwise value is  $(y)-(x)$ .

In ANSI C, macro invocation can be done as ABSdif (3+1, 10-8)

Then, it is expanded as

$$3+1 > 10-8? 3+1 - 10-8 : 10-8 - 3+1$$

which would produce output -14 instead of 2.

ANSI C provides stringizing operator # when name of macro parameter is preceded by #, argument is substituted.

For eg: # define DISPLAY (EXPR) printf ("# EXPR" = "%d\n", EXPR)

Then invocation:

DISPLAY (I \* J + 1)

would be expanded as

printf ("I \* J + 1" - " = %d \n", EXPR)

Moreover, ANSI C provides conditional compilation statements to be sure that a macro is defined at least once.

7) write short notes:

g) Multi-pass assembler

→ Multi-pass assembler completes its task in more than one pass. In multipass assembler only parts of the program having forward references must be processed in multiple passes, but not the whole program need multiple passes. To implement multipass assembler, we use a symbol table to store the

symbols that are not defined. We store name and numbers on the table. When a symbol is defined, we use its value to re-evaluate values of other symbols.

Thus, multipass assembler completes its task in two pass. In first pass, it scans code, validates it and creates symbol table. In second pass, it solves forward references and converts assembly code to machine code.

- b) Algorithm and data structure for a linking loader.  
→ The algorithm for linking loader is more complicated than absolute loader algorithm. A linking loader makes two passes over its input, which is similar to that of assembler. Pass 1 assigns address to all external symbols. Pass 2 performs actual loading, relocation and linking.

The main data structure needed linking loader is an external symbol table ESTAB. This table is analogous to SYMTAB in assembler algorithm. It is used to store name and address of each external symbol in the set of control sections being loaded. A hashed organization is used for this table. The other two variables are PROLADDR (program load address) and CSADDR (control section address). PROLADDR is beginning address in memory where linked program is to be loaded. Its value is supplied by OS to loader. CSADDR contains starting address assigned to control section currently being scanned by loader.

### c) Program blocks in assembler

Program block allow the generated machine instructions and data to appear in object program in a different order from the corresponding source statements. Program blocks refers to the segments of code that are rearranged within a single object program unit. The assembler directive USE indicates which portion of source program belongs to various blocks. At beginning, program statements are assumed to be of default block. If no USE statement is used then, entire program belongs to single block. Program block can contain several segments of source program. The assembler rearranges the segments to gather the pieces of each block together. These blocks will be assigned addresses in object program in the order in which they were first begun in source program.

|     |       |       |        |
|-----|-------|-------|--------|
| eg: | COPY  | START | O      |
|     | FIRST | STL   | RETADR |
|     | CLoop | JSUB  |        |
|     |       | :     |        |
|     |       | JSUB  | WRREC  |
|     |       | :     |        |
|     |       | USE   |        |
|     | RDREC | CLEAR | X      |
|     |       | CLEAR | A      |
|     |       | :     |        |
|     |       | CSE   |        |
|     | WRREC | CLEAR | X      |

Here, there are different program blocks RDREC and WRREC to read and write record into buffer.