



1. Explain the levels of the programming language

↳ Answer:

Programming language can be categorized into these three different levels.

(a) High Level Language

- Designed to be more human-readable and programmer-friendly.
- Provides more abstraction and encapsulation.
- Usually platform-independent, requiring an interpreter or compiler.
- Example:

C, C++, Java etc.

(b) Assembly level language

- consists of binary code and mnemonic instructions representing specific operations.
- Platform dependent.
- Slower than machine language.
- Assembler converts into machine language

(c) Machine level language

- Also called binary language because they contain only 0s and 1s.
- Have the lowest level of abstraction.
- Difficult to read, write and debug.
- Faster execution time.

2. Explain assembly language and compiling programming languages process with suitable examples.

Answer:

### Assembly language process

- Assembling converts source program into object program if syntactically correct and generates an intermediate .obj file or module.
- Assembler is used in assembling process which converts assembly code into the machine code.
- GAS, GNU is an example of assembler.



Source Program      One by one  
Passes.      Object Program

### The Assembly process

- Assembling the source code into an object code.
- Linking the object file with other modules or libraries into an executable program.
- Loading the program into memory.
- Running the program.



Fig: Assembly Language Process

Example:

| Mnemonics | Operands |
|-----------|----------|
| MOV       | AX, BX   |

The assembler reads a line like this one from the source code files and writes the equivalent machine instructions to an object code files.

↓  
[ 8BH 0C8H ]

## Compiling Process

- The compilation is a process of converting the source code into an object code.
- Stages of compilation
  - lexical analysis
  - symbol table construction
  - syntax analysis
  - semantic analysis
  - code generation
  - optimization
- Compilation makes sure that the source code follows syntax.
- Compilation error will be given if any code doesn't follow syntax.
- It converts whole code into machine language at a time.



Fig: Compilation Process:

- Eg of purely compiled language are C, C++, Erlang, Rust, Haskell etc.

③ Explain different types of addressing modes with examples.

Answer:

It is the way in which operands are specified in an instruction. Types of addressing modes are:

a) Direct Mode

- Contains memory addresses that CPU accesses.
- The 16-bit effective address of the data is part of the instruction.

Example:

ADD AL, [0801]

b) Indirect Mode

- The address in the instruction is not the address of operand, rather it contains the address of memory location where operand resides.

Example:

LDAC (5)

c) Register Direct and Register Indirect Mode

- Works same as direct and indirect modes, except they do not specify memory address, they specify a register.

Example:

LDAC (R) or

LDAC @ R or

LDAC R

(d) Immediate Mode

- Operand specified is not an address, it is actual data to be stored used.

Example:

LDAC #5

(e) Implied Mode

- Operand is specified itself in the instruction.

Example:

CLAC (Clears the Accumulator)

(f) Relative Mode

- Operand itself specified is an offset, not the actual address which is added to the content of the program counter register to generate required address.

Example:

LDAC \$5

(If next instruction is at location 12, the instruction reads data from  $12+5=17$  location and stores in accumulator.)

(g) Index and Base address Mode

- Index mode work like relative mode, except the address supplied by instruction is added to the content of index register.

Example:

Index Register  
↓

LDAC 5(X); Reads from  $10+5=15$

- Base mode is same as index mode except index register is replaced by base register.

Q) What do you mean by instruction set in the processor? How are they different from micro instructions? Explain the machine cycles generated with the instruction cycles with example.

Ans:

### Instruction Set

- An instruction set refers to the collection of instructions that processor can understand and execute.
- It defines the operation that the processor can perform such as arithmetic, logical and control operations.

### Micro Instructions

- Micro instructions are the lower level instructions that directly control the internal components of a processor.

### Differences

- ↳ Instruction set define the higher level instructions a processor can execute while micro instructions control the hardware components and execute the instruction at a lower level of abstraction.
- ↳ Instruction set defines the interface between the processor's hardware and software whereas micro instructions controls the hardware implementation of the processor.

## Instruction Machine Cycle



Fig :

→ Instruction cycle is the procedure a microprocessor goes through to process an instruction.

Suppose we have the instruction:

"INC R1"

### a. Fetch

- Microprocessor fetches the instruction from memory.
- PC holds the address of the next instruction to be fetched.
- CPU retrieves the address from PC and outputs it onto the address bus.
- Then memory subsystem places the corresponding instruction into the system data bus.
- The CPU reads the instruction code from the system data bus, which in this case is "INC R1".

b. Decode

- . The CPU decodes the instruction, determining that it is an increment operation.

c. Execute

- . The CPU performs the operation necessary to execute the instruction.
- . It retrieves the value from register R1.
- . The CPU increments the value by 1.
- . The resulting value is stored back in register R1.

⑤

Write about ISA. What are the factors to be considered while designing ISA ? Explain.



Answer:

- Instruction Set Architecture
- Crucial computer system that defines the interface between hardware and software.
- It provides the information needed to interact with the microprocessor.

→ Factors to be considered while designing ISA architecture

⑥ What should the instruction set and its processor be able to do ?



The ISA acts as an interface between the hardware and software, specifying both what the processor is capable of doing as well as how it gets done.

(b)

Whether the instruction set is complete or not ? (Completeness)

For a processor for general purpose computing it requires rich ISA, large instruction set, many registers. So it must be complete.

#### ④ Orthogonality

A good ISA should provide a rich set of independent and flexible instructions that can be combined to perform complex operations.

#### ⑤ Support for High-level language

