

## Tutorial One

Submitted By:

Pradip Dhungana  
201751  
BESE 4<sup>th</sup> Day

i) Explain the levels of programming language.

⇒ levels of programming language are:

- ① High level programming language
- ② Assembly level language
- ③ Machine level language

① High level programming language:

These languages hide the details of the computer and operating system on which they will run from the programmer. They are said to be platform-independent. The same code can be converted and run on computers with different hardware and operating systems without modification. Languages such as C++, Java, and Fortran are high-level language.

② Assembly level language:

Assembly language lies at a much lower level of abstraction. Each chip has its own assembly language. A program written in the assembly language of one microprocessor

cannot be run on a computer that has a different microprocessor - with one very important exception. It is platform dependent and Assembly level language makes use of mnemonics instead of numeric generation codes.

### (iii) Machine level language:

The lowest level of programming languages are machine languages. These languages contain the binary values that cause the microprocessors to perform certain operations. When a microprocessor reads and executes an instruction, it is a machine language instruction. Programmers do not write programs in machine language. It has faster execution time.

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

### ⇒ Assembly level language:

↳ Makes use of mnemonics instead of numeric generation codes.

↳ platform dependent

↳ Assembler converts into machine language.

↳ slower than machine language.

## → Compiling & assembling program



- A program written in high level language is input to a compiler. The compiler makes sure that every statement in program is valid.
- When a program has no errors, the compiling of the program will be finished i.e. source code generates object code.
- At this point, the program has been compiled successfully, but it is not yet ready to be executed.
- Some programs use the object code of other program in addition to their own.
- Linker combines your object code with any other required object code.
- This combined code is stored as an executable

file. It is actually the code that the computer runs.

- The loader copies the executable file into memory the microprocessor then runs the machine code contained in that file.
- Each assembly language instruction corresponds to one unique machine code instruction.
- The assembler, like the compiler converts its source code to object code.
- From there, it follows the linking & loading procedure that was used for compiled code.

3) Explain different types of addressing modes with examples.

⇒ Addressing modes:

↳ The way in which operands are specified in an instruction.

① Direct mode:

↳ Contains memory addresses that CPU accesses  
Eg: LDAC 5, read data from memory location 5 and stores in accumulator.

② Indirect mode:

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

E.g.: LDAC @5 or LDAC(5), first retrieve the content of memory location 5,

say 10. The CPU then retrieves the content of memory location 10, that actually contains the operand.

- (III) Register direct & register indirect modes:  
 → Works same as direct & indirect modes, except they do not specify memory address, instead they specify a register.  
 Eg: LDAC(R) or LDAC @ R  
 LDAC R

- (IV) Immediate mode:  
 → Operand specified is not an address, it is actual data to be used.  
 Eg: LDAC #5 moves the data value 5 into accumulator.

- (V) Implicit mode:  
 → doesn't explicitly specify an operand, instruction always refers to accumulator  
 Eg: CLAC, which clears the accumulator.

- (VI) Relative mode:  
 → Operand specified is an offset, not the actual address which is added to the content of program counter register to generate required address.

- Eg: LDAC \$5  
 → If next instruction is at location 12 i.e. PC has value 12, the instruction reads data from  $12+5=17$  location & stores in accumulator.

### (vii) Index mode & base address mode:

↳ Index mode works like relative mode, except the address supplied by instruction is added to the content of index register.  
Eg: LDA 5(x), reads from  $10 + 5 = 15$   
(Index register contains value 10)

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

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

⇒ ISA (Instruction set Architecture):

↳ Very important in the design of the microprocessor  
↳ Poorly designed ISA, even if implemented well leads to bad microprocessor design  
↳ Well designed ISA leads to powerful microprocessor.

↳ No magical formula for designing ISA; same requirement can have different ISA design, each of which can be valid.

↳ Must evaluate trade-off's between performance size and cost.

↳ Before beginning the design of ISA, it is to be decided what should ISA and its processor be able to do.

↳ If processor is to be used for general purpose computing, requires relatively large set of instruction to perform

Variety of tasks; for specialized processor, the task of microprocessor is very little and well known in advance.

### ↳ Orthogonality:

Instructions are orthogonal if they do not overlap or perform the same function. Good ISA design should minimize the overlapping.

→ Factors that should be considered while designing ISA:

(A) ⇒ Optimization of register set:

↳ If a processor is to be used for general purpose computing, such as in a personal computer, it will probably require quite a rich instruction set architecture.

Registers have a large effect on the performance of a CPU. The CPU can store data in its internal registers instead of memory. For many program segments, such as program loops, having data in registers significantly speeds up program execution. Having too few registers causes a program to make more references to memory, thus reducing performance.