It must provide instructions that map directly to high level language constructs.

#### ⑥ Are interrupts needed?

Many tasks in the computer can be performed efficiently if the interrupts are incorporated. So, designer must consider the interrupts.

#### ⑦ Types and sizes of the data

While designing ISA, designer must consider what type and size of data will the microprocessor deal with.

Some other factors to be considered are:

- Simplicity
- Code Density
- Forward Compatibility
- Scalability
- Performance
- Backward Compatibility
- Security

⑥ Explain basic computer organization with a block diagram.

Answer:



Fig: Basic CPU Organization

The block diagram of basic CPU organization consists of three main components:

- ① CPU
- ② Memory Subsystem
- ③ I/O Subsystem
- ④ System Buses

#### ① CPU Operations

Here, the CPU perform 4 operations:

##### i) Fetch

Retrieving an instruction from program memory.

(Q) Design the 1024 dimensional chip organization of 16x8 ROM chips.

(i) Decode

Fetched instruction is broken into parts.

(ii) Execution

The decoded instruction is then executed.

(iii) Store

CPU writes back the result of execution to the computer.

(Q) System Buses

1. A bus is a set of wires.

There are three types of bus:

1) Control Bus

The control bus carries the control signals which is generated by CU of the CPU.

2) Control bus signal is used for controlling and coordinating the various activities across the computer.

iii) Address Bus

It connects the CPU and another peripheral and carries only the memory address.

The address bus carries 8-bit data at a time, the CPU could address only ( $2^8$ ) i.e. 256 bytes of RAM.

### iii) Data Bus

- ↳ Bidirectional.
- ↳ Transfers data from one location to another across the computer.
- ↳ It may be 16 bit or 32 bit data bus.

### (3) Memory Subsystem

- ↳ The memory subsystem is made up of hardware and software components.
- ↳ It consists of RAM, ROM where there is Chip enable (CE) and Output enable (OE) logic exists.

### (4) I/O Devices

It consists

#### i) Input Device

- ↳ It consists of Tri-state buffer and Enable logic.



## iii) Output Device

- It consist of Register and enable logic.



- ① Explain the linear chip organization with an example.

→ Answer:

### Linear chip organization

It refers to the arrangement of components on a chip or integrated circuit in a linear fashion to create a function unit or subsystem.

#### Example:

Let us consider an  $8 \times 2$  ROM chips.  
Then:

- Comparing with  $2^n \times m$  i.e  $2^3 \times 2$   
 $\therefore$  16-bit
  - ↳ No. of Address input = 3 = n
  - ↳ No. of data output = 2 = m
  - ↳ 16 bits internal storage arranged as eight 2-bit locations.
- If  $CE = 0$ , decoder is disabled and no location is selected.
- If  $CE = 1$  and  $OE = 1$ , tri-state buffer for that location cell is enabled and data is output from the chip.
- ↳ The size of decoder is  $3 \times 8$  for an  $8 \times 2$  ROM chips.



(8)

What do you understand by high order interleaving and low order interleaving? Explain with an example.



Answer:

### High Order Interleaving

- In high order interleaving, the most significant bits of the address selects the memory chip.
- The least significant bits are sent as addresses to each chips.
- One problem is that consecutive addresses tends to be in the same chip.

#### Example:

Let us consider  $16 \times 2$  memory subsystem constructed from two  $8 \times 2$  ROM chips.

Now,

For,  $16 \times 2$  memory subsystem:

- No of address inputs = 4
- No of data lines = 2

So,

For  $8 \times 2$  memory subsystem:

No of address input = 3

No of data lines = 2

For High order interleaving:

$A_3$  selects memory chip.

$A_2, A_1, A_0$  are sent as address bits.



Fig: High order interleaving

## Low order interleaving

- In the low order interleaving, the least significant bits of the address select the memory chips.
- The most significant bits are sent as address to each chip.
- In this, consecutive memory addresses are in different memory modules.

Example:

Let us consider 16Y2 memory subsystem constructed using two 8Y2 ROM chips. Then,

↳ For 16Y2 memory subsystem:

- no. of address inputs = 4
- no. of data lines = 2

And,

↳ For 8Y2 ROM chips,

- no. of address inputs = 3
- no. of data lines = 2

↳ For, Memory Address A<sub>3</sub> A<sub>2</sub> A<sub>1</sub> A<sub>0</sub>,

A<sub>0</sub> selects memory chips.

A<sub>3</sub> A<sub>2</sub> A<sub>1</sub> are sent as address.



Fig: Low Order InterLeaving

9

Design two dimensional chip organization of  $16 \times 2$  ROM chips.

→

Answer:

For  $16 \times 2$  ROM chips,

No of address inputs = 4 (say  $A_3 A_2 A_1 A_0$ )

No of data lines = 2 (say  $D_0, D_1$ )

For  $16 \times 2$  memory chip organization  
2-D arrangement is given as:

| $A_3$ | $A_2$ | $A_1$ | $A_0$ |
|-------|-------|-------|-------|
| { 0   | 0     | 0 } 1 | 0     |
| { 0   | 0     | 0 } 1 | 1     |
| { 0   | 0     | 1 } 1 | 0     |
| { 0   | 0     | 1 } 1 | 1     |
| { 0   | 1     | 0 } 1 | 0     |
| { 0   | 1     | 0 } 1 | 1     |
| { 0   | 1     | 1 } 1 | 0     |
| { 0   | 1     | 1 } 1 | 1     |
| { 1   | 0     | 0 } 1 | 0     |
| { 1   | 0     | 0 } 1 | 1     |
| { 1   | 0     | 1 } 1 | 0     |
| { 1   | 0     | 1 } 1 | 1     |
| { 1   | 1     | 0 } 1 | 0     |
| { 1   | 1     | 0 } 1 | 1     |
| { 1   | 1     | 1 } 1 | 0     |
| { 1   | 1     | 1 } 1 | 1     |

→ In the above arrangement, for 3 higher order bits the chip value is same and low order is 0, 1 alternatively. Then,



(11) Design 8x4 memory subsystem at address 80H constructed using 8x2 ROM.

→ Answer:

For 8x4 Memory Subsystem,

No. of Address input = 3

No. of data lines = 4

For 8x2 ROM,

No. of address input = 3

No. of data lines = 2

Then,

Starting Address given = 80H  
So,

1 000 0b00

Used for CE Logic.      Used for the memory selection



(12)

A computer is connected with multiple input and output devices to the CPU through I/O processor via a common bus. Explain the memory mapped I/O and isolated mapped I/O.



Answer:

### Memory Mapped I/O

In memory mapped I/O, I/O devices are mapped to the memory space of the microprocessor.



Same instruction can control both I/O and memory.



Less efficient due to same buses.



Smaller in size due to less buses.



Simpler logic is used as I/O is also treated as memory only.



Special instruction such as LDA addr, STA addr, LDAX YP, MOV R,M etc are used.

### • Isolated Mapped I/O

- ↳ In Isolated Mapped I/O, Input/Output devices are mapped to separate I/O address space that is different from the memory address space.
- ↳ Separate instruction control read and write operation in I/O and memory.
- ↳ More efficient due to <sup>separate</sup> more buses.
- ↳ Larger in size due to more buses.
- ↳ It is complex due to separate logic is used for controlling both memory and I/O.
- ↳ Limited instruction such as IN OUT.

(13) Write about IO system organization and interfacing for input device and output device with necessary diagram.

↳ Answer:

(a) Input Device

or With its interface



↳ With the enable logic for the tri-state buffer



Explanation: The data from the input device goes to the tri-state buffer.

↳ When the values on the address bus and control bvs are correct, the buffers are enabled and data passes on the data bus.

↳ CPU, then can read these data.

↳ The key to these this design is enable logic.

• For the input device, the read signal should be asserted.

• Fig(b) shows the enable logic at address 11110000 with 8-bit address and control signals RD and IO/M.

### (B) Output Device

a> With its interface



b> The load logic for the Register



#### Explanation

- ↳ For the interface circuit for an output device, the tri-state is replaced by register.
- ↳ The tri-state buffers are used in input device make sure that no more than one device write data to the bus at any time.
- ↳ Since, the output devices read data from the bus, they do not need buffers so that data can be made available to all output devices.

(C) A bidirectional I/O device with its interface and enable/load logic.



(14)

Generate a load logic for an output device at CFH. Assume that the system is being operated in isolated mode.

L →

Answer:

At CFH,

$$CFH = 1100\ 1111$$

$$A_7\ A_6\ A_5\ A_4\ A_3\ A_2\ A_1\ A_0$$

Now,

The Load logic for an output device at CFH is.



- (15) There is an Input device at address 00H and an output device at 20H.  
Illustrate the design with necessary logic.

→

Answer:

Address of input device = 00H

= 0000 0000

A<sub>7</sub>A<sub>6</sub>A<sub>5</sub>A<sub>4</sub> A<sub>3</sub>A<sub>2</sub>A<sub>1</sub>A<sub>0</sub>

Address of output device = 20H

= 0010 0000

A<sub>7</sub>A<sub>6</sub>A<sub>5</sub>A<sub>4</sub> A<sub>3</sub>A<sub>2</sub>A<sub>1</sub>A<sub>0</sub>



(18)

A computer has a CPU with an 8 bit address bus and 16 bit data bus. The computer uses isolated IO. It has  $64 \times 16$  ROM at  $00H$  constructed using two  $82 \times 16$  ROM chips. It has  $32 \times 16$  of RAM at  $COH$ . The system has an input device at  $15H$  and the output device at  $75H$ . Show the design for the required system including all necessary logic.



Answer:

For  $64 \times 16$  of ROM, ( $2^6 \times 16$ )

No of address input = 6

No of data lines = 16

$00H = 0\ 0\ 0\ 0\ 0\ 0\ 0$

A<sub>7</sub> A<sub>6</sub> A<sub>5</sub> A<sub>4</sub> A<sub>3</sub> A<sub>2</sub> A<sub>1</sub> A<sub>0</sub>

For  $82 \times 16$  ROM and RAM

No. of address input = 5

No of data lines = 16

For RAM,

$COH = 1\ 1\ 0\ 0\ 0\ 0\ 0\ 0$

A<sub>7</sub> A<sub>6</sub> A<sub>5</sub> A<sub>4</sub> A<sub>3</sub> A<sub>2</sub> A<sub>1</sub> A<sub>0</sub>

For an Input and Output Device,

For input device =  $17H = [0\ 0\ 0\ 1\ 0\ 1\ 1]$

For output device =  $B5 = [1\ 0\ 1\ 1\ 0\ 1\ 0\ 1]$

A<sub>7</sub> A<sub>6</sub> A<sub>5</sub> A<sub>4</sub> A<sub>3</sub> A<sub>2</sub> A<sub>1</sub> A<sub>0</sub>