(B) Type and size of data that microprocessor uses:

↳ If a CPU will have to process floating-point data, for example, it is important to include instructions in the instruction set architecture that works on floating-point data. It is also necessary to incorporate registers to store.

floating point values.

④ Are interrupts needed?

↳ Very few tasks absolutely require that a CPU have interrupts but many tasks can be performed more efficiently if interrupts are incorporated into the microprocessor. If interrupts are included, the instruction set architecture must include the instructions & registers needed to process the interrupts.

⑤ Are conditional instruction needed?

↳ A jump or branch instruction may be conditional; that is, some condition outside of the instruction determines whether or not the jump is taken.

5) What do you mean by Instruction set in the processor? How are they different from Micro Instructions? Explain the machine cycles associated with the instruction cycle with the example.

⇒ An instruction set is a collection of commands or operations that a processor can understand and execute. These commands define the tasks the processor can perform, such as arithmetic operations, data movement and control flow. Programmers use instructions from the instruction set to write software and perform computations on a computer system.

b) Micro instructions represent the lower-level control signals and operations that the processor's hardware uses to execute those instructions efficiently. While the instruction set represents the higher level commands that software developers use to write programs.

b) The instruction cycle is the procedure a microprocessor goes through to process an instruction: first it fetches, or reads the instruction from memory. Then it decodes the instruction, determining which instruction it has fetched. Finally, it performs the operations necessary to execute the instruction.

6) Explain the basic computer organization with a block diagram.



fig: Basic Computer Organization

- This organization has 3 sub-systems: CPU, memory sub-system and I/O sub-system.
- CPU performs various operations and controls the computer.
- Memory sub-system is used to store programs being executed by the CPU along with the necessary data.
- The I/O sub-system allows the CPU to interact with input and output devices such as keyboards, monitors, etc.

7) Explain the linear chip organization with an example.

→ Here,

Consider an  $8 \times 2$  ROM chip:

→ Address lines = 3

→ Data lines = 2

→ 16 bits of internal storage.

If  $CE = 0$ , decoder is disabled & no location is selected.

If  $CE = 1$  &  $OE = 1$ , tri-state buffer for that location cell is enabled & data is output from the chip.

fig: →

→ As the number of locations increases, the size of address decoder needed becomes extremely large. To remedy this problem, the memory chip can be designed using multiple dimension of decoding.



fig: Internal linear organization of an 8x2 ROM chip.

8) What do you understand by high order interleaving & low order interleaving? Explain with an example.

### ⇒ ① High Order Interleaving:

In high-order interleaving, the most significant bits of the address select the memory chip. The least significant bits are sent as addresses to each chip. One problem is that consecutive addresses tend to be in the same chip. The maximum rate of data transfer is limited by the memory cycle time.

### ② Low Order Interleaving:

In low-order interleaving, the least significant bits select the memory bank (module). In this, consecutive memory addresses are in different memory modules. This allows memory access at much faster rates than allowed by the cycle time.

Example:

Constructing a  $16 \times 2$  memory subsystem from two  $8 \times 2$  ROM chips with:

- high-order interleaving
- low-order interleaving



(a)



(a) (high-order interleaving)

(b)



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

### ⇒ ① Isolated I/O:

In isolated I/O we have common bus (data and address) for I/O and memory but separate read and write control lines for I/O. So when CPU decode instruction then if data is for I/O then it places the address on the address line and set I/O read or write control line on due to which data transfer occurs between CPU and I/O. As the address space of memory and I/O is isolated and the name is so. The address for I/O here is called ports. Here we have different read-write instruction for both I/O and memory.

Address Bus

Data Bus



### 11) Memory mapped I/O:

- In this case every bus is common due to which the same set of instructions work for memory and I/O. Hence we manipulate I/O same as memory & both have same address space, due to which addressing capability of memory become less because some part is occupied by the I/O.



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

→ I/O Subsystem organization & Interfacing:

#### ① for input device:

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

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

- The CPU, then can read these data.

- The key to this design is the enable logic.

⇒ For the input device, the read signal (RD) should,

be asserted.

→ Figure (b) shows the enable logic for an input device at address 11110000 with 8-bit address and control signals RD and IO/Memory (IO/m).

→ An input device: (a) with its interface and  
(b) the enable logic for the tri-state buffers



## ⑪ For output device

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

→ An output device: (a) with its interface and  
 (b) the load logic for the register.



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

→ RTL (Register transfer language) is used to describe the micro-operations transfer among registers. It is a kind of intermediate representation (IR) that is very close to assembly language. Such ~~as~~ as that which is used in a compiler. The term "Register Transfer" can perform micro operations and transfer the result of operation to the same or other register.