17. A computer system has an 8-bit data bus and 8 bit address bus. The system operates in isolated I/O mode. It has 64 byte of ROM at 00H, constructed using two 82 byte of ROM. It also has RAM of 128 bytes. The RAM is constructed using  $128 \times 4$  RAM chips at address 80H. The system also has an I/O device at 7EH. Show the necessary design for the system.

→ Answer:

For  $64 \times 8$  ROM,

$$n = 6, m = 8$$

$n$  = Address line

$m$  = data lines

. For  $32 \times 8$  ROM,

$$n = 5, m = 8$$

For  $128 \times 8$  RAM,

$$n = 7, m = 8$$

For  $128 \times 4$  RAM,

$$n = 7, m = 4$$

For ROM:

$$\text{Address} = 00H = 0000\ 0000 \quad A_7\ A_6\ A_5\ A_4\ A_3\ A_2\ A_1\ A_0$$

For RAM,

$$\text{Address} = 80H = 1000\ 0000 \quad A_7\ A_6\ A_5\ A_4\ A_3\ A_2\ A_1\ A_0$$

For I/O Device:

$$\text{Address} = 7EH = 01\ 01\ 1110 \quad A_7\ A_6\ A_5\ A_4\ A_3\ A_2\ A_1\ A_0$$



(19) A computer system with an 8-bit address bus using Isolated I/O. It has  $16 \times 8$  ROM starting at the address  $00H$  constructed using  $8 \times 8$  chips.  $64 \times 8$  of RAM starting  $80H$  constructed using  $64 \times 4$  chips. There is an I/O device at  $40H$ .

→ Answer:

Same.

20, 21, 22 → Some.

(23) Design an  $8 \times 4$  ROM chip using  $4 \times 4$  ROM chips. Illustrate using low level interleaving.

→ Answer:

For  $8 \times 4$  ROM chip-

No. of address input = 3

No. of data lines = 4

For  $4 \times 4$  ROM chip,

No. of address input = 2

No. of data lines = 4



(25) What do you mean by RTL? In how many ways RTL are implemented. Explain with an example.

↳ Answer:

- RTL stands for Register Transfer Language.
- It is a symbolic representation of notation used to specify the sequence of the micro-operations.
- Notation used by RTL is: conditions: conditions: micro-operations

↳ Example: Consider that, the transfer  $X \leftarrow Y$  occurs when control signal  $\alpha$  is high in RTL.

$$\alpha : X \leftarrow Y$$

### RTL Implementation

@ Direct Connection



↳ In this method, the components in the designs are connected directly to each other.

↳ Each component has its own individual connections to other components forming a point-to-point connection.

### b) Bus Connection.



- ↳ A bus is a shared communication pathway that connects multiple component in design.
- ↳ Bus acts as a communication medium, allowing the components to transmit and receive data.

(26) List out the arithmetic and logical microoperations and illustrate the implementation of each of them.

→ Answer:

| Operations | Examples                                         |
|------------|--------------------------------------------------|
| Add        | $X \leftarrow X + Y$                             |
| Subtract   | $X \leftarrow X - Y$ ; $X \leftarrow X + Y' + 1$ |
| Increment  | $X \leftarrow X + 1$                             |
| Decrement  | $X \leftarrow X - 1$                             |
| AND        | $X \leftarrow X \wedge Y$ or $X \leftarrow X Y$  |
| OR         | $X \leftarrow X \vee Y$                          |
| XOR        | $X \leftarrow X \oplus Y$                        |
| NOT        | $X \leftarrow X'$                                |

### Implementation

a) Addition ( $d: X \leftarrow X + Y$ )



④ Subtraction: ( $d \rightarrow x - y$  or  $x \leftarrow x + y + 1$ )



⑤ Increment & Decrement

$\alpha$ :  $x \leftarrow x + 1$ ,  $\beta$ :  $x \leftarrow x - 1$



⑥ AND  $\alpha$ :  $x \leftarrow x \wedge y$  or  $\alpha$ :  $x \leftarrow x.y$



(e) XOR



(f) OR  $\alpha: x \leftarrow x \vee y$



(g) NOT:  $\alpha \leftarrow \alpha: x \leftarrow \bar{x}$



(27) Draw the state diagram of the modulo 6 counter and implement it using registers.

→ Answer:

### State Table of Modulo-6 Counter

| Present State  | U | Next State     | C | V <sub>2</sub> V <sub>1</sub> V <sub>0</sub> |
|----------------|---|----------------|---|----------------------------------------------|
| S <sub>0</sub> | 0 | S <sub>0</sub> | 1 | 0 0 0                                        |
| S <sub>0</sub> | 1 | S <sub>1</sub> | 0 | 0 0 1                                        |
| S <sub>1</sub> | 0 | S <sub>1</sub> | 0 | 0 0 1                                        |
| S <sub>1</sub> | 1 | S <sub>2</sub> | 0 | 0 1 0                                        |
| S <sub>2</sub> | 0 | S <sub>2</sub> | 0 | 0 1 0                                        |
| S <sub>2</sub> | 1 | S <sub>3</sub> | 0 | 0 1 1                                        |
| S <sub>3</sub> | 0 | S <sub>3</sub> | 0 | 0 1 1                                        |
| S <sub>3</sub> | 1 | S <sub>4</sub> | 0 | 1 0 0                                        |
| S <sub>4</sub> | 0 | S <sub>4</sub> | 0 | 1 0 0                                        |
| S <sub>4</sub> | 1 | S <sub>5</sub> | 0 | 1 0 1                                        |
| S <sub>5</sub> | 0 | S <sub>5</sub> | 0 | 1 0 1                                        |
| S <sub>5</sub> | 1 | S <sub>6</sub> | 1 | 0 0 0                                        |
| S <sub>6</sub> | X | S <sub>6</sub> | 1 | 0 0 0                                        |
| S <sub>7</sub> | X | S <sub>0</sub> | 1 | 0 0 0                                        |

Here:

States = S<sub>1</sub>, S<sub>2</sub>, S<sub>3</sub>, S<sub>4</sub>, S<sub>5</sub>, S<sub>6</sub>, S<sub>7</sub>

States of counter = V<sub>2</sub>V<sub>1</sub>V<sub>0</sub>

U is used to control the counter.

{ Rough:

→ Here, when the counter's value is '000' to '100' and its 'up' signal 'U' is asserted, the output of the counter is incremented. This condition can be expressed as (S<sub>0</sub>+S<sub>1</sub>+S<sub>2</sub>+S<sub>3</sub>+S<sub>4</sub>) U.

↳ Under this condition, C is also set to '0'.

↳ Under V to represent the value  $V_2V_1V_0$ , these two actions can be expressed as:

$$V \leftarrow V+1, C \leftarrow 0$$

⇒ The resulting RTL is:

$$(S_0 + S_1 + S_2 + S_3 + S_4) U : V \leftarrow V+1, C \leftarrow 0$$

Continuing with counter in state  $S_5$  ( $V = 101$ ) and  $U = 1$ , the counter must be reset to 000 and C must be set to 1.

$$S_5 U : V \leftarrow 0, C \leftarrow 1.$$

This leaves only the condition

$$(S_0 + S_1 + S_2 + S_3 + S_4 + S_5) \bar{U}$$

unaccounted.

Since  $S_5 U$  and  $S_0 + S_7$  trigger the same microoperation, they can be combined.  $\therefore \{$

Thus the final behaviour of the modulo 6 counter can be expressed by:

$$(S_0 + S_1 + S_2 + S_3 + S_4) U : V \leftarrow V+1, C \leftarrow 0$$

$$(S_5 U + S_6 + S_7) : V \leftarrow 0, C \leftarrow 1.$$

↳ State diagram for the modulo 6 counter:



↳ Design:



(28)

Draw the state diagram of the modulo 6 counter and implement it using regt<sup>t</sup> a 8 bit counter.

→ Answer:

State Table → Same.

State Diagram → same.

Behaviour:

$$\text{clear: } (\bar{V}_1 + (V_1 + V_0) U) \\ = (\bar{V}_2 + \bar{V}_1 \cdot \bar{V}_0) U$$

$$\text{Load: } (V_2 \cdot V_1 + V_2 V_0 U) : V \leftarrow 0, C \leftarrow 1$$

→ Design



Q. Explain different types of shift micro operations with examples.

Ans:

These are four types of shift microoperations:

- a. Arithmetic Shift
- b. Decimal Shift
- c. Linear Shift
- d. Circular Shift.

### a. Arithmetic Shift

It work with number that have signed formats.

Leftmost bit is sign bit.

#### i) Arithmetic Shift Left (ashl)

- All bits are shifted to left except the bit at the beginning, which is the sign bit and is discarded.
- Bit 0 is loaded into last position.

Eg:



#### ii) Arithmetic Shift Right (ashr)

- Each bit is moved to the right one by one and the least significant (LSB) bit is rejected and the most significant bit (MSB) is filled with the value of the previous MSB.

Eg:



### (b) Decimal Shift

- For a BCD representation, each decimal digit is represented by 4 bits similar to linear shift but 11 shifts (one digit) inside of one bit.

#### ① Decimal Shift Left (dshl)

$$A_1 \ A_0 \rightarrow A_0 \ 0000$$

Eg:

$$\begin{array}{r} 1101 \ 0011 \\ \downarrow \\ A_0 \ 0000 \end{array}$$

#### ② Decimal Shift Right (dshr)

Eg:

$$A_1 \ A_0$$

$$1101 \ 0011$$



$$0000 \ A_1$$

### (c) Linear Shift

#### ① Linear shift left (shi)

- Shift all the bits to left.

- MSB is discarded at beginning and we load zero at LSB, a vacant position.



## 11 Linear Shift Right (shr)

- ↳ Shifts all the bits at right.
- ↳ Bit at last position is discarded.
- ↳ The vacant position at beginning is padded.

Eg example:



## (d) Circular Shift

### i) Circular shift left (clsl)

- ↳ All bits are shifted to left and the bit at the beginning is circulated back at the end position.



### ii) Circular Shift Right (ccir)

- ↳ All bits are shifted right and the bit at last is circulated at the 1st position.

Eg:



(30)

Perform eight different shift operations  
on  $X = 110101010110$



Answer:  $\downarrow 110101010110$

shd = 1010 1010 1100

shr = 0101 0101 0110 0110 1010 10110

cil = 1010 1010 1101

cir = 0110 1010 1011

ashl = 1010 1010 1100

ashlr = 1101 1010 1011

dshd = 1011 0000 0000

dshr = 0000 0000 1101

(31)

Repeat the above on 1010 1100



Answer: 1010 1100

shd = 0101 1000

shr = 10101 0110

cil = 0101 1001

cir = 0101 0110

ashd = 0101 1001

ashr = 1101 0110

dshd = 1100 0000

dshr = 0000 1010

(32) Write about VHDL code and explain different sections of VHDL with its advantages and disadvantages.

→ Answer:

### VHDL

- Very High-speed Integrated Circuit Hardware Description Language.
  - Programming language used to model the digital system by dataflow, behavioural and structural style of modeling.
- ↳ VHDL is used for following purposes:
- For describing hardware and for the simulation of hardware.
  - As a modeling language and for early performance estimation of system architecture.

↳ Sections of VHDL

@ Entity Declaration

- It defines the names, input-output, signals and modes of a hardware module.

Syntax :-

```
entity entity-name is  
    port declaration;  
end entity-name;
```

In port declarations, reserved words are:

in :- port can be Read

out :- port can be written

inout:- can be read and written

Buffer:- port can be read and written,  
it can have only one source.

### (b) Architecture

- Architecture can be described using structural, dataflow, behavioral and mixed style.

Syntax:-

```
architecture architecture-name of entity-name;
architecture-declarative-part;
begin
    statements;
end architecture-name;
```

- ↳ A built-in or user defined signal type  
eg:- bit, characters, Boolean, std-logic etc.

### Advantages

- i. It supports various design & methodologies like Top-down and Bottom-up approach.
- ii. It supports all CAD tools.
- iii. It provides tight coupling to low levels of design.
- iv) Supports multi-level abstraction.

## Disadvantages

- i) It requires specific knowledge of the structure and syntax of the language.
- ii) More difficult to visualize and troubleshoot a design.
- iii) Some VHDL programme can't be synthesized.
- iv) It is more difficult to learn.