→ Implementation of RTL:

Example:

Assume that conditions j, o, h and n are mutually exclusive.

j: M  $\leftarrow$  A; o: A  $\leftarrow$  Y; h: R  $\leftarrow$  M; ~~n: Y  $\leftarrow$  R, M  $\leftarrow$  R~~  
n: Y  $\leftarrow$  R, M  $\leftarrow$  R

(a) Implement RTL code using direct connections



⑥ Implement the RTL code using a bus & tri-state buffer.



⑦ Implement the RTL code using a bus & MUX.



26) List out the arithmetic & logical micro-operations and illustrate the implementation of each of them.

| Operation | Example                                           |
|-----------|---------------------------------------------------|
| Add       | $X \leftarrow X + Y$                              |
| Subtract  | $X \leftarrow X - Y$ or $X \leftarrow X + Y' + 1$ |
| Increment | $X \leftarrow X + 1$                              |
| Decrement | $X \leftarrow X - 1$                              |
| AND       | $X \leftarrow X \wedge Y$ or $X \leftarrow XY$    |
| OR        | $X \leftarrow X \vee Y$                           |
| XOR       | $X \leftarrow X \oplus Y$                         |
| NOT       | $X \leftarrow \bar{X}$ or $X \leftarrow X'$       |

### ① Addition:

↳ The Add arithmetic micro-operation adds the values of the two registers and stores the output in the desired register.

Ex:

$$X \leftarrow X + Y$$

Here,  $X$  &  $Y$  are the registers whose contents we want to add and,  $X$  is the desired register for storing the output.

### ② Subtraction:

↳ It subtracts the values of the two registers & stores the result in the desired register.

$$\text{ex: } X \leftarrow X - Y$$

Here,  $X$  &  $Y$  are the registers whose contents we want to subtract and  $X$  is the desired register for storing the output.

### ③ Increment:

↳ It increments the value of a register by 1.

Ex :-

$$X \leftarrow X + 1$$

Here, we incremented the value of X register and stored in X register.

### ④ Decrement:

↳ It decrements the value of a register by 1.

Ex :-

$$X \leftarrow X - 1$$

Here, we decrement the value of X register & store in X.

### ⑤ AND:

↳ It multiplies the contents of given registers logically And).

Ex :-

$$X \leftarrow X \wedge Y$$

Here, the contents of X & Y registers are logically Anded and stored in X.

### ⑥ OR

↳ It adds ~~the~~ (logically OR) the contents of given registers.

Ex :-

$$X \leftarrow X \vee Y$$

### ⑦ XOR:

↳ Exclusive OR

$$Ex :- X \leftarrow X \oplus Y$$

29) Explain different types of shift microoperations with example.

| Operation              | Notation |
|------------------------|----------|
| Linear shift left      | shl(x)   |
| Linear shift right     | shr(x)   |
| Circular shift left    | cil(x)   |
| Circular shift right   | cir(x)   |
| Arithmetic shift left  | ashl(x)  |
| Arithmetic shift right | ashr(x)  |
| Decimal shift left     | dshl(x)  |
| Decimal shift right    | dshr(x)  |

⇒ 1) Linear Shift:

It transfers the zero through the serial input. We use the symbols ~~shl(x)~~ & ~~shr(x)~~ for the logical linear left shift & ~~shl(x)~~ for the logical right shift.

a) linear shift left:

This left shift operator is denoted by the double left 'shl(x)'.

Ex:-



b) linear shift right

↳ the right shift operator is denoted by  $\text{shs}(x)$ .

Ex :-



2) Arithmetic shift ~~left~~.

The arithmetic shift micro-operation moves the signed binary number either to the left or to the right position.

a) Arithmetic Left shift:

↳ In this shift, each bit is moved to the left one by one. The empty least significant bit (LSB) is filled with zero and the most significant bit (MSB) is rejected. Same as the left logical shift.

Ex :- MSB

LSB



b) Arithmetic right shift:

↳ In this shift, each bit is moved to the right one by one and the least significant (LSB) bit is rejected and the empty most significant bit (MSB) is filled with the value of the previous MSB.

Ex :-



### 3) Circular shift:

b) The circular shift circulates the bits in the sequence of the register around both ends without any loss of information.

#### a) Circular shift left:

In this micro shift operation each bit in the register is shifted to the left one by one. After shifting, the LSB becomes empty, so the value of the MSB is filled in there.  
Ex:-



#### b) Circular shift right:

In this micro shift operation each bit in the register is shifted to the right one by one. After shifting, the MSB becomes empty, so the value of the LSB is filled in there. Ex:-



30) Perform eight different shift operations on  $X = 110101010110$ .

⇒ ① linear shift left:

$$\begin{array}{r} 110101010110 \\ \swarrow \searrow \swarrow \searrow \swarrow \searrow \swarrow \searrow \\ 101010101100 \end{array}$$

② linear shift right:

$$= 011010101011$$

③ Arithmetic left shift:

$$= 101010101100$$

④ Arithmetic Right shift:

$$= 111010101011$$

⑤ Circular left shift:

$$= 101010101101$$

⑥ Circular right shift:

$$= 011010101011$$

⑦ Decimal shift left:

$$= 101010101100$$

⑧ Decimal shift right:

$$= 11010101011$$

31) Repeat the above on 10101100.

⇒ ① linear shift left:

$$= 01011000$$

② linear right shift:

$$= 0101010$$

③ Arithmetic left shift:

$$= 01011000$$

(iv) Arithmetic Right Shift:

$$= 11010110$$

(v) Circular left shift:

$$= 01011001$$

(vi) Circular right shift:

$$= 0010110$$

(vii) Decimal left shift:

$$= 010110000$$

(viii) Decimal Right shift:

$$= 1010110$$

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

$\Rightarrow$  VHDL (Very high speed integrated circuit (VHSSC) Hardware Description language)

↳ VHDL was developed to provide a standard for designing digital systems.

↳ VHDL specifies a formal syntax. The designer creates a design file using that syntax just as a programmer writes a C-program.

↳ The designer then synthesizes the design using only design package that can accept VHDL files. This is equivalent to the programmer compiling the C-Program. It checks for errors in syntax and declaration, but not in logic.

↳ Finally, the designer debugs the design using simulation tools.

→ Advantages of VHDL:

### ⑥ PORTABILITY:

Just as a valid C-program can be compiled by any compliant C compiler, a VHDL design can be synthesized by any design system that supports VHDL.

### ⑦ Device Independent:

The VHDL file is device independent. The same file can be used to implement the design on a custom IC, on ASICs or any PLD that is capable of containing the design.

### ⑧ SIMULATION:

VHDL designs can be simulated by the design system, allowing the designer to verify the design performance before committing it to hardware.

### ⑨ SYSTEM SPECIFICATION:

The designer can design the system using a high level of abstraction, such as a finite state machine, down to a low level digital logic implementation.

→ Disadvantages of VHDL:

↳ VHDL source code often becomes long and difficult to follow, especially at a low level of abstraction.

↳ Different design tools may produce different valid design for the same system, especially for high level of abstraction, providing no details about the implementation.

33) Write down VHDL code for following:

⇒ a) AND gate:

-- Header file declaration  
library IEEE;  
use IEEE.std\_logic\_1164.all;

-- Entity declaration

entity andgate is  
port (A : in std\_logic; -- A input  
B : in std\_logic; -- B input  
Y : out std\_logic); -- Output  
end andgate;

Architecture andlogic of andgate is

begin

Y <= A AND B;

end andlogic;

⇒ "--" is used to comment.

b) OR gate:

→ library IEEE;  
use IEEE.std\_logic\_1164.all

entity ORgate is

```
port(A: in std_logic;
      B: in std_logic;
      Y: out std_logic);
end ORgate;
```

architecture orLogic of ORgate is

begin

```
Y <= A OR B;
```

end orLogic;

c) NOT gate:

→ 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 notLogic of not\_gate is

begin

```
Y <= not(A);
```

end notLogic;

### d) NOR Gate:

```
→ library IEEE;
use IEEE.std_logic_1164.all;
entity nor_gate is
port(A: in std_logic;
      B: in std_logic;
      Y: out std_logic);
end nor_gate;
architecture norlogic of nor_gate is
begin
Y <= not(A OR B)
end norlogic;
```

### e) NAND Gate:

```
→ library IEEE;
use IEEE.std_logic_1164.all;
entity nand_gate is
port(A: in std_logic;
      B: in std_logic;
      Y: out std_logic);
end nand_gate;
architecture nandlogic of nand_gate is
begin
Y <= not (A and B);
end nandlogic;
```

### f) XOR Gate:

→ library IEEE;

use IEEE.std\_logic\_1164.all;

entity XOR\_gate is

port(A: in std\_logic;

B: in std\_logic;

Y: out std\_logic);

end XOR\_gate;

architecture XORlogic of XOR\_gate is

begin

$$Y \leftarrow A \text{XOR} B;$$

end XORlogic;

### g) XNOR Gate:

~~Tree~~