(32)

Write down VHDL code for the following:

a.

AND gate



b

library ieee;

use ieee.std\_logic\_1164.all;

entity AND\_Gate is

Port (in1, in2 : in std\_logic;

out1 : out std\_logic);

end AND\_Gate;

architecture behavioral\_and of AND\_GATE is

begin

out1 <= in1 and in2;

end behavioral\_and;

b. OR Gate

library ieee;

use ieee.std\_logic\_1164.all;

entity OR\_GATE is

Port (in1, in2 : in std\_logic;

out1 : out std\_logic);

end OR\_GATE;

architecture behavioral\_or of OR\_GATE is

begin

out1 <= in1 or in2;

end behavioral\_or;



① NOT gate

$$A \rightarrow \bar{A} \quad Y = \bar{A}$$

↳ library ieee;

use ieee.std\_logic\_1164.all;

entity NOT\_GATE is

Port ( A: in std\_logic;

Y: out std\_logic );

end NOT\_GATE;

architecture behavioral-NOT of NOT\_GATE is

begin

Y <= not(A);

end behavioral-NOT;

(d) NAND Gate



↳ library ieee;

use ieee.std\_logic\_1164.all;

entity NAND\_GATE is

Port ( in1, in2 : in std\_logic;

out1 : out std\_logic );

end NAND\_GATE;

architecture behavioral-NAND of NAND\_GATE

begin

out1 <= in1 nand in2 ;

end behavioral-NAND ;

## ② NOR gate

$$a \quad b \quad c = \overline{a+b}$$

L →

library ieee;

use ieee.std\_logic\_1164.all;

entity NOR\_GATE is

port (a, b : in std\_logic;

c : out std\_logic);

end NOR\_GATE;

architecture behavioral\_NOR of NOR\_GATE is

begin

c <= a nor b;

end behavioral\_NOR;

## (P) ③ XOR GATE

L →

XOR GATE

$$a \quad b \quad c = A \oplus B$$

library ieee;

use ieee.std\_logic\_1164.all;

entity XOR\_GATE is

port (A, B : in std\_logic;

c : out std\_logic);

end XOR\_GATE;

architecture behavioral-XOR of XOR-GATE is  
begin

$$c \leftarrow A \text{ xor } B;$$

end behavioral-XOR;

(g) XNOR GATE



library ieee;  
use ieee.std\_logic\_1164.all;

entity XNOR-GATE is  
Port (a, b : in std\_logic;  
c : out std\_logic);  
end XNOR-GATE;

architecture behavioral-XNOR of XNOR-GATE is

begin

$$c \leftarrow a \text{ xnor } b$$

end behavioral-XNOR;

### h. Half Adder



```
library ieee;  
use ieee.std_logic_1164.all;
```

```
entity half-adder is  
Port ( a,b: in std_logic;  
sum,carry: out std_logic );  
end half-adder;
```

```
architecture behavioral-half of half-adder is  
begin  
sum <= A xor B;  
carry <= A and B;  
end behavioral-half;
```

### i. Full Adder



```
library ieee;  
use ieee.std_logic_1164.all;
```

entity full-adder is

```
Port (a,b,c : in std_logic;  
      sum,carry : out std_logic);  
end full-adder;
```

architecture behavioral-full of full-adder is  
begin

```
sum <= (A xor B) xor C;  
carry <= ((a and b) or (b and c) or (a and c));  
end behavioral-full;
```

jj) Half Subtractor



library ieee;

```
use ieee.std_logic_1164.all;
```

entity half-subtractor is

```
Port (A,B : in std_logic;  
      Difference,Borrow : out std_logic);  
end half-subtractor;
```

architecture h-subtractor of half-subtractor is

begin

```
Difference <= A xor B;  
Borrow <= ((not A) and B);  
end h-subtractor;
```

## k) Full subtractor



```

library ieee;
use ieee.std_logic_1164.all;
entity fu
entity full-sub is
Port( a,b,c : in std_logic;
      Diff,Borrow : out std_logic);
end full-sub;

```