→ library IEEE;

use IEEE.std\_logic\_1164.all;

entity xnor\_gate is

port(A: in std\_logic;

B: in std\_logic;

Y: out std\_logic);

end xnor\_gate;

architecture xnorlogic of xnor\_gate is

begin

$$Y \leftarrow \text{not}(A \text{XOR} B);$$

end xnorlogic;

## h) Half adder:

→ library IEEE;  
 use IEEE.std\_logic\_1164.all;  
 entity H-adder is  
 port (A: in std\_logic;  
 B: in std\_logic;  
 sum: out std\_logic;  
 carryout: out std\_logic);  
 end H-adder;  
 architecture flow of H-adder is  
 begin  
 sum  $\leftarrow A \text{ xor } B$ ;  
 carryout  $\leftarrow A \text{ and } B$ ;  
 end flow;

## i) full adder:

→ library IEEE;  
 use IEEE.std\_logic\_1164.all;  
 entity full\_adder is  
 port (A, B, carry\_in: in std\_logic;  
 sum, carry\_out: out std\_logic);  
 end full\_adder;  
 architecture flow of full\_adder is  
 component half\_adder is  
 port (A, B: in std\_logic;  
 sum, carryout: out std\_logic);  
 end component;  
 component OR-gate is  
 port (A, B: in std\_logic;  
 Y: out std\_logic);

end component;

signal T1, T2, T3: std\_logic;

begin

half\_adder1: half\_adder port map

( A => A, B => B, sum => T1, carryout => T2);

half\_adder2: half\_adder port map

( A => T1, B => carry\_in, sum => sum,  
carryout => T3);

or\_gate1: or\_gate port map (A => T3, B => T2,

Y => carry\_out);

end flow;

j) Half subtractor:

→ library IEEE;

use IEEE.std\_logic\_1164.all;

entity half\_sub is

port (A,B: in std\_logic;  
diff, borrow: out std\_logic);

end half\_sub;

architecture flow of half\_sub is

begin

diff <= A xor B;

borrow <= not(A) and B;

end flow;

## k) Full Subtractors:

→ library IEEE;  
use IEEE.std\_logic\_1164.all;

entity full\_sub is

port(A, B, borrow\_in: in std\_logic;  
diff, borrow\_out: out std\_logic);

end full\_sub;

architecture flow of full\_sub is

component half\_sub is

port(A, B: in std\_logic;  
diff, borrow: out std\_logic);

end component;

component or\_gate is

port(A, B: in std\_logic;  
Y: out std\_logic);

end component;

signal T1, T2, T3: std\_logic;

begin

half\_sub1: half\_sub port map

(A  $\Rightarrow$  A, B  $\Rightarrow$  B, diff  $\Rightarrow$  T1, borrow  $\Rightarrow$  T2);

half\_sub2: half\_sub port map

(A  $\Rightarrow$  T1, B  $\Rightarrow$  borrow\_in, diff  $\Rightarrow$  diff,  
borrow  $\Rightarrow$  T3);

or\_gate1: or\_gate port map (A  $\Rightarrow$  T3, B  $\Rightarrow$  T2,  
Y  $\Rightarrow$  borrow\_out);

end flow;

1) 4x1 multiplexer;

→ library ieee;

use ieee.std\_logic\_1164.all;

use ieee.std\_logic\_arith.all;

~~entity mux\_4t1~~

use ieee.std\_logic\_unsigned.all;

entity MUX\_SOURCE is

Port (S: in std\_logic\_vector (1 downto 0);

I: in std\_logic\_vector (3 downto 0);

Y: out std\_logic);

end MUX\_SOURCE

architecture Behavioral of MUX\_SOURCE is

begin

process (S, I)

begin

if (S <= "00") then

Y <= I(0);

elsif (S <= "01") then

Y <= I(1);

elsif (S <= "10") then

Y <= I(2);

else

Y <= I(3);

end if;

end process;

end Behavioral;

m) 1x4 demultiplexers:

→ library IEEE;

use IEEE.std\_logic\_1164.all;

entity Demultiplexer1x4 is  
port

A: in std\_logic;

S: in std\_logic\_vector(1 downto 0);

F, G, H, I: out std\_logic);

end entity Demultiplexer1x4;

architecture Behavioral of Demultiplexer1x4 is  
begin

with S select

F := A when "00",

'0' when others;

with S select

G := A when "01",

'0' when others;

with S select

H := A when "10",

'0' when others;

with S select

I := A when "11",

'0' when others;

with S select

I := A when "11",

'0' when others;

end architecture Behavioral;

## Q) 8x3 encoder:

→ library ieee;