Architecture full of full-sub is

begin

$$\text{Diff} \Leftarrow (a \text{ nor } b) \text{ nor } c$$

$$\text{Borrow} \Leftarrow (a \text{ xor } b)$$

$$\text{Borrow} \Leftarrow (((\text{not}(a \text{ xor } b)) \text{ and } c) \text{ or } (\text{not}(a) \text{ and } b))$$

end full;

(m) 4x1 Multiplexer

library ieee;  
use ieee.std\_logic\_1164.all;

entity MUX is

Port (S1, S0, D0, D1, D2, D3 : in std\_logic;  
Y : out std\_logic);

end MUX

architecture mun of MUX is

begin

$$\begin{aligned} Y &= ((\text{not } S_0) \text{ and } (\text{not } S_1) \text{ and } D_0) \text{ or} \\ &\quad (S_0 \text{ and } (\text{not } S_1) \text{ and } D_1) \text{ or} \\ &\quad ((\text{not } S_0) \text{ and } S_1 \text{ and } D_2) \text{ or} \\ &\quad (S_0 \text{ and } S_1 \text{ and } D_3); \end{aligned}$$

end mun;

(n) 1x4 demultiplexer

library ieee;  
use ieee.std\_logic\_1164.all;

entity DEMUX is

Port (S1, S0, D : in std\_logic;  
Y0, Y1, Y2, Y3 : out std\_logic);

end MUX;

architecture demun of DEMUX is

begin

$$Y_0 \leftarrow ((\text{not } S_0) \text{ and } (\text{not } S_1) \text{ and } D);$$

$$Y_1 \leftarrow ((\text{not } S_0) \text{ and } S_1 \text{ and } D);$$

$$Y_2 \leftarrow (S_0 \text{ and } (\text{not } S_1) \text{ and } D);$$

$$Y_3 \leftarrow (S_0 \text{ and } S_1 \text{ and } D);$$

end demun;

m) 8x3 encoder

↳ Library ieee;

use ieee.std\_logic\_1164.all;

entity encode is

Port (i0, i1, i2, i8, i4, i6, i7 : in std\_logic;

o0, o1, o2 : out std\_logic);

end encode;

architecture encoder of encode is

begin

o0 <= i4 or i5 or i6 or i7;

o1 <= i2 or i8 or i6 or i7;

o2 <= i1 or i3 or i5 or i7;

end encoder;

n) 3x8 decoder

Library ieee;

use ieee.std\_logic\_1164.all;

entity decode is

Port (i0, i1, i2 : in std\_logic;

o0, o1, o2, o3, o4, o5, o6, o7 : out std\_logic);

end decode

architecture decoder of decode is

begin

o0 <= (not i0) and not(i1) and not(i2);

o1 <= (not i0) and (not i1) and i2;

o2 <= (not i0) and i1 and (not i2);

o3 <= (not i0) and i1 and i2;

o4 <= i0 and (not i1) and (not i2);

o5 <= i0 and (not i1) and i2;

o6 <= i0 and i1 and (not i2);

o7 <= i0 and i1 and i2;

end decoder

② SR flip-flop

library ieee;  
use ieee std\_logic\_1164.all;

entity SR is  
Port ( s, r, clk : in std-logic ;  
q, qb : inout std-logic );  
end SR ;

architecture data of SR is  
signal s1, r1 : std-logic ;  
begin  
s1 <= s nand clk ;  
r1 <= r nand clk ;  
q <= s1 nand qb ;  
qb <= r1 nand q ;  
end data ;

## ① JK Flipflop

Library ieee;  
use ieee.std\_logic\_1164.all;

entity JK is

Port ( J, K, CLK, reset : in std\_logic;  
q, qbar : out std\_logic);

end JK;

Architecture data of JK is

Signal S1, S2, S3, S4 : std\_logic;

begin

S1 <= not (J and CLK and qbar);

S2 <= not K and CLK and q);

S3 <= S1 nand q-bar;

S4 <= S2 nand q;

q <= S3 and (not (reset));

qbar <= S4 and reset;

end data;

## ⑥ $\leftrightarrow$ T flip flop.

library ieee;  
use ieee.std\_logic\_1164.all;

```
entity Tflip is  
    port (T, clk, clr: in std_logic;  
          Q: out std_logic);  
end Tflip;
```

architecture T-flipflop of T-flip is

```
signal temp: std_logic;  
begin  
    process (clk, clr)  
        begin  
            if clr = '1' then  
                temp := '0';  
            else if (clk 'event' and clk = '1') then  
                if T = '0' then  
                    temp := temp;  
                else if T = '1' then  
                    temp := not (temp);  
                end if;  
            end if;  
        end process;  
        Q := temp;  
    end T-flipflop;
```

### 5. D - flip flop

```
library ieee;
use ieee.std_logic_1164.all;

entity D-flip
    Port ( d, clk : in std_logic;
           q, qb : inout std_logic);
end D-flip;
```

architecture data of D-flip is

```
signal d1, s1, r1 : std_logic;
```

begin

```
s1 <= d nand clk;
```

```
d <= d nand d;
```

```
r1 <= d nand d;
```

```
q <= s1 nand qb;
```

```
qb <= r1 nand q;
```

end data;

84) Write down the VHDL code for Modulo 6 counter using a low level of abstraction.

↳ library ieee;  
use ieee.std\_logic\_1164.all;