use ieee.std\_logic\_1164.all;

entity Encoder8x3 is  
port

A, B, C, D, E, F, G, H: in std\_logic;

Y: out std\_logic\_vector(2 downto 0);

end entity Encoder8x3;

architecture Behavioral of Encoder8x3 is  
begin

Y <= "000" when A = '1' else

"001" when B = '1' else

"010" when C = '1' else

"011" when D = '1' else

"100" when E = '1' else

"101" when F = '1' else

"110" when G = '1' else

"111" when H = '1'

"000";

end architecture Behavioral;

## Q) 3x8 decoders:

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

entity Decoder3x8 is  
port(

A, B, C: in std\_logic;  
Y: out std\_logic\_vector(7 down to 0));  
end entity Decoder3x8;

architecture behavioral of Decoder3x8 is  
begin

~~Y<= "00000001"  
"00000010"  
"00000011"  
"00000100"  
"00000101"  
"00000110"  
"00000"  
"~~

~~Y<= "00000001" when (A='0' and  
B = '0' and C = '0') else~~

~~"00000010" when(A='0'  
and B='0' and C='1') else  
"00000100" when(A='0'  
and B='1' and C='0') else~~

"00001000" when (A='0' and B='1' and C='1') else  
"00010000" when(A='1' and B='0' and C='0') else  
"00100000" when(A='1' and B='0' and C='1') else  
"01000000" when(A='1' and B='1' and C='0') else  
"10000000" when(A='1' and B='1' and C='1') else  
"00000000";  
end architecture Behavioral;

## p) SR flip flop:

→ library ieee;

use ieee.std\_logic\_1164.all;

entity SR\_FlipFlop is

port (

S, R: in std\_logic;

Q, Qbar: out std\_logic);

end entity SR\_FlipFlop;

architecture Behavioral of SR\_FlipFlop is

signal Q\_int, Qbar\_int: std\_logic;

begin

process (S, R)

begin

if (R = '1') then

Q\_int <= '0';

Qbar\_int <= '1';

elsif (S = '1') then

Q\_int <= '1';

Qbar\_int <= '0';

endif;

end process;

Q <= Q\_int;

Qbar <= Qbar\_int;

end architecture Behavioral;

## a) JK Flipflop:

```
→ library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;
```

```
entity JK_FF is
PORT (J, K, CLOCK: in std_logic;
Q, QB: out std_logic);
end JK_FF;
```

architecture behavioral of JK\_FF is

```
begin
PROCESS (CLOCK)
variable TMP: std_logic;
begin
if (CLOCK='1' and CLOCK'EVENT) then
    if (J='0' and K='0') then
        TMP := TMP;
    elsif (J='1' and K='1') then
        TMP := not TMP;
    elsif (J='0' and K='1') then
        TMP := '0';
    else
        TMP := '1';
    end if;
    end if;
    Q := TMP;
    QB := not TMP;
end process;
end behavioral;
```

## a) T flip flop:

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

entity T_FF is
port (T: in std_logic;
      CLOCK: in std_logic;
      Q: out std_logic);
end T_FF;
```

architecture behavioral of T\_FF is

```
signal tmp: std_logic;
begin
process (clock)
begin
  if Clock'event and clock = '1' then
    if T = '0' then
      tmp := tmp;
    else if T = '1' then
      tmp := not (tmp);
    end if;
  end if;
  end process;
  Q < tmp;
end Behavioral;
```

## 3) D FlipFlop:

→ library ieee;  
use ieee.std\_logic\_1164.all;  
use ieee.std\_logic\_arith.all;  
use ieee.std\_logic\_unsigned.all;

entity D\_FF is  
PORT (D, CLOCK: in std\_logic;  
Q: out std\_logic);  
end D\_FF;

architecture behavioral of D\_FF is  
begin  
process(CLOCK)  
begin  
if CLOCK='1' and CLOCK'EVENT then  
Q<=D;  
end if;  
end process;  
end behavioral;

34) 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 (
    v, clk: in std_logic;
    q2, q1, q0: buffer std_logic;
    v2, v1, v0, c: out std_logic);
end mod 6;
```

architecture amod6 of mod6 is

begin

```
cct_mod6: process(q2, q1, q0, v, clk)
```

begin

if rising edge(clk) then

$$\begin{aligned} q2 &= (q2 \text{ and } (\text{not } q1) \text{ and } (\text{not } q0)) \text{ or} \\ &\quad (q2 \text{ and } (\text{not } q1) \text{ and } (\text{not } v)) \text{ or} \\ &\quad ((\text{not } q2) \text{ and } q1 \text{ and } q0 \text{ and } v); \end{aligned}$$