entity mod6 is  
Port (U, clk : in std-logic;  
q2, q1, q0 : buffer std-logic;  
V2, V1, V0, C : out std-logic);  
end mod6;

architecture modulo6 of mod6 is  
begin ect-mod6: process (q2, q1, q0, U, clk)  
begin if rising-edge(clk) then  
q2 <= (q2 and (not q1) and (not q0)) or  
(q2 and (not q1) and (not U)) or  
(not q2) and q1 and q0 and U);  
  
q1 <= ((not q2) and q1 and (not q0)) or  
((not q2) and q1 and (not U)) or  
((not q2) and (not q1) and q0 and U);  
  
q0 <= ((not q2) and (not q0) and U) or  
((not q1) and (not q0) and U) or  
((not q2) and q0 and (not U)) or  
((not q1) and q0 and (not U));  
end if;  
V2 <= q2;  
V1 <= q1;  
V0 <= (q2 and q1) or q0;

```
C<= not (q2 or q1 or q0);  
end process cct-mod6;  
end modulo6;
```

35)

~~20~~ Write a VHDL code for the following combinational circuits:

a.  $F = AB + \bar{A}\bar{B}$

b. library ieee;  
use ieee.std\_logic\_1164.all;

entity circuit is

Port (A, B, C : in std\_logic;  
Y : out std\_logic);  
end circuit;

architecture data of ~~circuit~~ circuit is

begin

$Y<= (A \text{ and } B) \text{ or } (\text{not } A) \text{ and } (\text{not } B);$   
end data;

b.  $F(x,y,z) = \Sigma(1,3,4,6)$

c.  $F(A,B,C) = \Sigma(1,3,6,7)$

d.  $F(A,B,C) = \Pi(0,5,7)$

↳ Truth table:

|   | Input Variables |   |   | SOP ( $\Sigma$ )        | POS ( $\Pi$ )             |
|---|-----------------|---|---|-------------------------|---------------------------|
|   | A               | B | C |                         |                           |
| 0 | 0               | 0 | 0 | $\bar{A}\bar{B}\bar{C}$ | $A+B+C$                   |
| 1 | 0               | 0 | 1 | $\bar{A}\bar{B}C$       | $A+B+\bar{C}$             |
| 2 | 0               | 1 | 0 | $\bar{A}BC$             | $A+\bar{B}+C$             |
| 3 | 0               | 1 | 1 | $\bar{A}B\bar{C}$       | $A+\bar{B}+\bar{C}$       |
| 4 | 1               | 0 | 0 | $A\bar{B}\bar{C}$       | $\bar{A}+\bar{B}+\bar{C}$ |
| 5 | 1               | 0 | 1 | $A\bar{B}C$             | $\bar{A}+B+\bar{C}$       |
| 6 | 1               | 1 | 0 | $\bar{A}BC$             | $\bar{A}+\bar{B}+C$       |
| 7 | 1               | 1 | 1 | $ABC$                   | $A+\bar{B}+\bar{C}$       |

b)  $F(x,y,z) = \Sigma(1,3,4,6)$

↳ It can be written as:  $F(A,B,C) = \Sigma(1,3,4,6)$

Now, From truth table,

$$F = \bar{A}\bar{B}\bar{C} + \bar{A}\bar{B}C + A\bar{B}\bar{C} + ABC$$

VHDL Code:

```
library ieee;
use ieee.std_logic_1164.all;
```

entity circuit is:

```
Port (A,B,C : in std_logic;
      F: out std_logic);
```

end circuit;

architecture data of circuit 1's

begin

$$\begin{aligned} F &= (\text{not } A) \text{ and } (\text{not } B) \text{ and } C \text{ or} \\ &(\text{not } A) \text{ and } B \text{ and } C \text{ or} \\ &(A \text{ and } (\text{not } B) \text{ and } (\text{not } C)) \text{ or} \\ &(A \text{ and } B \text{ and } (\text{not } C)); \end{aligned}$$

end data;

b.  $F(A, B, C) = \Sigma(1, 3, 6, 7)$

↳ From truth table:

$$F = \overline{A} \overline{B} C + \overline{A} B C + A \overline{B} C$$

VHDL code

library ieee;

use ieee.std\_logic\_1164.all;

entity circuit is

Port (A, B, C: in std\_logic;

F: out std\_logic);

end circuit;

architecture data of circuit 1's

begin

$$\begin{aligned} F &= ((\text{not } A) \text{ and } (\text{not } B) \text{ and } C) \text{ or} \\ &((\text{not } A) \text{ and } B \text{ and } C) \text{ or} \\ &(A \text{ and } B \text{ and } (\text{not } C)) \text{ or} \\ &(A \text{ and } B \text{ and } C); \end{aligned}$$

end data;

$$\textcircled{O} \quad F(A, B, C) = \pi(0, 1, 5, 7)$$

From the above table,

$$F = (A + B + C) \cdot (\bar{A} + B + C) \cdot (\bar{A} + \bar{B} + \bar{C})$$

VHDL code :

```
library ieee;
use ieee.std_logic_1164.all;
```

```
entity circuit is
Port (A, B, C : in std_logic;
      F: out std_logic);
end circuit;
```

Architecture data of circuit is

begin

$$F \leftarrow (A \text{ or } B \text{ or } C) \text{ and}$$

$$((\text{not } A) \text{ or } B \text{ or } (\text{not } C)) \text{ and}$$

$$((\text{not } A) \text{ or } (\text{not } B) \text{ or } (\text{not } C));$$

end data;