$$\begin{aligned} q1 &= ((\text{not } q2) \text{ and } q1 \text{ and } (\text{not } q0)) \text{ or} \\ &\quad ((\text{not } q2) \text{ and } q1 \text{ and } (\text{not } v)) \text{ or} \\ &\quad ((\text{not } q2) \text{ and } (\text{not } q1) \text{ and } q0 \text{ and } v); \end{aligned}$$

$$\begin{aligned} q0 &= ((\text{not } q2) \text{ and } (\text{not } q0) \text{ and } v) \text{ or} \\ &\quad ((\text{not } q1) \text{ and } (\text{not } q0) \text{ and } v) \text{ or} \\ &\quad ((\text{not } q2) \text{ and } q0 \text{ and } (\text{not } v)) \text{ or} \\ &\quad ((\text{not } q1) \text{ and } q0 \text{ and } (\text{not } v)); \end{aligned}$$

end if;

$v2 = q2;$

```

V1L= q7;
V0Z = (q2 and q1) or q0;
C <= not (q2 or q1 or q0);
end process cct_mod6;
end qmod6;

```

35) Write a VHDL code for the following combinational circuits.

$$q) F = AB + A'B'$$

→ library ieee;

use ieee.std\_logic\_1164.all;

```

entity CombinationalCircuit1 is
port (
    A; B: in std_logic;
    F : out std_logic);
end entity CombinationalCircuit1;

```

architecture Behavioral of CombinationalCircuit1 is

begin
 F <= A and B or (not A and not B);
end architecture Behavioral;

- ⑥  $F(x,y,z) = \sum(1, 3, 6, 7) \rightarrow$  sum of product  
 ⑦  $F(x,y,z) = \sum(1, 3, 4, 6) \rightarrow$  sum of product  
 ⑧  $F(x,y,z) = \prod(0, 2, 5, 7) \rightarrow$  product of sum

~~Solution:~~

⑥

| x | y | z | 00 | 01 | 11 | 10 |
|---|---|---|----|----|----|----|
| 0 |   |   |    | 1  | 1  |    |
| 1 |   |   |    |    | 1  | 1  |

$$F = x'z + xy$$

VHDL code:

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

```
entity CombinationalCircuit2 is
port (
    A, B : in std_logic;
    F : out std_logic);
end entity CombinationalCircuit2;
```

architecture Behavioral of CombinationalCircuit2 is

begin

```
F <= (not A and B) or (A and B);
```

end architecture Behavioral;

(C) ~~SOLN~~

| X | Y | Z | F |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |

$$F = X'Z + XZ'$$

VHDL code:

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

entity circuit3 is

port

(A, B : in std\_logic;

F : out std\_logic);

end entity circuit3;

architecture Behavioral of circuit3 is  
begin

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

end architecture Behavioral;

(A true if A is 1 and B is 0 or A is 0 and B is 1)  
 To implement this logic we can use

Q) ~~Q1~~  
 Q2

|   | X | 00 | 01 | 11 | 10 |
|---|---|----|----|----|----|
| 0 |   | 0  | -1 | 1  | 0  |
| 1 |   | 1  | 0  | 0  | 1  |

$$\textcircled{1} (x+z)(x'+z')$$

VHDL code:

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

entity circuit4 is  
 port

(A, B: in std\_logic);  
 F: out std\_logic);  
 end entity circuit4;

architecture Behavioral of circuit4 is

begin

F := (A or B) and (not A or not B);

end architecture Behavioral;

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

→ State table for the modulo 6 counter:

| Present State  | V | 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 | 000                                          |
| S <sub>0</sub> | 1 | S <sub>1</sub>   | 0 | 001                                          |
| S <sub>1</sub> | 0 | S <sub>1</sub> ' | 0 | 010                                          |
| S <sub>1</sub> | 1 | S <sub>2</sub>   | 0 | 010                                          |
| S <sub>2</sub> | 0 | S <sub>2</sub> ' | 0 | 010                                          |
| S <sub>2</sub> | 1 | S <sub>3</sub>   | 0 | 011                                          |
| S <sub>3</sub> | 0 | S <sub>3</sub> ' | 0 | 011                                          |
| S <sub>3</sub> | 1 | S <sub>4</sub>   | 0 | 100                                          |
| S <sub>4</sub> | 0 | S <sub>4</sub> ' | 0 | 100                                          |
| S <sub>4</sub> | 1 | S <sub>5</sub>   | 0 | 101                                          |
| S <sub>5</sub> | 0 | S <sub>5</sub> ' | 0 | 101                                          |
| S <sub>5</sub> | 1 | S <sub>0</sub>   | 1 | 000                                          |
| S <sub>6</sub> | X | S <sub>0</sub>   | 1 | 000                                          |
| S <sub>7</sub> | X | S <sub>0</sub>   | 1 | 000                                          |

→ The 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:

$C=0$  $V=111$  $C=1$  $V=000$  $C=0$  $V=001$  $C=0$  $V=010$  $C=0$  $V=110$  $C=0$  $V=101$  $C=0$  $V=100$  $C=0$  $V=011$ 

→ Implementation of the RTL code for the modulo 6 counter

(a) Using registers:



28) Draw the state diagram of the modulo 6 counter and implement it using a 3-bit counter.

⇒ State diagram:



→ Implementation using 3-bit counter:



23) Design an 8x4 ROM chip using 4x4 ROM chips.  
Illustrate using low level interleaving.

⇒ Answer:

For 8x4 ROM chip;

No. of address input = 3

No. of data lines = 4

For 4x4 ROM chip

No. of address input = 2

No. of data lines = 4



10) Construct 8x4 memory subsystems us fng 8x2 ROM chips with required control signals.

$\Rightarrow$



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 }   | 0     |
| { 0   | 0     | 0 }   | 1     |
| { 0   | 0     | 1 }   | 0     |
| { 0   | 0     | 1 }   | 1     |
| { 0   | 1     | 0 }   | 0     |
| { 0   | 1     | 0 }   | 1     |
| { 0   | 1     | 1 }   | 0     |
| { 0   | 1     | 1 }   | 1     |
| { 1   | 0     | 0 }   | 0     |
| { 1   | 0     | 0 }   | 1     |
| { 1   | 0     | 1 }   | 0     |
| { 1   | 0     | 1 }   | 1     |
| { 1   | 1     | 0 }   | 0     |
| { 1   | 1     | 0 }   | 1     |
| { 1   | 1     | 1 }   | 0     |
| { 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,

9) contd... (figure)



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,

so, Starting Address given = 80H

10 0 0 0 | 0 0 0

used for  
CE logic

used for the  
memory selection



Read Signal



③ Generate load logic for an output device. i.e. CS-H. Assume that the system is being operated in isolated mode.

$$\Rightarrow M_1, C_F H, \\ C_F H = \overline{M_0} \overline{A_5} \overline{A_4} \overline{A_3} A_2 A_1 A_0$$

Now, The load logic for an output device at CS-H is:



Q1 There is an input device at address 00H and an output device at 20H. Illustrate the design with necessary logic.

- ⇒ Answer is : Address of input device = 00H
- |              |       |       |       |       |          |       |               |
|--------------|-------|-------|-------|-------|----------|-------|---------------|
| Input Device | 8     | 8     | 8     | 8     | Register | 8     | Output Device |
|              | →     | →     | →     | →     |          | →     |               |
|              | Logic | Logic | Logic | Logic |          | Logic |               |
|              | E     | E     | E     | E     |          | E     |               |
- Address of output device = 20H



- ⑯ A computer has a CPU with an 8 bit address bus and 16 bit data bus. The computer uses isolated I/O. It has  $64 \times 16$  ROM at  $00H$  constructed using two  $32 \times 16$  ROM chips. It also has  $32 \times 16$  of RAM at  $C0H$ . The system has an output device at  $15H$  and the output device at  $76H$ . 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

$$\text{ROM} = \begin{matrix} 0 & 0 & 0 & 0 & 0 & 0 \\ A_7 & A_6 & A_5 & A_4 & A_3 & A_2 & A_1 & A_0 \end{matrix}$$

→ For  $32 \times 16$  ROM and RAM

No. of address input = 5

No. of data lines = 16

For RAM,

$$\text{RAM} = \begin{matrix} 1 & 1 & 0 & 0 & 0 & 0 & 0 \\ A_7 & A_6 & A_5 & A_4 & A_3 & A_2 & A_1 & A_0 \end{matrix}$$

For an Input and Output Device,

$$\text{For input device} = \text{I/O} = \begin{bmatrix} 0 & 0 & 0 & 1 & 0 & 1 & 0 & 1 & 1 \\ A_7 & A_6 & A_5 & A_4 & A_3 & A_2 & A_1 & A_0 \end{bmatrix}$$

$$\text{For output device} = \text{I/O} = \begin{bmatrix} 0 & 0 & 0 & 1 & 0 & 1 & 0 & 1 & 0 \\ A_7 & A_6 & A_5 & A_4 & A_3 & A_2 & A_1 & A_0 \end{bmatrix}$$

CLASSMATE

四庫全書

16

四

