# LECTURES NOTES ON DIGITALELECTRIONICS AND MICROPROCESSOR

# GOVT.POLYTECHNIC,BHADRAK



# **PREPARED BY** TAPAN KUMAR DAS

# DEPARTMENT OF ELECTRICAL ENGINEERING Government Polytechnic, Bhadrak

#### BASICSOFDIGITALELECTRONICS

The branch of electronics that deals with digital data in the form of codes. There areonly two codes in digital electronics, and they are 0 and 1. 0 is considered to be lowlogic while 1 is considered to be high logic.

Digital Electronicscan also be defined as the circuit which deals with Digital Signal is knows as Digital Electronics

#### **AdvantagesOfDigitalElectronics**

- a. DigitalElectroniccircuitsarerelativelyeasytodesign.
- b. Ithashigherprecisionrateintermsofaccuracy.
- c. Transmittedsignalsarenotlostoverlongdistance.
- d. DigitalSignalscanbestoredeasily.
- e. Digital Electronics is more immune to 'error' and 'noise' than analog. But in case of high-speed designs, a small noise can induce error in the signal.
- f. ThevoltageatanypointinaDigitalCircuitcanbeeitherhighorlow;hence there is less chance of confusion.
- *g.* DigitalCircuitshavetheflexibilitythatcanchangethefunctionalityofdigital circuits by making changes in software instead of changing actual circuit.

#### **DisadvantagesofDigitalElectronics**

- a. The real world is analog in nature, all quantities such as light, temperature, soundetc.DigitalSystemsisrequiredtotranslateacontinuoussignaltodiscrete which leads to small quantization errors. To reduce quantization errors a large amount of data needs to be stored in Digital Circuit.
- b. DigitalCircuitsoperateonlywithdigitalsignalshence,encodersanddecoders are required for the process. This increases the cost of equipment.

#### NumberSystem

A digital system can understand positional number system only where there are a few symbols called digits and these symbols represent different values depending on the position they occupy in the number.

Avalueofeachdigitinanumbercanbedeterminedusing

- a. Thedigit
- b. Thepositionofthedigit inthenumber
- c. The base of the number system (where base is defined as the total number of digits available in the number system).

#### TypenumberSystem

- 1. DecimalNumberSystem
- 2. BinaryNumberSystem
- 3. OctalNumberSystem
- 4. HexadecimalNumberSystem

### DecimalNumberSystem

Thenumbersystemthatweuseinourday-to-daylifeisthedecimalnumbersystem The decimal number system contains ten digits from 0 to 9.(0,1,2,3,4,5,6,7,8,&9) Base=10 Thepositioninthedecimalnumbersystemspecifiesthepowerofthebase(10).

## Example

Mathematically, we can write it as

 $2541 = (2 \times 1000) + (5 \times 100) + (4 \times 10) + (1 \times 1)$  $= (2 \times 10^{3}) + (5 \times 10^{2}) + (4 \times 10^{1}) + (1 \times 10^{0})$ = 2541

### BinaryNumberSystem

Generally, abinary number system is used in the digital computers. In this number system, it carries only two digits, either 0 or 1

Thebinarynumbersystemcontains2digitsfrom0&1 Base=10

The position in the binary numbers ystems pecifies the power of the base (2) Mathematically,

we can write it as

```
1101.011=(1\times2^{3})+(1\times2^{2})+(0\times2^{1})+(1\times2^{0})+(0\times2^{-1})+(1\times2^{-2})+(1\times2^{-3})
OctalNumberSystem
```

Theoctalnumbersystemcontains8digitsfrom0to7(i.e.0,1,2,3,4,5,6&7) Base=8

The position in the octal number system specifies the power of the base (8) Mathematically,

we can write it as

12570=(1×8<sup>4</sup>)+(2×8<sup>3</sup>)+(5×8<sup>2</sup>)+(7×8<sup>1</sup>)+(0×8<sup>0</sup>) **HexadecimalNumberSystem** Uses10digitsand6letters,0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F.

Lettersrepresentsnumbersstartingfrom10.A=10,B=11,C=12,D=13,E=14,F=15. Base =16

The position in the Hexa decimal Number System number system specifies the power of the

base (8)

Mathematically, we can write it as

 $19FDE_{16}=(1\times16^{4})+(9\times16^{3})+(F\times16^{2})+(D\times16^{1})+(E\times16^{0})$ 

#### NumberSystemandBaseConversions

ElectronicandDigitalsystemsmayuseavarietyofdifferentnumbersystems, (e.g. Decimal, Hexadecimal, Octal, Binary).

AnumberNinbaseorradixbcanbewrittenas:

(N)b=dn-1dn-2-----d1d0.d-1d-2----- d-m

Intheabove, dn-1tod0istheintegerpart, thenfollows aradixpoint, and then

d-1 to d-m is the fractional part.

dn-1=Mostsignificantbit(MSB) d-

m = Least significant bit (LSB)

| Base | Representation |
|------|----------------|
| 2    | Binary         |
| 8    | Octal          |
| 10   | Decimal        |
| 16   | Hexadecimal    |

# 1. DecimaltoBinary

Convert(34.25)<sub>10</sub>toBinaryequivalent

Step1:Dividethenumber34anditssuccessivequotientswithbase2.

| 2)34 | Remainder |
|------|-----------|
| 2)17 | 0 +       |
| 2) 8 | 1         |
| 2 4  | 0         |
| 2) 2 | 0         |
| 2) 1 | 0         |
| 0    | 1         |

#### Step 2:

Now, perform the multiplication of 0.25 and successive fraction with base 2.

| Operation | Result | carry |
|-----------|--------|-------|
| 0.25×2    | 0.50   | 0     |
| 0.50×2    | 0      | 1     |

 $(0.25)_{10} = (.01)_2$ 

FinalResultis

(??.??)22=(????????)2

## 2. BinarytoDecimal

```
Convert(1010.01)2toequivalentDecimalNo.
```

```
(1010.01)_2 = 1 \times 2^3 + 0 \times 2^2 + 1 \times 2^1 + 0 \times 2^0 + 0 \times 2^{-1} + 1 \times 2^{-2} = 8 + 0 + 2 + 0 + 0 + 0.25 = 10.25
```

=(10.25)10

# 3. DecimaltoOctal

Convert(86)<sub>10</sub>toOctalequivalent **Step1:**Dividethenumber34anditssuccessivequotientswithbase8.

| 8 <u>)86</u> | Remainder |
|--------------|-----------|
| 8)10         | 6 🛉       |
| 8) 1         | 2         |
| 0            | 1         |

## Step2:

Now perform the multiplication of 0.35 and successive fraction with base 8.

| Operation | Result | carry |
|-----------|--------|-------|
| 0.35X8    | 2.8    | 2     |
| 0.8X8     | 6.4    | 6     |
| 0.4X8     | 3.2    | 3     |
| 0.3X8     | 2.4    | 2     |

## (0.35)10=(2632)8

So, the octal number of the decimal number 86.35 is 126.2632

### 4. OctaltoDecimal

 $(12.2)_8$ 1x8<sup>1</sup>+2x8<sup>0</sup>+2x8<sup>-1</sup>=8+2+0.25=10.25 (12.2)<sub>8</sub>=(10.25)<sub>10</sub>

# 5. HexadecimaltoBinary

To convert from Hexadecimal to Binary, write the 4-bit binary equivalent of hexadecimal.

| Binary equivalent | Hexadecimal |
|-------------------|-------------|
| 0000              | 0           |
| 0001              | 1           |
| 0010              | 2           |
| 0011              | 3           |
| 0100              | 4           |
| 0101              | 5           |
| 0110              | 6           |
| 0111              | 7           |
| 1000              | 8           |
| 1001              | 9           |
| 1010              | А           |
| 1011              | В           |
| 1100              | С           |
| 1101              | D           |
| 1110              | E           |
| 1111              | F           |

# Example

(3A)16=(00111010)2

## 6. BinarytoHexadecimal

ToconvertfromBinarytoHexadecimal,startgroupingthebitsingroupsof4from the rightend and write the equivalent hexadecimal for the 4-bit binary. Add extra 0'son the left to adjust the groups.

1111011011 <u>001111011011</u> (001111011011)2=(3DB)<sub>16</sub>

## 7. Hexa-decimaltoDecimalConversion

The process of converting hexadecimal to decimal is the same as binary to decimal. The process starts from multiplying the digits of hexadecimal numbers with its corresponding positional weights. And lastly, we add all those products.

```
Example1:(152A.25)<sub>16</sub>
```

 $(152A.25)_{16} = (1 \times 16^3) + (5 \times 16^2) + (2 \times 16^1) + (A \times 16^0) + (2 \times 16^{-1}) + (5 \times 16^{-2})$ = 5418.14453125

#### 8. DecimaltoHexadecimal

|      |      | Rema | ainder |
|------|------|------|--------|
| 16)2 | 2861 | Dec. | Hex.   |
| 16)  | 178  | 13   | Dţ     |
| 16)  | 11   | 2    | 2      |
|      | 0    | 11   | в      |

?????**=**??????

#### Binaryaddition, subtraction, Multiplication and Division

#### 1. Binaryaddition

| Case | Α | ÷ | В | Sum | Carry |
|------|---|---|---|-----|-------|
| 1    | 0 | + | 0 | 0   | 0     |
| 2    | 0 | + | 1 | 1   | 0     |
| 3    | 1 | + | 0 | 1   | 0     |
| 4    | 1 | + | 1 | 0   | 1     |

Infourthcase, abinary additioniscreating as umof (1+1=10) i.e. 0 is written in the given column and a carry of 1 over to the next column.

#### **Example-Addition**

| 0011010 + 001100 = 00100110 | 11       | carry  |
|-----------------------------|----------|--------|
|                             | 0011010  | = 2610 |
|                             | +0001100 | = 1210 |
|                             | 0100110  | = 3810 |

#### 2. BinarySubtraction

**Subtraction and Borrow**, these two words will be used very frequently for the binary subtraction. There are four rules of binary subtraction.

| Case | Α | 15  | В | Subtract | Borrow |
|------|---|-----|---|----------|--------|
| 1    | 0 |     | 0 | 0        | 0      |
| 2    | 1 | -   | 0 | 1        | 0      |
| 3    | 1 | 823 | 1 | 0        | 0      |
| 4    | 0 |     | 1 | 0        | 1      |

Example-Subtraction

| 0011010 - 001100 = 00001110 | 1 1      | borrow |
|-----------------------------|----------|--------|
|                             | 0011010  | = 2610 |
|                             | -0001100 | = 1210 |
|                             | 0001110  | = 1410 |

#### 3. Binary Multiplication

Binary multiplication is similar to decimal multiplication. It is simpler than decimal multiplication because only 0s and 1s are involved. There are four rules of binary multiplication.

| Case | Α | x | В | Multiplication |
|------|---|---|---|----------------|
| 1    | 0 | x | 0 | 0              |
| 2    | 0 | х | 1 | 0              |
| 3    | 1 | x | 0 | 0              |
| 4    | 1 | x | 1 | 1              |

-

#### Example-Multiplication

Example: 0011010 x 001100 = 100111000

| 0011010    | = 2610  |
|------------|---------|
| x0001100   | = 1210  |
| 0000000    |         |
| 0000000    |         |
| 0011010    |         |
| 0011010    |         |
| 0100111000 | = 31210 |

.1'scomplementand2'scomplementnumbersforabinary number

a.1's complement

### 1'scomplement

**1's complement** of a binary number is another binary number obtained by toggling all bits in it, i.e., transforming the 0 bit to 1 and the 1 bit to 0.

Originalvalue 1's complement  $0 \longrightarrow 1$ 

 $\begin{array}{ccc} 0 & & & 1 \\ 1 & \longrightarrow & 0 \end{array}$ 

Examples:

1'scomplementof7(0111)is8(1000)

1'scomplementof12(1100)is3(0011)

## **Useof1's complement**

The main use of 1's complement is to represent a signed binary number. Apart from this, it is also used to perform various arithmetic operations such as addition and subtraction.

In signed binary number representation, we can represent both positive and negative numbers

## 2'scomplement

2'scomplement of a binary number is 1 added to the 1's complement of the binary number.

| i.e. | Original value   | 1's complement    |             |
|------|------------------|-------------------|-------------|
|      |                  | 2'scomplement1011 | 0100        |
|      |                  | 0100+1=0101       |             |
|      | 1101             | 0010              | 0010+1=0011 |
| lleo | of2's complement |                   |             |

## Useof2's complement

Negative binary numbers are represented in 2's complement form so that the same logic circuit can be used to perform addition as well as subtraction

Subtractionofbinarynumbersin 2'scomplementmethod.

#### Theoperationiscarriedoutbymeansofthefollowingsteps:

(i) Findthe 2'scomplementofthesubtrahend(negativeno.only,because2's complement of positive no. is remain same) of given no..

(ii) Thenitisaddedtotheminuend.(add2'scomplementedwithpositivegivenno.)

(iii) If the final carry overof the sum is 1, it is dropped and the result is positive.

(iv) If there is no carry over, thetwo's complement of the sum will be the result and it is negative.

### Examples:

#### (i) **110110-10110**

#### Solution:

Now,2'scomplementof010110is(101101+1)i.e.101010.Addingthiswith the minuend.

110110 Minuend

#### <u>101010</u> 2'scomplementofsubtrahend

Carryover1 100000 Resultofaddition Afterdroppingthecarryoverwegettheresultofsubtractiontobe100000.

#### (ii) 10110-11010

#### Solution:

2'scomplementof11010is(00101+1)i.e.00110.Hence Minued - 10110

2'scomplementofsubtrahend- <u>00110</u> Resultofaddition- 11100

Asthereisnocarryover, the result of subtraction is negative and is obtained by writing the 2's complement of 11100 i.e. (00011 + 1) or 00100.

Hencethedifferenceis-100.

Use of weighted and Un-weighted codes & write Binary equivalent number for a number in 8421, Excess-3 and Gray Code and vice-versa.

#### Weighted code

Weighted binary codes are those binary codes which obey the positional weight principle.Eachpositionofthenumber representsaspecificweight. Severalsystems of the codes are used to express the decimal digits 0 through 9. In these codes each decimal digit is represented by a group of four bits.

- a. BCD(8421)
- b. 6311
- c. 2421
- d. 642-3
- **e.** 84-2-1



## **UseofWeightedcodes**

- a) Datamanipulationduringarithmeticoperation.
- b) Weightedbinarycodeisessentialfordisplayingnumericvaluesindigital devices such as voltmeters and calculators
- .c)Torepresentthedecimaldigitsincalculators,voltmetersetc.

# Non-WeightedCodes

In this type of binary codes, the positional weights are not assigned. The examples of non-weighted codes are Excess-3 code and Gray code.

## Nonweightedcodes areusedin:

- a) Toperformcertainarithmeticoperations.
- b) Shiftpositionencodes.
- c) Usedforerrordetectingpurpose.

## **Excess-3code**

The Excess-3 code is also called as XS-3 code. It is non-weighted code used to express decimalnumbers.The Excess-3codewordsarederivedfromthe8421BCDcodewords adding (0011)2 or (3)10 to each code word in 8421. The excess-3 codes are obtained as follows –

Example

| Decimal | BC  | D   | Exces | s-3  |
|---------|-----|-----|-------|------|
|         | 84  | 2 1 | BCD + | 0011 |
| 0       | 0 0 | 0 0 | 0 0   | 1 1  |
| 1       | 0 0 | 0 1 | 0 1   | 0 0  |
| 2<br>3  | 0 0 | 1 0 | 0 1   | 0 1  |
| 3       | 0 0 | 1 1 | 0 1   | 1 0  |
| 4       | 0 1 | 0 0 | 0 1   | 1 1  |
| 5       | 0 1 | 0 1 | 1 0   | 0 0  |
| 6       | 0 1 | 1 0 | 1 0   | 0 1  |
| 7       | 0 1 | 1 1 | 1 0   | 1 0  |
| 8       | 1 0 | 0 0 | 1 0   | 1 1  |
| 9       | 1 0 | 0 1 | 1 1   | 0 0  |

# GrayCode

It is the non-weighted code and it is not arithmetic codes. That means there are no specificweightsassignedtothebitposition. It has a very special feature that, only one

bit will change each time the decimal number is incremented as shown in fig. As only one bit changes at a time, the gray code is called as a unit distance code. The gray code is a cyclic code. Gray code cannot be used for arithmetic operation.

## ConvertabinarynumbertoaGraynumber

Let'sunderstandthealgorithmtogofrombinarytoGray.Seetheconversionfrom'11101' binary to its equivalent in Gray code.



# ConvertaGraynumber toabinarynumber

Let'sunderstandthealgorithmtogofrombinarytoGray.Seetheconversionfrom '11101' binary to its equivalent in Gray code.



# ApplicationofGraycode

- Graycodeispopularlyusedintheshaftpositionencoders.
- Ashaftpositionencoderproducesacodewordwhichrepresentstheangular position of the shaft.

### Importanceof parity Bit.

A parity bit is an extra bit included in binary message to make total number of 1's either odd or even. Parity word denotes number of 1's in a binary string. There are two parity system-even and odd.

# Evenparitysystem

In even parity system 1 is appended to binary string it thereisanodd number of 1's in string otherwise 0 is appended to make tot levennumber of 1's.

# Oddparitysystem

Inoddparitysystem,1isappendedtobinarystringifthereisevenanumber of 1's to make an odd number of 1's

# ImportanceofparityBit.

Thepurposeofaparitybitistoprovideasimplewaytochec Errors k for

# Logic Gates: AND, OR, NOT, NAND, NOR and with truth table.

**EX-ORgates** 

# WhatisLogicGates?

Logicgatesaretebalicbuildingblocksofanydigitalsystem.Itisan electroniccircuithavingoneormorethanoneinputandolyoneoutput. Therelationship Letweentheinputandtheoutputisbas dona certain logic. Based on this, logic gates are named as AND gate, OR gate, NOT gate etc.

# ANDGate

An AND gate is a logic gate having two or more inputs and  $\epsilon$  singleoutput. An AND gate operates on logical multiplication rules



Expression for AND gate Y=A.B Truth Table of AND gate

| Inj | Input |   |
|-----|-------|---|
| Α   | В     | Y |
| 0   | 0     | 0 |
| 0   | 1     | 0 |
| 1   | 0     | 0 |
| 1   | 1     | 1 |

## ORGate



ExpressionforORgateY=A+B

# TruthTable

| Input |   | Output |
|-------|---|--------|
| Α     | В | Y      |
| 0     | 0 | 0      |
| 0     | 1 | 1      |
| 1     | 0 | 1      |
| 1     | 1 | 1      |

### NOTGate

TheNOTgateisthemostbasiclogicgateofallotherlogicgates.NOTgateisalso known as an **inverter** 

NOT gate only has one input and one output it converts 0 into 1 or 1 into 0.



ExpressionforNOTgateZ=2

# TruthTable

| Inputs | Outputs |  |
|--------|---------|--|
| A      | Y       |  |
| 0      | 1       |  |
| 1      | 0       |  |

# NANDGate

TheNANDgateisaspecialtypeoflogicgateinthedigitallogiccircuit. The NAND gate is the combination of AND -NOT gate

TheNANDgate istheuniversalgate.ItmeansallthebasicgatessuchasAND,OR,and NOT gate can be constructed using a NAND gate. The output state of the NAND gate will be low only when all the inputs are high. Simply, this gate returns the complement result of the AND gate.



ExpressionforNANDgateZ=2.2

# TruthTable

| Input |   | Out Put |
|-------|---|---------|
| А     | В | Z=?.?   |
| 0     | 0 | 0       |
| 0     | 1 | 1       |
| 1     | 0 | 1       |
| 1     | 1 | 0       |

# NORGate

TheNORgateisalsoauniversalgate

TheNORgateisthecombinationoftheOR-NOTgate

TheNORgateistheuniversalgate.ItmeansallthebasicgatessuchasAND,OR, and

NOT gate can be constructed using a NOR gate.

TheoutputstateoftheNORgatewillbehighonlywhenalloftheinputsare low. Simply, this gate returns the complement result of the OR gate



#### ExpressionforNorgateZ=2+2

# TruthTable

| In | put | Out Put |
|----|-----|---------|
| А  | В   | Z=?+?   |
| 0  | 0   | 1       |
| 0  | 1   | 0       |
| 1  | 0   | 0       |
| 1  | 1   | 0       |

EX-OR



ExpressionforEX-ORgateZ=(2B+A2)

## TruthTable

| Input |   | Out Put |
|-------|---|---------|
| А     | В | Z=A⊕B   |
| 0     | 0 | 1       |
| 0     | 1 | 0       |
| 1     | 0 | 0       |
| 1     | 1 | 0       |

RealizeAND,OR,NOToperationsusingNAND,NORgates.

NANDandNOR gatesprovidethefollowingmeritsinthedigitallogic system design

- 1. Fabrication of NAND and NOR gates are easier than basic gates using in the integrated digital logic families
- 2. NumberoftransistorsusedtodesignNANDandNORgatesarealso less thanANDand ORgates.Sincethecoreareareducesintheintegrated digital circuits.
- 3. The conversion of NAND and NOR are more conveniet indigital design.
- 4. AllotherlogicgatescanberealizedcompletelyusingNANDorNOR gates.
- 5. Anydigitalckt.canbeimplementedperfectlyusingeitherNANDor NOR gates thus these are called as universal gate

### ImplementationofLogicgatesusingNANDGate

#### i) NOTgate

ThelogicsymbolandBooleanexpressionofNOTgateisrepresentedby



NANDequivalentrepresentationforNOTgateis

Theaboveexpression indicates that if the input terminals of NAND gate are Same shown in fig



#### ii) ANDGate

ThelogicsymbolandBooleanexpression of AND gate is represented by



Y=A.B

NANDequivalentrepresentationforANDgateis

#### Nowaboveexpressioncandrawnas

\_



#### iii) **OR gate:**



NANDequivalentrepresentationforORgateis



iv) **NORgate:** 



Y=?+? NANDequivalentrepresentationforNORgateis Y=? +?=?+?

=?.?



# v) Ex-OR gate:



NANDequivalentrepresentationforEx-ORgateis

Nowaboveexpressioncandrawnas



vi) Ex-NORgate:



 $Y=A \odot B= 22+AB$ 

NANDequivalentrepresentationforEx-NORgateis



## ImplementationofLogicgatesusingNOR Gate

#### i) NOTgate

The logic symbol and Boolean expression of NOT gate is represented by



NORequivalentrepresentationforNOTgateis

$$\frac{Z=?}{=?+?}$$

Nowaboveexpressioncandrawnas



#### ii) AND Gate

ThelogicsymbolandBooleanexpressionofANDgateisrepresented by



Y=A.B NANDequivalentrepresentationforANDgateis Y=A.B=2.2=2.+2



#### iii) ORgate:

The logic symbol and Boolean expression of OR gate is represented by



NORequivalentrepresentationforORgateis

Nowaboveexpressioncandrawnas



## iv) NANDgate:

The logic symbol and Boolean expression of NAND gate is represented by





NORequivalentrepresentationforNANDgateis



# v) Ex-ORgate:

ThelogicsymbolandBooleanexpressionofEx-OR gate is represented by



Y=A?+??NOR

equivalentrepresentationforEx-ORgateis

$$Y = \overline{A2 + 22}$$

$$= (A2).(22)$$

$$= (2+2).(A+2)$$

$$= (2+2)+(A+2)$$

$$= (2+2)+(A+2)$$

Nowaboveexpressioncandrawnas



### i) Ex-NORgate:

ThelogicsymbolandBooleanexpression of **Ex-NOR** gate is represented by



 $Y=A \odot B= 22 + AB$ NORequivalentrepresentationfor**Ex-NOR** gate is

$$Y = A \odot B = 27 + 27$$

$$= 27 + 27$$

$$= 27 + 27$$

$$= (27).(27)$$

$$=(\overline{2+2}).(\overline{2+2})$$

$$=(\overline{2+2}).(\overline{2+2})$$

$$=(\overline{2+2}).(\overline{2+2})$$

$$=(\overline{2+2})+(\overline{2+2})$$

Nowaboveexpressioncandrawnas



PROCEDURETOIMPLEMENTTHEBOOLEANFUNCTIONUSINGUNIVERSALGATE:

- 1. DrawalogicdiagramfortheBooleanfunctionusingbasicgatesi.e.AND,OR,and NOT
- 2. ReplacethegatewithequivalentNANDorNORrealization.
- 3. If any pathhas continuous two inversions, discard those terms to reduce the number of logic gates employed to implement the Boolean function.
- 4. RedrawthesimplifiedlogicdiagramastheUniversalgatesimplementation of Boolean function.

*Example:ImplementthefollowingBooleanfunctionusingminimumnumberof(i)NAND gates, (ii)NOR gates* 

Solution:

GivenBooleanfunction,

- (i) UsingNANDgates:
- 1. Step:1DrawalogicdiagramfortheBooleanfunctionusingbasicgatesi.e. AND,OR,and NOT



2. Step:2ReplacethegatewithequivalentNANDrealization.



**3**. Step:3Ifanypathhascontinuoustwo inversions,discardthosetermstoreduce the number of logic gates employed to implement the Boolean function.



In this case, both path are having two inversions in series so discard those inverter

4. Step:4RedrawthesimplifiedlogicdiagramastheUniversalgates implementation of Boolean function



- (ii) UsingNORgates:
- 1. Step:1DrawalogicdiagramfortheBooleanfunctionusingbasicgatesi.e. AND,OR,and NOT



2. Step:2ReplacethegatewithequivalentNORrealization.



3. Step:3Ifanypathhascontinuoustwo inversions, discard those terms to reduce the number of logic gates employed to implement the Boolean function.



Inthiscase, output section ehaving two inversions inseries so discard those inverter

4. Step:4RedrawthesimplifiedlogicdiagramastheUniversalgates implementation of Boolean function



# DifferentpostulatesandDe-Morgan'stheoremsinBoolean algebra.

a. ??=?+?

## Use Of Boolean Algebra For Simplification Of Logic Expression

# WhatisBoolean Algebra?

Boolean Algebra is used to analyze and simplify the digital (logic) circuits. It uses only the binary numbers i.e. 0 and 1. It is also called as **Binary Algebra**or**logical Algebra**. Boolean algebra was invented by **George Boole** in 1854

# RuleinBoolean Algebra

Following are the important rules used in Boolean algebra.

- I. Variable used can have only two values. Binary 1 for HIGH and Binary 0 for LOW.
- II. Complement of a variable is represented by an overbar (-). Thus, complement of variable B is represented as  $\overline{B}$ . Thus if B = 0 then  $\overline{B}$  = 1 and B = 1 then  $\overline{B}$  = 0.
- III. ORingofthevariablesisrepresentedbyaplus(+)signbetweenthem.For example ORing of A, B, C is represented as A + B + C.
- IV. LogicalANDingofthetwoormorevariableisrepresentedbywritingadot between them such as A.B.C. Sometime the dot may be omitted like ABC.

## BASICLAWSOFBOOLEANALGEBRA:

### 1. NOTLaw:

i. 
$$0=1$$
  
ii.  $1=0$ 

- iii. A=2
- 2. ANDLaws

- iii. A.A= A
- iv. A. 2=0
- 3. ORLaws:
  - i. A+0=A
  - ii. A+1=1
  - iii. A+A= A
  - iv. A+ 🗉=1

### 4. CommutativeLaws:

- i. A+A=B+A
- ii. A.B=B.A
- iii. A+B+C=C+B+C

iv. A.B.C=B.C.A=C.A.B

- 5. Associativelaws:
  - i. A+(B+C)=(A+B)+C
  - ii. A.(B.C)=(A.B).C
- 6. Distributivelaw:
  - i. A+BC=(A+B)(A+C)
  - ii. A(B+C)=AB+AC

#### BOOLEANTHEOREM

1. A+AB =A

Proof:A+AB=A(B+
$$\mathbb{Z}$$
)+AB  
=AB+A $\mathbb{Z}$ +AB  
=AB+ $\mathbb{Z}\mathbb{Z}$   
=A(B+ $\mathbb{Z}$ )  
=A .1  
=A

**2. A(A+B)=A** Proof: A(A+B)=A.A+A.B

=A+AB

=A

3. A+2B=A+B

Proof:  $A + \boxed{2}B = A + AB + \boxed{2}B$ =  $A + (A + \boxed{2})B$ = A + B

4. A. (□+B)= A Proof: A.(□+B)=A. □+AB =0+AB

5. AB+A.2=A
 6. (A+ B).(A+2)=A
 7. (A+ B).( A+C )= A+ BC
 8. AC+ 2BC=AC+BC

#### **DEMORGAN'S THEOREM:**

#### DUALITYTHEOREM:

Dualitytheoremsaythatinthelogicfunctionapplyingthefollowingchangesin the AND, OR and NOT operation doesn't affect the output.

- 1. Swap'0'and'1'presentintheexpression.
- 2. ReplacingANDoperationbyORoperation
- 3. ReplacingORoperationbyANDoperation

Examples:

b. 
$$A(B+C)=AB+AC$$

Afterapplyingdualitytheoremintheaboveexpression,itbecomes A + (

$$BC) = (A + B) . (A + C)$$

#### **ABSORPTIVETHEOREM:**

**TRANSPOSITION THEOREM:** 

USING THE THEOREM & LAWS, SIMPLIFY THE FOLLOWING EXPRESSION

2. **(**A+B)(A+C)

| =A.A+A.C+A.B+B.C | -Distributivelaw         |
|------------------|--------------------------|
| =A+A.C +A.B+B.C  | -IdempotentANDlaw(A.A=A) |
| =A(1+C)+A.B+B.C  | -Distributivelaw         |
| =A+AB+BC         | -IdentityORlaw(1+C=1)    |
| =A(1+B)+BC       |                          |
| =A.1+BC          |                          |

=A+BC

3. 2222+2222+2222+2222+222+22==2222+2222+2222+222+22==2(222+222+222+222+22+2)=2(222+222+222+222+2)=(2+2)(2+2)=A+D4. 222+222+222+222=222+222+222+222=222+222+222+222=222+222+22+22=222+2(2+2)=222+2(2+2)(2+2)=222+2(2+2)(2+2)=222+2(2+2)+22=2(22+2)+2(2+2)=2(22+2)+2(2+2)

```
=?(?+?)+??
```

=??+??+??

# Karnaugh MapFor2,3,4 Variable,SimplificationOfSOP And POS Logic Expression Using K-Map.

### A.BOOLEAN FUNCTION:

Boolean function consists of a set of Boolean variables to represent a number using Boolean connectivity's logical NOT, logical AND, logical OR operations, parenthesis and equality sign. It also known as Boolean expression.

Based on the arrangement of literals and terms Boolean expression is classified in two types such as,

- 1. SumofProduct(SOP)form
- 2. ProductofSum(POS)form

## 1. SumofProduct(SOP)form:

Sum of Product term is consisting of sum (OR operation) of many terms; the terms may consists of single literal or product of many literals (Variables). The sum of the terms is called SOP function.

Example:

- i. F(A,B,C)=222+22+22+222
- ii. F(x,y,z)=??+??+???
- iii. F(A,B,C,D)=2222+2222+2222+2222+2222

## a.StandardSumofProduct(SOP)form:

The SOP form of expression is said to be Standard Sum of Product formor Canonical form expression if the terms present in the expression contains all the literals present in the function.

Each individual term present in the expression must have all the literalsof a function.

ThestepstoconvertnoncanonicalSOPtoCanonicalorstandard SOP.

- 1. Findthemissingliteralineachproductterm.
- 2. Multiply(AND)eachproducttermtothetermhavingmissingliteralbyORingthe missing literal and its complement.
- 3. Expandthetermsandrearrangetheliteralsintheproduct terms.
- 4. Reduce the expression by omitting the repeated terms if any (i.e. A+A=A)

Example:

**i)** ConvertthegivenexpressionF(A,B,C)= A+ℤCintocanonicalSOP form.

Inthe given expression, literal Band C are missing in the 1<sup>st</sup> product term. So (B+ $\mathbb{Z}$ ) and (C+ $\mathbb{Z}$ ) are multiplied (AND) with the term A. Similarly, literal A is missing in the 2<sup>nd</sup> product term. So (A+ $\mathbb{Z}$ ) is multiplied (AND) with the product term  $\mathbb{Z}$ C.

Given;

$$F(A,B,C)=2+2\overline{2}$$

$$=2(2+2)+2\overline{2}(2+2)$$

$$=22+2\overline{2}+2\overline{2}\overline{2}+2\overline{2}\overline{2}$$

$$=22(2+2)+2\overline{2}(\overline{2}+2)+2\overline{2}\overline{2}+\overline{2}\overline{2}\overline{2}$$

$$=222+2\overline{2}\overline{2}+2\overline{2}\overline{2}+2\overline{2}\overline{2}+2\overline{2}\overline{2}$$

# 2. ProductofSum(POS)form:

Product of Sum (POS) term is consisting of sum (AND operation) of many terms;the terms may consists of single literal or product of many literals (Variables).The product of the set of sum terms is called POS function.

Example:

- i. F(A,B,C)=(2+2+2)(2+2)(2+2)(2+2)(2+2)
- ii. F(x,y,z)=(2+2)(2+2)(2+2+2)
- iii. F(A,B,C,D) = (2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2)(2+2+2)(2+2+2)(2+2+2)(2+2)(2+2+2)(2+2+2)(2+2+2)(2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2+2)(2+2)(2+2+2)(2+2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2)(2+2

# a)StandardProductofsum(POS)form:

The POS form of expression is said to be **Product of sum** form or Canonical form expression if the terms present in the expression contains all the literalspresent in the function.

Each individual term present in the expression must have all the literals of a function.

ThestepstoconvertnoncanonicalPOStoCanonicalorstandard POS.

- 1. Findthemissingliteralineachsumterm.
- 2. OReachsumtermtothetermhavingmissingliteralbyANDing(product)the missing literal and its complement.
- 3. Expandthetermsandrearrangetheliteralsinthesumterms.
- 4. Reduce the expression by omitting the repeated terms if any (i.e. A. A=A) Let us

see an example here.

## ConvertthegivenexpressionF(A,B,C)=(A+B)(B+C)intocanonicalPOSform.

In the given expression, literal C is missing in the 1<sup>st</sup>sum term. So  $(C.\overline{C})$  is added with the term (A+B).Similarly,literalAismissinginthe2<sup>nd</sup>sumterm.So(A.A)isadded with the term (B+C).

Given;

$$F(A,B,C)=(?+?)(?+?)$$

=(?+?)+(?.?)(?+?)+(?.?)

=(2+2+2)(2+2+2)(2+2+2)(2+2+2)

#### 3. SIMPLIFICATIONOFBOOLEANFUNCTION:

There are 3-different basic simplification methods available for minimizing Boolean function

- 1. Booleanalgebra
- 2. Karnaughmap
- 3. QuineMcCluskeymethod

#### a. KARNAUGHMAP(K-MAP):

Simplifying theBoolean functions using Boolean postulates and theorems. It is time consuming process and to re-write the simplified expressions after each step.

To overcome this difficulty,**Karnaugh**introduced a method for simplification of Boolean functions in an easy way.

This method is a graphical method for simplification of Boolean function which consists of 2<sup>n</sup> cells for 'n' variables. Each cell of K-map represents one of the **minterm**. The adjacent cells are differed only in single bit position.

#### ClassificationofK-Map:

DependsonthenumberofvariablesusedintheK-mapitisclassified as

- ii. 3-Variablek-map
- iii. 4-Variablek-map
- iv. 5-Variablek-map

#### 1. 2-Variablek-map:

Thenumberofvariable(n)=2 The

number of cells  $=2^n=2^2=4$ 



• The possible combinations of grouping 2 adjacent minterms are {( $m_0, m_1$ ), ( $m_2, m_3$ ), ( $m_0, m_2$ ) and ( $m_1, m_3$ )}.

| Vari | able | Minterm        | S              |
|------|------|----------------|----------------|
| А    | В    | Representation | mi             |
| 0    | 0    | [?] [?]        | $m_1$          |
| 0    | 1    | ??             | m <sub>2</sub> |
| 1    | 0    | ? ?            | m <sub>3</sub> |
| 1    | 1    | ? ?            | m4             |

(Mintermsof2-variableexpression)

#### 2. 3-Variablek-map:

Thenumberofvariable(n)=3 The

number of cells  $=2^n=2^3=8$ 

| X | 00             | 01             | 11             | 10             |
|---|----------------|----------------|----------------|----------------|
| 0 | m <sub>0</sub> | m <sub>1</sub> | m <sub>3</sub> | m <sub>2</sub> |
| 1 | m <sub>4</sub> | m <sub>5</sub> | m <sub>7</sub> | m <sub>6</sub> |

## 3. 4-Variablek-map:

Thenumberofvariable(n)=4

Thenumberofcells=2<sup>n</sup>=2<sup>4</sup>=16

| wx YZ | 00              | 01              | 11              | 10              |
|-------|-----------------|-----------------|-----------------|-----------------|
| 00    | m <sub>0</sub>  | m <sub>1</sub>  | m <sub>3</sub>  | m <sub>2</sub>  |
| 01    | m <sub>4</sub>  | m <sub>5</sub>  | m <sub>7</sub>  | m <sub>6</sub>  |
| 11    | m <sub>12</sub> | m <sub>13</sub> | m <sub>15</sub> | m <sub>14</sub> |
| 10    | m <sub>8</sub>  | m <sub>9</sub>  | m <sub>11</sub> | m <sub>10</sub> |

# Don'tcarecondition:

In some digital systems, nonessential minterms or maxterms may be introduced intheinputsequences.Suchnonessentialmintermsormaxtermsarecalledasdon'tcare condition in the Boolean expression.

These nonessential terms never occur in the input sequence of the system.

Normally, in K-Map don't care conditions are represented by symbol 'X'. Don't care values can be taken as either '0' or '1'.

Don't care conditions occur in the digital system sunder the following condition:

- i. If certain combinations of input variables are never occur, then the output functions of such combinations are considered as nonessential or don't care condition.
- ii. If certain combinations of variables are irrelevant even all the input combination of variables occurs, then the output functions of such combinations are considered as nonessential or don't care condition.

# GroupingcellforMinimization:

InK-map,mintermsaremarkedby'1'

maxterm are marked by'0'

don'tcarearemarkedby'd'or'x'i.eX='0'or '1'

In minterm function, don't care condition is considered as '1' if necessary for simplification or grouping cell. Else, it is marked by '0'

In maxterm function, don't care condition is considered as '0' if necessary for simplification or grouping cell. Else, it is marked by '1'

Grouping of cell or Loop of cell is process of combining adjacent cells for simplification.

Groupingisobtainedbycombining1'sor0'sof2<sup>i</sup>numbercells,wherei=0,1,2...,n (n -->number of variables used in the Boolean function.)

# IsolationCellor Singlecellgroup(i=0):

- i. K-mapcelliscalledasIsolationgroupwhennoadjacenthorizontalorvertical cell is '1'for minterm and'0' for maxterm.
- ii. Isolationcellcan'tbeusedforsimplification,itgivestheBooleanfunctionremain as same



**2-Cellgroup(i=1):**2cellgroupingisusedtodiscardanyvariablefromtwoadjacent cell in the simplification process

### **ProcedureforMintermfunction:**

- i. Groupthecellifak-mapcontainshorizontallyadjacentpair(2cell)ofcellsas1's
- ii. Groupthecellifak-mapcontainsverticallyadjacentpair(2cell)ofcellsas1's
- iii. If any cell contain 1 with a djacent vertical or horizontal cell as don't care condition 'X' then group those two cells by considering X=1
- iv. If any cell contain only don't care condition' X' then don't group those cells (Discard by considering as X=0)



#### ProcedureforMaxtermfunction:

- i. Groupthecellifak-mapcontainshorizontallyadjacentpairofcellsas0's
- ii. Groupthecellifak-mapcontainsverticallyadjacentpair(2cell)ofcellsas0's
- iii. If any cell contain 0 with a djacent vertical or horizontal cell as don't care condition 'X' then group those two cells by considering X=0
- iv. If any cell contain only don't care condition' X' then don't group those cells (Discard by considering as X=1)

| A           | and the | 13 | 0  | 1. 5      | DIAN    | Contraction | i.Um  | arme in a |
|-------------|---------|----|----|-----------|---------|-------------|-------|-----------|
| B B         |         |    |    | ABC       | BC      | BC          | BC    | BČ        |
| A 0 0       |         |    |    | Ā         | 0       | 1           | X     | 0         |
| A 0 1       |         |    |    | A         | 0       | 1           | 1     | 1 1       |
| (i)         |         |    |    | Earned of | at or a | (i          | i)    | . martali |
|             | BCD     | CD | ĒD | CD        | CD      |             |       |           |
|             | AB      | 0  | 1  | 0         | 1       |             |       |           |
|             | ĀB      | 0  | 1  | x         | 1       |             |       |           |
|             | AB      | 1  | 0  | 0         | 1       |             |       |           |
| N O HOME Y  | AB      | 0  | 1  | 15        | x       |             |       |           |
| Jam der har |         |    | (1 | ii)       | X       | 100         | - Mai |           |

**4-Cellgroup(i=2):**4cellgroupingisusedtodiscardanytwovariablesfromfour(4) adjacent cells in the simplification process

#### ProcedureforMintermfunction:

- i. Groupthecellifak-mapcontainshorizontallyfour(4)adjacentofcellsas1's
- ii. Groupthecellifak-mapcontainsverticallyfour)4)adjacentpailofcellsas1's
- iii. Group the cell If a K-map contain vertically two adjacent cell and horizontal two adjacent cellwhich adjacent to each other are 1's.
- iv. If any cellcontain 1's with adjacent vertically or horizontal cell as don't care condition 'X' then group those four cell by considering X=1.
- v. If any adjacent cell contain only don't care condition 'X' then don't group thosecells ( Discard by considering as X=0)







#### ProcedureforMaxtermfunction:

- i. Groupthecellifak-mapcontainshorizontallyfour(4)adjacentofcellsas0's
- ii. Groupthecellifak-mapcontainsverticallyfour)4)adjacentpailofcellsas0's
- iii. Group the cell If a K-map contain vertically two adjacent cell and horizontal two adjacent cellwhich adjacent to each other are 0's.
- iv. If any cellcontain 1's with adjacent vertically or horizontal cell as don't care condition 'X' then group those four cell by considering X=0.
- v. If any adjacent cell contain only don't care condition 'X' then don't group thosecells ( Discard by considering as X=1)





**8-Cellgroup(i=3):**8cellgroupingisusedtodiscardanythree(3)variablesfrom eight (8) adjacent cells in the simplification process

#### ProcedureforMintermfunction:

- i. Groupthecellifak-mapcontainshorizontallyeight(8)adjacentofcellsas1's
- ii. Groupthecellifak-mapcontainsverticallyeight(8))adjacentpailofcellsas1's
- iii. If any cell contain 1's with adjacent vertically or horizontal cellas don't care condition 'X' then group those eight (8) cell by considering X=1.
- iv. If any adjacent cell contain only don't care condition 'X' then don't group thosecells ( Discard by considering as X=0)







#### **ProcedureforMaxtermfunction:**

- i. Groupthecellifak-mapcontainshorizontallyeight(8)adjacentofcellsas0's
- ii. Groupthecellifak-mapcontainsverticallyeight(8))adjacentpailofcellsas0's
- iii. If any cell contain 0's with adjacent vertically or horizontal cellas don't care condition 'X' then group those eight (8) cell by considering X=0.
- iv. If any adjacent cell contain only don't care condition 'X' then don't group thosecells ( Discard by considering as X=1)

| AB | CD | CD | CD | CD |        |
|----|----|----|----|----|--------|
| ĀB | 1  | 1  | 1  | 1  | 00 D   |
| ĀВ | 1  | 1  | 1  | 1  | 12-1-1 |
| AB | 0  | 0  | 0  | 0  | >/     |
| AB | 0  | 0  | 0  | 0  | 1. 1   |

| AB | CD | ĒD | CD | CD | the Site          |
|----|----|----|----|----|-------------------|
| ĀB | 0  | 0  | 1  | 0  |                   |
| ĀВ | 0  | 0  | 0  | 1  | Appendiate of the |
| AB | 0  | 0  | ×  | 1  | C-UTIN CAL        |
| AB | 0  | 0  | 1  | 1  |                   |





#### SHORTQUESTIONSANDANSWERS

#### 1. Definedigitalsystem?

Ans.A digital system is a system which deals with discrete signal. The input and output of this system is two binary value which is 0 and 1. Examples of digital systems are mobile phones, radio, megaphones and many more

#### 2. Listtheapplicationsofdigitalsystem?

Ans.MobilePhones,CalculatorsandDigitalComputers

Radios and communication Devices.

#### 3. Whatismeantbybit?

Ans. Single digit that used to represent the number is called bit i.e 1 or 0

#### 4. Whatisradixnumbersystem?

Ans. Radix (base)number systemisa generalrepresentationofallthenumber system. It represent the weight of each digits present in the number system. Example:

Base of binary no. system =2 Baseofoctalno.system =8 Baseofhexadecimalno.system=16

#### 5. Definebinarycode?

**Ans.** A group of binary bit that are used to represent the characters, numbers, lettersor words or symbol iscalled asbinary codes.

The digital data is represented, stored and transmitted as group of binary bits. This group is also called asbinary code. The binary code is represented by the number as well as alphanumeric letter.

#### 6. Whatareweightedbinarycodes?

**Ans.** Acodewhichconsistsofbitweightforeachdigitpresentinthebinary code is called weighted binary codes

Example: BCDcodes

#### 7. Whatarenon-weightedbinarycodes?

Ans. Acodewhichisnothavinganybitweightforthedigitpresentinthe binary code is called non-weighted binary codes

Example:Excess-3code,graycode.

#### 8. Whatisgraycode?Whyisitcalledasreflectivecodeandcycliccode?

**Ans.**Itisthe non-weightedbinary code, that means thereare nospecific weights assigned to the bit position. only one bit position will changeeach time the decimal number is incremented so called reflective code. Also the adjacent gray representation differs in only binary bit hence it is referred as cyclic code.

#### 9. StatetheassociativepropertyofBooleanalgebra

**Ans.** Associative law defines that the grouping of variable in the multivariable AND and OR operation does not change the output.

i. A+(B+C)=(A+B)+C

ii. A.(B.C)=(A.B).C

#### 10. StatethedistributivepropertyofBooleanalgebra

**Ans**. Associative law defines that the distribution of variable with AND operation over OR operation is equal to distribution of variable with OR operation over AND operation

i. A+BC=(A+B)(A+C)

ii. A(B+C)=AB+AC

#### 11. StatetheDeMorgan'stheorem

- i. ?.?=?+?
- ii. ?+?=?.?

#### 2. COMBINATIONALLOGICCIRCUITS

#### Givetheconceptofcombinationallogic circuits:

Acombinational circuitisthedigitallogic circuitin which the output dependson the combination of present inputs applied to the circuit and It does not depend past input

Combinational circuits are developed using combination of AND, OR, NOT, NAND, and NOR logic gates.

CombinationalLogic Circuitsare memory lessdigitallogiccircuitswhoseoutput at any instant in time depends only on the combination of its inputs

The combinational logic circuits have no feedback circuit is used.



#### Halfaddercircuitandverifyitsfunctionalityusingtruthtable:

Halfadderisacombinationalcircuitwhichconsistsoftwobinaryinputvariables called augend and addendand two binary output variables called sum and carry. In the addition result, the lower significant bit is called as sum and the higher significant bit is called as carry.

Truthtable

| Tuttiable |      |       |     |  |  |  |
|-----------|------|-------|-----|--|--|--|
| Ir        | nput | Outp  | ut  |  |  |  |
| А         | В    | Carry | Sum |  |  |  |
| 0         | 0    | 0     | 0   |  |  |  |
| 0         | 1    | 0     | 1   |  |  |  |
| 1         | 0    | 0     | 1   |  |  |  |
| 1         | 1    | 1     | 0   |  |  |  |

| In | iput | Outpi | ut  |
|----|------|-------|-----|
| А  | В    | Carry | Sum |
| 0  | 0    | 0     | 0   |
| 0  | 1    | 0     | 1   |
| 1  | 0    | 0     | 1   |
| 1  | 1    | 1     | 0   |
|    |      |       |     |



Sum=??+??=?⊕?



 ${\bf Realizea Half-adderusing NAND gates only and NOR gates only.}$ 

Half-adderusingNANDgates



#### Half-adderusingNANDgates



#### Fulladdercircuitandexplainitsoperationwithtruthtable:

Full adder is a combinational circuit which consists of three binary input variables called augend and addendand two binary output variables called sum and carry. In the addition result, the lower significant bit is called as sum and the higher significant bit is called as carry

| IIutiltable |   |     |      |        |  |  |
|-------------|---|-----|------|--------|--|--|
| Inputs      |   |     | Οι   | utputs |  |  |
| А           | В | Cin | Cout | S      |  |  |
| 0           | 0 | 0   | 0    | 0      |  |  |
| 0           | 0 | 1   | 0    | 1      |  |  |
| 0           | 1 | 0   | 0    | 1      |  |  |
| 0           | 1 | 1   | 1    | 0      |  |  |
| 1           | 0 | 0   | 0    | 1      |  |  |
| 1           | 0 | 1   | 1    | 0      |  |  |
| 1           | 1 | 0   | 1    | 0      |  |  |
| 1           | 1 | 1   | 1    | 1      |  |  |

Truthtable





For Sum



| BC | <sup>in</sup> 00 | 01             | _ 11           | 10             |
|----|------------------|----------------|----------------|----------------|
| 0  | 0                | $(\mathbf{i})$ | 0              | $(\mathbf{i})$ |
| 1  | (1)              | 0              | $(\mathbf{i})$ | 0              |

 $Sum = \overline{A} \ \overline{B}C_{in} + \overline{A}\overline{B}\overline{C}_{in} + \overline{A}\overline{B} \ \overline{C}_{in} + A\overline{B}C_{in}$ 

K-mapcanbesimplifiedas

$$SUM = \overline{A} \ \overline{B} C_{in} + \overline{A} \ \overline{B} \ \overline{C}_{in} + \overline{A} \ \overline{B} \ \overline{C}_{in} + \overline{A} \ \overline{B} \ \overline{C}_{in} + \overline{A} \ \overline{B} \ C_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \left[ (\overline{A} + B) \cdot (A + \overline{B}) \right] + \overline{C}_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \ (\overline{A} \ \overline{B} \cdot \overline{\overline{A}} \ \overline{B}) + \overline{C}_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B}) + \overline{C}_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B}) + \overline{C}_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

$$= C_{in} \ (\overline{A} \ \overline{B} + \overline{A} \ \overline{B})$$

Fulladdercircuitdiagram



#### Realizefull-adderusingtwoHalf-addersandanOR– gateandwritetruth table.

Thefulladdercanbeimplementedwithtwohalfaddersby cscading them.ThesumoutputoffirsthalfadderisEx-ORofAandB. Thesum outputof full adder is Ex-OR of Cin and output of first half adder.

> Truthtable Outputs Inputs В S А  $C_{\text{in}}$ Cout

#### k-map

For Carry (Cout)

For Sum



Cout = AB+A Cin+B Cin

Sum = A BCin+ABCin+AB Cin+ABCin

11

0

(i)

10

1

0

K-mapcanbesimplifiedas

 $SUM = \overline{A} \overline{B} C_{in} + \overline{A} \overline{B} \overline{C}_{in} + A \overline{B} \overline{C}_{in} + A \overline{B} C_{in}$  $= C_{in} (\overline{A} \overline{B} + A \overline{B}) + \overline{C}_{in} (A \overline{B} + \overline{A} \overline{B})$  $= C_{in} [(\overline{A} + \overline{B}) \cdot (A + \overline{B})] + \overline{C}_{in} (A \overline{B} + \overline{A} \overline{B})$  $= C_{in} (\overline{A} \overline{B} \cdot \overline{\overline{A}} \overline{B}) + \overline{C}_{in} (A \overline{B} + \overline{A} \overline{B})$  $= C_{in} (\overline{A} \overline{B} + \overline{\overline{A}} \overline{B}) + \overline{C}_{in} (A \overline{B} + \overline{A} \overline{B})$  $= C_{in} (\overline{A} \overline{B} + \overline{\overline{A}} \overline{B}) + \overline{C}_{in} (A \overline{B} + \overline{A} \overline{B})$  $= C_{in} (\overline{A} \overline{B} + \overline{\overline{A}} \overline{B}) + \overline{C}_{in} (A \overline{B} + \overline{A} \overline{B})$  $= C_{in} \oplus (A \oplus \overline{B})$ 

Cout=???;+???;+??

$$=(2+2)22_{22}+(2+2)22_{22}+22$$
  
=222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{22}+222\_{



Blockdiagram



#### Circuit diagram

#### Fullsubtractorcircuitandexplainitsoperationwithtruthtable.:

a. Half adder circuit and verify its functionality using truth

**table:**Half subtract is a combinational circuit which consists of two binary input variables calledminuendand

subtrahendandtwobinaryoutputvariablescalleddifferenceand borrow. In the two bit result, the lower significant bit is called as difference and the higher significant bit is called as borrow.

| Α | В | Borrow | Difference |
|---|---|--------|------------|
| 0 | 0 | 0      | 0          |
| 0 | 1 | 1      | 1          |
| 1 | 0 | 0      | 1          |
| 1 | 1 | 0      | 0          |

#### Truthtable

K- map

For Difference



Difference = AB + AB = A⊕B For Borrow



Borrow = AB

Logicdiagram



#### b.Fullsubtractorcircuit ndexplainitsoperationwithtruthtable.:

Fullsubtractionisacombinationalcircuitwhichconsistsofthreebinaryinput variablescalledminuendsandsubtrahends andtwobinaryoutputvariablescalled difference and borrow out. In the subraction result, the lower significant bit is called as differenceand the higher significant bit is called as borrowout

#### Truthtable

| Inputs |   |     | Out | puts |
|--------|---|-----|-----|------|
| A      | в | Bin | D   | Bout |
| 0      | 0 | 0   | D   | 0    |
| 0      | 0 | 1   | 1   | 1    |
| 0      | 1 | 0   | 1   | 1    |
| 0      | 1 | 1   | 0   | 1    |
| 1      | 0 | 0   | 1   | 0    |
| 1      | 0 | 1   | 0   | 0    |
| 1      | 1 | 0   | 0   | 0    |
| 1      | 1 | 1   | 1   | 1    |

Table 3.9 Truth table for full-subtractor





Difference =  $\overline{A} \ \overline{B}B_{in} + \overline{A} B \ \overline{B}_{in} + A \ \overline{B} \ \overline{B}_{in} + A \ B B_{in}$ =  $B_{in}(\overline{A} \ \overline{B} + A B) + \overline{B}_{in}(\overline{A} \ B + A \ \overline{B})$ =  $B_{in}(A \odot B) + \overline{B}_{in}(A \oplus B)$ =  $B_{in}(\overline{A \oplus B}) + \overline{B}_{in}(A \oplus B)$ =  $B_{in}(\overline{A \oplus B}) + \overline{B}_{in}(A \oplus B)$ 



Logic circuit for Full subtractor

## 2.5Realizefull-subtractionusingtwoHalf-subtractor andanOR–gateand write truth table.

The full subtractor can be implemented with two half subtractors by cascading them. The difference output of first half subtractor is Ex-OR of A and B. The difference output of full subtractor is Ex-OR of Bin and output of first half subtractor.

Similarly, the borrow output of first half subtractor is ORed with the borrow output of second half subtractor toget the borrow output of full subtractor.

Simplification of Difference and Borrow

Difference = 
$$\overline{A} \ \overline{B} B_{in} + A B B_{in} + A \overline{B} B_{in} + A B B_{in}$$
  
=  $B_{in} (\overline{A} \ \overline{B} + A B) + \overline{B}_{in} (\overline{A} B + A \overline{B})$   
=  $B_{in} (A \odot B) + \overline{B}_{in} (A \oplus B)$   
=  $B_{in} (\overline{A \oplus B}) + \overline{B}_{in} (A \oplus B)$   
=  $B_{in} \oplus (A \oplus B)$ 

Borrow = 
$$\overline{A} B + \overline{A} B_{in} + B B_{in}$$
  
=  $\overline{A} B + \overline{A} B_{in} (B + \overline{B}) + B B_{in} (A + \overline{A})$   
=  $\overline{A} B + \overline{A} B B_{in} + \overline{A} \overline{B} B_{in} + A B B_{in} + \overline{A} B B_{in}$   
=  $\overline{A} B (1 + B_{in} + B_{in}) + \overline{A} \overline{B} B_{in} + A B B_{in}$   
=  $\overline{A} B + \overline{A} \overline{B} B_{in} + A B B_{in}$   
=  $\overline{A} B + B_{in} (\overline{A} \overline{B} + A B)$   
=  $\overline{A} B + B_{in} (A \odot B)$   
=  $\overline{A} B + B_{in} (\overline{A} \oplus B)$ 

Using the simplified boolean expressions for difference and l orrowoutput, the full subtractor can be realized



Realization of full subtractor with two half subtractors

#### 2.7Operationof4X1Multiplexersand1 X4demultiplexer

**Multiplexer** is a cominational circuit that has maximum of 2<sup>n</sup> number data inputs, 'n' number of selection controllines and single output line. Oe of these data inputs will be connected to the output based on the values of selection lines. Shown in figure.



 $\label{eq:Where I0,I1,I3,I4,...,In} are the input line, Y is the output line and S_0, S_1, \dots, S nare the selection line.$ 

#### a.4x1Multiplexer

4x1MultiplexerhasfourdatainputsI<sub>3</sub>,I<sub>2</sub>,I<sub>1</sub>&I<sub>0</sub>,twoselectionliness<sub>1</sub>&s<sub>0</sub>andone output Y. The **block diagram** of 4x1 Multiplexer is shown in the following figure.



One of these 4 inputs will be connected to the output based on the combination of inputs present at these two selection lines. Truth table of 4x1 Multiplexer is shown below.

| Selection Lines |    | Output         |
|-----------------|----|----------------|
| S <sub>1</sub>  | So | Y              |
| 0               | 0  | Io             |
| 0               | 1  | l <sub>1</sub> |
| 1               | 0  | I <sub>2</sub> |
| 1               | 1  | 13             |



Logiccircuitdiagram

#### **De-Multiplexer**:

**De-Multiplexer**is a combinational circuit that performs the reverse operation of Multiplexer. It has single input, 'n' selection lines and maximum of 2<sup>n</sup> outputs. De-Multiplexer is also called as **De-Mux**.

#### 1x4De-Multiplexer

1x4 De-Multiplexer has one input I, two selection lines, s1& s0and four outputs Y3, Y2, Y1&Y0. Theblock diagramof 1x4 De-Multiplexer is shown in the following figure.



The single input 'I' will be connected to one of the four outputs, Y3to Y0based on the values of selection lines s1& s0. TheTruth tableof 1x4 De-Multiplexer is shown below.

| Selection<br>inputs |    | outputs |    |       |    |
|---------------------|----|---------|----|-------|----|
| $S_1$               | So | Y3      | Y2 | $Y_1$ | Y0 |
| 0                   | 0  | 0       | 0  | 0     | 1  |
| 0                   | 1  | 0       | 0  | 1     | 0  |
| 1                   | 0  | 0       | 1  | 0     | 0  |
| 1                   | 1  | 1       | 0  | 0     | 0  |

From the above Truth table, we can directly write the **Boolean functions** for each output as

 $Y_{0}=I$   $S_{1}S_{0}Y_{1}=IS_{1}$   $S_{0}Y_{2}=IS_{1}$   $S_{0}Y_{3}=I$   $S_{1}S_{0}$ 55



Logiccircuitdiagram

#### WorkingofBinary-DecimalEncoder&3 X8Decoder.

#### a.Decoder

Decoder isacombinational circuit that has multiple input multiple output that is 'n' number of input lines and maximum of 2<sup>n</sup> number of output lines.

OneoftheseoutputswillbeactiveHighbasedonthecombinationofinputs present, when the decoder is enabled. That means decoder detects a particular code. i.e Inthedecoder,thecombinationofinput informationlinesdefinethelog coutputofany one. outputlineaslogichighat atimeandtherestoftheoutputlinesarebeigfixedto logic 0. The outputs of the decoder are nothing but the min termsof 'n' input variableslines, when it is enabled.

### 2 to4Decoder

Let2to4DecoderhastwoinputsA<sub>1</sub>&A<sub>0</sub>andfouroutputsY<sub>3</sub>,Y<sub>2</sub>,Y<sub>1</sub>&Y<sub>0</sub>. The **block diagram** of 2 to 4 decoder is shown in the following figure.

```
i.e inputlines'n'=2
```

output lines=2<sup>n</sup>=2<sup>2</sup>=4



One of these four outputs will be '1' for each combination of inputs when enable, Eis'1'. The **Truth table** of 2 to 4 decoder is shown below.

| Enable | Inp            | outs           |                | Out            | puts           |                |
|--------|----------------|----------------|----------------|----------------|----------------|----------------|
| E      | A <sub>1</sub> | A <sub>0</sub> | Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> |
| 0      | Х              | Х              | 0              | 0              | 0              | 0              |
| 1      | 0              | 0              | 0              | 0              | 0              | 1              |
| 1      | 0              | 1              | 0              | 0              | 1              | 0              |
| 1      | 1              | 0              | 0              | 1              | 0              | 0              |
| 1      | 1              | 1              | 1              | 0              | 0              | 0              |

 $From Truth table, we can write the {\it Boolean functions} for each output as$ 



### 3 to8Decoder

Let3to8Decoderhas3inputsA<sub>2</sub>A<sub>1</sub>&A<sub>0</sub>and8outputsY<sub>7</sub>,Y<sub>6</sub>,Y<sub>5</sub>,Y<sub>4</sub>,Y<sub>3</sub>,Y<sub>2</sub>,Y<sub>1</sub>&Y<sub>0</sub>. The **block diagram** of 3 to 8 decoder is shown in the following figure.

i.einputlines'n'=3

outputlines= $2^n=2^3=8$ 

| Enable | Ι              | nput  | s              | Outputs |    |            |                       |            |                |                |                       |
|--------|----------------|-------|----------------|---------|----|------------|-----------------------|------------|----------------|----------------|-----------------------|
| Е      | A <sub>3</sub> | $A_1$ | A <sub>0</sub> | Y7      | Y6 | <b>Y</b> 5 | <b>Y</b> <sub>4</sub> | <b>Y</b> 3 | Y <sub>2</sub> | $\mathbf{Y}_1$ | <b>Y</b> <sub>0</sub> |
| 0      | х              | х     | х              | 0       | 0  | 0          | 0                     | 0          | 0              | 0              | 0                     |
| 1      | 0              | 0     | 0              | 0       | 0  | 0          | 0                     | 0          | 0              | 0              | 1                     |
| 1      | 0              | 0     | 1              | 0       | 0  | 0          | 0                     | 0          | 0              | 1              | 0                     |
| 1      | 0              | 1     | 0              | 0       | 0  | 0          | 0                     | 0          | 1              | 0              | 0                     |
| 1      | 0              | 1     | 1              | 0       | 0  | 0          | 0                     | 1          | 0              | 0              | 0                     |
| 1      | 1              | 0     | 0              | 0       | 0  | 0          | 1                     | 0          | 0              | 0              | 0                     |
| 1      | 1              | 0     | 1              | 0       | 0  | 1          | 0                     | 0          | 0              | 0              | 0                     |
| 1      | 1              | 1     | 0              | 0       | 1  | 0          | 0                     | 0          | 0              | 0              | 0                     |
| 1      | 1              | 1     | 1              | 1       | 0  | 0          | 0                     | 0          | 0              | 0              | 0                     |

 $From Truth table, we can write the {\it Boolean functions} for each output as$ 

$$Y_{0} = EA_{2} \qquad A_{1}$$

$$A_{0}Y_{1} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{2} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{2} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{3} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{4} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{5} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{6} = E \qquad A_{2} \qquad A_{1}$$

$$A_{0}Y_{7} = EA_{2}A_{1}A$$

0

Logical circuit of the above expression sis given below:



Logicdiagram3to8linedecoder

#### Encoder:

An encoder is a multiple input multi output combinational digital circuit that performs the inverse operation of a decoder. It means that an encoder converts the 2<sup>n</sup>number of coded inputs into n number of coded outputs.



The output lines of a digital encoder generate the binary equivalent of the input line whose value is equal to 1 and are available to encode either a decimal or hexadecimal input pattern to typically a binary or B.C.D (binary coded decimal) output code

#### 4 to2lineEncoder:

There are four inputs (Y0, Y1, Y2, and Y3) and two outputs (A0 and A1) in the 4 to2lineencoder.Inaddition,Togettherespectivebinarycodeontheoutputside,one

inputlineatatimeissettotrueina4-inputline.The4to2lineencoder'sblock diagram and truth table are shown below.



|    | Inp            | Outputs |       |    |    |
|----|----------------|---------|-------|----|----|
| Y3 | Y <sub>2</sub> | $Y_1$   | $Y_0$ | A1 | Ao |
| 0  | 0              | 0       | 1     | 0  | 0  |
| 0  | 0              | 1       | 0     | 0  | 1  |
| 0  | 1              | 0       | 0     | 1  | 0  |
| 1  | 0              | 0       | 0     | 1  | 1  |

 $The terms A_0 and A_1 are logically expressed as follows:$ 

$$A_1 = Y_3 + Y_2$$
  
 $A_0 = Y_3 + Y_1$ 

#### **Circuit Diagram**

TwoinputORgatescanbeusedtoimplementtheaforementionedtwoBoolean functions. Further, The 4 to 2 encoder circuit diagram is given in the graphic below.



#### **Usesof Encoder**

Inalldigitalsystems, these systems are relatively simple to operate.

To convertade cimal number to a binary number, encoders are employed. The goalisto complete a binary operation like addition, subtraction, multiplication, and so on.

#### Disadvantages

The disadvantages of a standard encoder are listed below.

- Whenalloftheencoder'soutputsare0,there isambiguity.Becausewhenonlytheleast significantinputisoneorwhenallinputsarezero,itcouldbethecode inputs. n atchingthe
- Whenmorethanoneinputissettohigh,theencodergeneratesanoutputthatmayor maynotbethepropercode.IfbothY3andY6are'1',forexample,theecoder outputs 111.ThisisneitherthecomparablecodeforY3,whenitis'1',norisittheequivalent code for Y6, when it is '1'.

## WorkingofTwobitmagnitudecomparator.

AmagnitudedigitalComparatorisacombinationalcircuitthat**comparestwo digitalor binary numbers** in ordertofindoutwhetheronebinarynumber isequal,less than, or greater than the other binary number. We logically design a circuit for which we will have two inputs one for A and the other for B and have three output terminals, one for A > B condition, one for A = B condition, and one for A < B condition.

$$\begin{array}{c|c}
A & & & \\
N & - & bit \\
Comparator & & A = B \\
B & & & A < B
\end{array}$$

| Trutł | ntable |       |    |         |     |                   |
|-------|--------|-------|----|---------|-----|-------------------|
|       | Inj    | out   |    | Out put |     |                   |
| I     | 4      | ]     | В  | A>B     | A=B | A <b< td=""></b<> |
| A1    | A      | $B_1$ | Bo |         |     |                   |
| 0     | 0      | 0     | 0  | 0       | 1   | 0                 |
| 0     | 0      | 0     | 1  | 0       | 0   | 1                 |
| 0     | 0      | 1     | 0  | 0       | 0   | 1                 |
| 0     | 0      | 1     | 1  | 0       | 0   | 1                 |
| 0     | 1      | 0     | 0  | 1       | 0   | 0                 |
| 0     | 1      | 0     | 1  | 0       | 1   | 0                 |
| 0     | 1      | 1     | 0  | 0       | 0   | 1                 |

| 0 | 1 | 1 | 1 | 0 | 0 | 1 |
|---|---|---|---|---|---|---|
| 1 | 0 | 0 | 0 | 1 | 0 | 0 |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 |
| 1 | 0 | 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 | 0 | 1 | 0 |

From the above truth table K-map for each output can be drawn as follows:



 $A > B = A_1 A_0 \overline{2}_0 + \overline{2}_1 \overline{2}_0 A_0 + A_1 \overline{2}_1$ 



 $A=B = \overline{\mathbb{D}}_{1}\overline{\mathbb{D}}_{0}\overline{\mathbb{D}}_{1}\overline{\mathbb{D}}_{0} + \overline{\mathbb{D}}_{1}A_{0}\overline{\mathbb{D}}_{1}B_{0} + A_{1}A_{0}B_{1}B_{0} + A_{1}\overline{\mathbb{D}}_{0}B_{1}\overline{\mathbb{D}}_{0}$ 

 $= (\mathbb{P}_{1}\overline{\mathbb{P}_{1}} (\mathbb{P}_{0}\overline{\mathbb{P}}_{0} + \mathbb{P}_{0}\mathbb{P}_{0}) + \mathbb{P}_{1}\mathbb{P}_{1}(\mathbb{P}_{0}\mathbb{P}_{0} + \mathbb{P}_{0}\overline{\mathbb{P}}_{0})$  $= (\mathbb{P}_{1}\overline{\mathbb{P}_{1}} + \mathbb{P}_{1}\mathbb{P}_{1})(\mathbb{P}_{0}\mathbb{P}_{0} + \mathbb{P}_{0}\overline{\mathbb{P}}_{0})$  $= (\mathbb{P}_{1} \odot \mathbb{P}_{1})(\mathbb{P}_{0} \odot \mathbb{P}_{0})$ 



 $A{<}B = \boxed{2}_{1}\boxed{2}_{0}\boxed{2}_{1}{+}\boxed{2}_{1}\boxed{2}_{0}\boxed{2}_{0}{+}\boxed{2}_{1}\boxed{2}_{1}$ 



## **3.SEQUENTIALLOGIC CIRCUITS**

The outputs of the sequential circuits depend on both the combination of present inputs and previous outputs. The previous output is treated as the present state. So, the sequentialcircuitcontainsthecombinationalcircuitanditsmemory storageelements. A sequentialcircuitdoesn'tneedtoalwayscontainacombinational circuit.So, the sequential circuit can contain only the memory element.



BLOCKDIAGRAMOFSEQUENTIALCKT

Differencebetweenthecombinationalcircuitsandsequentialcircuitsaregiven below:

|   | CombinationalCircuits                | SequentialCircuits                      |  |  |
|---|--------------------------------------|-----------------------------------------|--|--|
| 1 | The outputs of the combinational     | Theoutputsofthesequentialcircuits       |  |  |
|   | circuitdependonlyonthepresent inputs | dependonboth presentinputsand           |  |  |
|   |                                      | present state(previous output).         |  |  |
| 2 | Thefeedbackpathisnotpresentinthe     | Thefeedbackpath ispresent in the        |  |  |
|   | combinationalcircuit.                | sequentialcircuits.                     |  |  |
| 3 | In combinational circuits, memory    | In the sequential circuit, memory       |  |  |
|   | elements are not required.           | elementsplayanimportantroleand          |  |  |
|   |                                      | require.                                |  |  |
| 4 | Theclocksignalisnotrequiredfor       | Theclocksignalisrequired for sequential |  |  |
|   | combinationalcircuits.               | circuits.                               |  |  |
| 5 | Thecombinationalcircuitissimpleto    | Itisnotsimpletodesignasequential        |  |  |
|   | design.                              | circuit.                                |  |  |

State the necessity of clock and give the concept of level clocking andedge triggering,

1.Clock:

A clock signalis a periodic signalin whichON time and OFF time neednotbe the same.WhenONtimeandOFFtimeoftheclocksignal arethesame, a squarewaveisused torepresenttheclocksignal.Belowisa diagramwhich representstheclocksignal:



Aclocksignalisconsideredasthesquarewave.Sometimes,thesignal stays at logic, either high 5V or low 0V, to an equal amount of time. It repeats with a certain time period, which will be equal to twice the 'ON time' or 'OFF time'.

#### TypesofTriggering

Thesearetwotypesoftriggeringinsequential circuits:

#### Level triggering

ThelogicHighandlogicLo <sub>V</sub> arethetwolevelsintheclocksignal.Inleveltriggering, whentheclockpulseisata <sub>p</sub>articularlevel,onlythenthecircuitisacti ated.Thereare thefollowingtypesofleveltriggering:

#### Positivelevel triggering

In a positive level triggering, the signal with Logic High occurs. So, in this triggering, the circuit is operated with such type of clock signal. Below is the diagram of positive level triggering:



#### Negativelevel triggering

Innegativeleveltriggering, the signal with Logic Lowoccurs. So, in thit riggering, the circuit isoperated with such type of clock signal. Below is the diagram of Negative level triggering:



#### Edgetriggering

Inclocksignalofedgetriggering, two types of transitions occur, i.e., transitioneither from Logic Low to Logic High or Logic High to Logic Low.

Basedonthetransitions of the clock signal, there are the following types of edge triggering:

#### Positiveedge triggering

The transition from Logic Low to Logic High occurs in the clock signal of positive edge triggering.So,inpositiveedgetriggering,thecircuitisoperatedwithsuchtypeofclock signal.Thediagramofpositieedgetriggeringisgivenbelow.



#### Negativeedge triggering

The transition from Logic Highto Logic low occurs in the clock signal of negative edge triggering. So, innegative edge triggering, the circuit is operated with such type of clock signal. The diagram of negative edge triggering is given below.



#### Whatisflipflop?

Flip-Flop is popularly known as the basic digital memory circuit. It is an edge triggered synchronoussequential logic circuit that is capable of storing single bit binary information. It has two states as logic 1(High) and logic 0(low) states. A flip flop is a sequential circuit which consists of a single binary state of information or data. The digital circuit is a flip flop which has two outputs and are of opposite states. It is also known as a Bistable Multivibrator.

#### **ClockedSRflipflop**

SR(Set-Reset)flip-flopisaclockedsequentialcircuitwhichiscontrolledbyedge triggered CLK control signal.



LogicdiagramusingANDandNORgate Truth

| Γ | al | bl  | le |
|---|----|-----|----|
| - | ~  | ~ - | ~  |

|     | Inputs |   | Out | tputs | States    |  |  |
|-----|--------|---|-----|-------|-----------|--|--|
| CLK | S      | R | Q   | ?     |           |  |  |
| 0   | 0      | 0 | NC  | NC    | No.change |  |  |
| 0   | 0      | 1 | NC  | NC    | No.change |  |  |
| 0   | 1      | 0 | NC  | NC    | No.change |  |  |
| 0   | 1      | 1 | NC  | NC    | No.change |  |  |
| 1   | 0      | 0 | NC  | NC    | No.change |  |  |
| 1   | 0      | 1 | 0   | 1     | Reset     |  |  |
| 1   | 1      | 0 | 1   | 0     | Set       |  |  |
| 1   | 1      | 1 | Х   | Х     | No.change |  |  |

#### ClockedSRflipflopwithpresetandclearinputs.

In SR flip flop, with the help of Preset and Clear, when the power is switched ON, the state of the circuit keeps on changing, i.e. it is uncertain. It may come to Set(Q= 1) or Reset (Q' = 0) state. In many applications, it is desired to initially Set or Reset the flip flop. This thing is accomplished by the Preset (PR) and the Clear (CLR).



#### **BLOCKDIAGRAMOFF/F**

#### OperationsinSRFlip-Flop-

• Case-1:

PR=CLR=1

Theasynchronousinputs are inactive and the flip flop responds freely to the S, R and the CLK inputs in the normal way.

• Case-2:

PR=0andCLR=1

ThisisusedwhentheQissetto1.

#### • Case-3:

PR=1andCLR=0

This is used when the Q'issetto 1.

• Case-4:

PR=CLR=0

Thisisaninvalidstate.

|    | INPUTS |     |    |    |        | YUTS    | Comments  |
|----|--------|-----|----|----|--------|---------|-----------|
| PR | CLR    | CLK | S  | R  | Q(n+1) | ? (n+1) |           |
| 0  | 1      | NA  | NA | NA | 1      | 0       | Set       |
| 1  | 0      | NA  | NA | NA | 0      | 1       | Re-set    |
| 1  | 1      | 0   | NA | NA | Qn     | ? n     | No.change |

| 1 | 1 | 1 | 0 | 0 | Qn | ? n | No.change  |
|---|---|---|---|---|----|-----|------------|
| 1 | 1 | 1 | 1 | 0 | 1  | 0   | Set        |
| 1 | 1 | 1 | 0 | 1 | 0  | 1   | Re-set     |
| 1 | 1 | 1 | 1 | 1 | Х  | х   | Notallowed |

#### ApplicationsofFlip-Flop:

- 1. Flipflopsareusedasabounceeliminationswitch.
- 2. Theyareusedasaserialtoparallelandparalleltoserialconversion.
- 3. Itisusedforcounters.
- 4. It is used for frequency divider and also as a latch.

## 3.5ConstructlevelclockedJKflipflopusingS-Rflip-flopandexplain with truth table

The<u>JK flip flop</u> is one of the most used flip flops in digital circuits. The JK flip flop is a universal flip flop having two inputs 'J' and 'K'. In SR flip flop, the 'S' and 'R' are the shortened abbreviated letters for Set and Reset, but J and K are not. The J and K are themselves autonomous letters which are chosen to distinguish the flip flop designfrom other types. JK flip-flop can either be triggered upon the leading-edge of the clock or on its trailing edge and hence can either be positive- or negative- edge-triggered, respectively.

The JK flip flop work in the same way as the SR flip flop work. The JK flip flop has 'J' and 'K' flip flop instead of 'S' and 'R'. The only difference between JK flip flop and SR flip flop is that when both inputs of SR flip flop is set to 1, the circuit produces the invalid states as outputs, but in case of JK flip flop, there are no invalid states even if both 'J' and 'K' flip flops are set to 1.

The JK Flip Flop is a gated SR flip-flop having the addition of a clock input circuitry. The invalid or illegal output condition occurs when both of the inputs are set to 1 and are prevented by the addition of a clock input circuit. So, the JK flip-flop has four possible input combinations, i.e., 1, 0, "no change" and "toggle".



#### TRUTHTABLE

| IN | PUTS | OUTPUT | STATES                      |
|----|------|--------|-----------------------------|
| J  | K    | Q+     |                             |
| 0  | 0    | Q      | Previousstate               |
| 0  | 1    | 0      | Re-set                      |
| 1  | 0    | 1      | Set                         |
| 1  | 1    | ?      | Toggles(Complementofpresent |
|    |      |        | state )                     |

# [Typethedocumenttitle]

[Typethedocumentsubtitle]

leenamarndi

# **Microprocessor**

A microprocessor is a multipurpose, programmable, clock driven register based semiconductor device that read binary instructions from memory, accept binary data as input and process data according to instruction and provide result as output

Itisakindofintegratedcircuit(IC)unitwhichcombinesallthebasicfunctionsofa central processing unit (CPU) of the computer.

Itisaprogrammable unitthatisfabricatedonthe siliconchipand itconsistsofan ALU unit, clock, and control unit and register array which accepts the input in binary form (0's and 1's) and delivers the output after processing the input data as per the instructions fetched into the memory unit

# **Microcomputer**

AdigitalcomputerinwhichonemicroprocessorhasbeenprovidedtoactasaCPUiscalled microcomputer



The basic building blocks of this processor are an ALU, register array, and the main control processing unit. The function of the arithmetic logical unit (ALU) is to perform the mathematical and logical operations based on the data fetched from the input units or the memory device.

# Someimportant terms

- Bit:Adigitofthebinarynumberof code iscalledabit
- Nibble:The4bit(digit)binarynumberorcodeis calleda nibble
- Byte:8 bitbinaryno.iscalledByte
- Word:16bitbinaryno.iscalled byte

# ArchitectureofIntel8085A Microprocesorsand descriptionofecbblock.

- Itisa40pinI.C.packagefabricatedonasingleLSI chip. 0
- TheIntel8085usesasingle +5Vd.c.supplyforits operation. 0
- Intel8085is clockspeedisabout 3 MHz; theclockcycleisof 320ns. 0
- 8bit databus. 0
- Address busisof16-bit, which can address up to 64KB 0
- Ithas80basicinstructionsand246opcodes. 0



Block Diagram of 8085

Itconsistsof3(Three)mainsectiontheseareasfollows

- 1. Arithmetic&LogicUnit
- 2. TimingandControlunit
- 3. SetsofRegister

# 1. Arithmetic&LogicUnit

The arithmetic and logic unit performs the following arithmetic and logic operation

- i) Addition
- ii) Subtraction
- iii) LogicalAND
- iv) LogicalOR
- v) LogicalExclusiveor
- vi) Increment
- vii) Decrement

# 2. TimingandControlunit

Thetiming and control unitcomesunder the section of CPU, and it generates the timing and control signals which are necessary for the execution of Instructions. It controls flow of data from CPU to other devices. It provides status, control and timing signals which are required for the operation of memory and I/O device. It is also used to control the operations performed by the microprocessor and the devices connected to it. There are certain timing and control signals like: Control signals, DMA Signals, RESET signals, Status Signal.

# 3. SetsofRegister

Registersare used for temporary storage and manipulation of data and instructions by the microprocessor. Data remain in the registers till they are sent to the I/O devices or memory. Intel 8085 microprocessor has the following registers:

- a) One8-bitaccumulator(ACC)i.e.registerA
- b) Sixgeneralpurposeregistersof8-bit,theseareB,C,D,E,HandL
- c) One16-bitstackpointer,SP
- d) One16-bitProgramCounter,PC
- e) Instructionregister
- f) Temporaryregister

In addition to the above mentioned registers the 8085 microprocessor contains a set of five flip-flops which serve as flags (or status flags).

Aflagisaflip-flopwhichindicatessomeconditionswhicharisesafterthe execution of an arithmetic or logical instruction.

### a) Accumulator(ACC):

The accumulator is an 8-bit register associated with the ALU. The register 'A' is an accumulator in the 8085. It is used to hold one of the operands of an arithmetic and logical operation. The final result of an arithmetic or logical operation is also placed in the accumulator.

### b) General-PurposeRegisters:

The 8085 microprocessor contains six 8-bit general purpose registers. They are: B, D, C, E, H and L register.

Toholddataof16-bitacombinationoftwo8-bitregisterscanbeemployed. The

combination of two 8-bit registers is called register pair.

The valid register pairs in the 8085 are: D-E, B-C and H-L. The H-L pair is used to actas a memory pointer.

### c) StackPointer(SP):

It is a 16-bit special function register used as memory pointer. A stack is nothing but a portion of RAM i.e. it is sequence of memory location set aside by a programmer to store/ retrieve the content of accumulator, flags, program counter and general-purpose register during the execution of a program.

StackworkonLIFO(lastinfirstout)Principle

Itsoperationisfastercomparednormalstore/retrieveofmemorylocation

Thestackpointer(SP)controlstheaddressingofthestack.TheStackPointercontainsthe address of the top element of data stored in the stack.

# d) ProgramCounter(PC):

It is a 16-bit special purposeregister. It is used to hold the address of memory of the next instruction to be executed. It keeps the track of the instruction in a program while they are being executed. The microprocessor increments the content of the next program counter during the execution of an instruction so that at the end of the execution of an instruction it points the next instructions address in the program.

#### e) Instructionregister

The instruction register holds the opcode (operation code or instruction code) of the instruction which is being decoded and executed.

#### f) Temporaryregister

It is an 8-bit register associated with the ALU. It holds data during an arithmetic/logical operation. It is used by the microprocessor. It is not accessible to programmer.

#### g) Flags:

The Intel 8085 microprocessor contains five flip-flops to serve as a status flags. The flipflops are reset or set according to the conditions which arise during an arithmetic or logical operation.

- a. CarryFlag(CS)
- b. ParityFlag(P)
- c. AuxiliaryCarryFlag(AC)
- d. ZeroFlag(Z)
- e. SignFlag(S)

| ?7 | 26 | ? <sub>5</sub> | ? <sub>4</sub> | ? <sub>3</sub> | ? <sub>2</sub> | ? <sub>1</sub> | 20 |
|----|----|----------------|----------------|----------------|----------------|----------------|----|
| S  | Z  | Х              | AC             | Х              | Р              | Х              | CS |

# a) CarryFlag(CS)

Carry is generated when performing n bit operations and the result is more than n bits, thenthisflagbecomesseti.e.1,otherwiseitbecomesreseti.e.0. Duringsubtraction(A-B),ifA>Bitbecomesresetandif(A<B)itbecomesset. Carry flag is also called borrow flag.

1-carryoutfromMSBbitonadditionorborrowintoMSBbitonsubtraction0-no carry out or borrow into MSB bit

#### Example:

MVIA30(load30HinregisterA) MVIB40 (load40HinregisterB) SUB B (A = A – B) Thesesetofinstructionswillsetthe carry flagto1as30 –40generatesacarry/borrow.

MVIA40(load40HinregisterA) MVIB30 (load30HinregisterB) SUB B (A = A – B) Thesesetofinstructionswillresetthesignflagto0as40–30doesnotgenerateany carry/borrow.

# b) ParityFlag(P)

Ifafteranyarithmeticorlogicaloperationtheresulthasevenparity, an evennumber of 1 bits, the parity register becomes set i.e. 1, otherwise it becomes reset i.e. 0.

1-accumulatorhasevennumberof1bits 0accumulator has odd parity

#### Example:

```
MVIA05(load05HinregisterA)
Thisinstructionwillsettheparityflagto1astheBCDcodeof05His00000101,which contains
even number of ones i.e. 2.
```

# c) AuxiliaryCarryFlag (AC)

This flag is used in BCD number system(0-9). If after any arithmetic or logical operationD(3)generatesanycarryandpassesontoB(4)thisflagbecomesset i.e.1,otherwiseitbecomesreseti.e.0.Thisistheonlyflagregisterwhichis notaccessiblebytheprogrammer1-carryout frombit3onadditionorborrow into bit 3 on subtraction 0-otherwise

#### Example:

MOVA2B(load2BHinregisterA) MOV B 39 (load 39Hinregister B) ADD B (A = A + B) Thesesetofinstructionswillsettheauxiliarycarryflagto1,asonadding2Band39, addition of lower order nibbles B and 9 will generate a carry.

# d) Zero Flag(Z)

Afteranyarithmeticalorlogicaloperationiftheresultis0(00)H,thezeroflagbecomes set i.e. 1, otherwise it becomes reset i.e. 0. 00Hzeroflag is1.

from 01HtoFFHzeroflagis 0

1-zeroresult0-non-zero result

#### Example:

MVIA10(load10HinregisterA) SUB A (A = A - A) Thesesetofinstructionswillsetthezero flagto1as10H-10His00H

# e) SignFlag(S)

AfteranyoperationiftheMSB(B(7))oftheresultis1, it indicates the number is negative and the sign flag becomes set, i.e. 1. If the MSB is 0, it indicates the number is positive and the sign flag becomes reset i.e. 0. from00Hto7F, signflag is0 from80Hto FF, signflag is1

1- MSB is 1(negative) 0- MSB is 0(positive)

#### Example:

MVIA30(load30HinregisterA) MVIB40 (load40HinregisterB) SUB B (A = A – B) Thesesetofinstructionswillsetthesignflagto1as30–40isanegativenumber.

MVIA40(load40HinregisterA) MVIB30 (load30HinregisterB) SUB B (A = A – B) Thesesetof instructionswillresetthesignflagto0as40 –30 is apositivenumber.

# PinDiagram8085microprocessor



Fig 1.2 Pin Diagram of 8085

### A8- A15(Output):

ThesearetheAddressBusandusedformost significant8bitsofthememoryaddress or the 8 bits of the I/O address,

#### AD0- AD7(Input/Output)

Multiplexed Address/Data Bus it serve dual purpose. They are used forLeast significant 8 bits of the memory address (or I/0 address) during the first clock cycle of a machine cycle. Then itbecomes the data bus during the second and third clock cycles. **ALE (Output):** 

Address Latch Enable signal it goes high during the first clock cycle of a machine cycle and enables the lower 8 bit address to get latched either into the memory or external latch So when pulse goes high means ALE=1, it makes address bus enable and when ALE=0, means low pulse makes data bus enable.

IO/2 (Output):

Itisastatussignalwhichdistinguisheswhetherl/Oormemoryoperationisbeing performed

When it goes high, the address on the address busis for an I/O device.

i.elfl $0/\overline{M}$  = 1thenl/Ooperationisbeingperformed.

When it goes low, the address on the address busis for an memory location

i.elfl $0/\overline{M} = 0$ then  $\circ$  Memory operation is being performed.

#### SO,S1(Output):

These are the status signals sent by the microprocessor to distinguish the various typeof operation

| S | 1 <b>S</b> 0 |       |                                           |
|---|--------------|-------|-------------------------------------------|
| 0 | 0            | HALT  |                                           |
| 0 | 1            | WRITE |                                           |
| 1 | 0            | READ  |                                           |
| 1 | 1            | FETCH | S1 can be used as an advanced R/W status. |

### **Output**:

RDstandsforRead.

 $It is an active low signal.i.e \overline{{\tt D}} = 0 then read operation is perform$ 

It is a control signalsent by the microprocessor to the memory/input device to control READ operation. A low signal indicates that data on the data bus must be placed either from selected memory location or from input device.

 $\overline{\mathbb{R}}$  indicates the selected memory or input device is to be read and that the Data Bus is available for the data transfer.

# 22(Output ):

WRstandsforwrite.

Itisanactivelowsignal.i.eWR=0thenwriteoperationisperform

It is a control signal sent by microprocessor to the memory/ output device to control Writeoperation A low signal indicates that data on the data bus must be written into selected memory location or into output device.

WR indicates the data on the Data Bus is to be written into the selected memory or output device.

# READY(Input):

It is a signal sent by an input or output device to the microprocessor.

 $\label{eq:link} It indicates that the input or output device is ready to send or received at a.$ 

ThemicroprocessorexaminesREADYsignalbeforeitperformsdatatransferoperation

If Ready is high, it indicates that the input or output device is ready tosend orreceivedata.

If Ready is low, the microprocessor will wait for Ready to go high before completing the read or write cycle.

### HOLD(Input):

It indicates that another device is requesting the use of the address and data bus. Having received HOLD request the microprocessor relinquishes(give up) the use of the buses as soon as the current machine cycle is completed. Internal processing may continue. After the removal of the HOLD signal the processor regains the bus.

#### ExplainwithExample

The HOLD pin specifies when any device is demanding the employ of address as well as a data bus. The two devices are LCD as well as A/D converter. Assume that if A/D converter is employing the address bus as well as a data bus. When LCD desires the utilize of both the buses by providing HOLD signal, subsequently the microprocessor transmits the control signal toward the LCD after that the existing cycle will be ended. When the LCD procedure is over, then the control signal is transmitted reverse to A/D converter.

### HLDA(Output):

This is the response signal of HOLD, and it specifies whether this signal is obtained or not obtained. After the implementation of HOLD demand, this signal will go low.

#### **INTR(Input)**:

It is an Interrupt signal sent by an external device to the microprocessor, when it goeshighthemicroprocessorsuspendstheexecutionofitsnormalsequenceofinstructions i.elfitisactive,theProgramCounter(PC)willbeinhibitedfromincrementingandan INTAwillbeissued.

#### ????(Output):

Itisaninterruptacknowledgesignalissuedbythemicroprocessorafterreceivingan interrupt request from an external device. it is low active signal.

### RST5.5, 6.5,7.5:

Thesepinsaretherestartmaskableinterruptsor VectoredInterrupts, usedtoinsert an inner restart function repeatedly. All these interrupts are maskable, they can be allowed or not allowed by using programs.

# TRAP (Input):

Trap interrupt is a non maskable restart interrupt. It is recognized at the same time as INTR.ItisunaffectedbyanymaskorInterruptEnable.Ithasthehighestpriorityof any interrupt.

# **RESET IN (Input):**

Reset sets the Program Counter to zero and resets the Interrupt Enable and HLDA flipflops. None of the other flags or registers (except the instruction register) areaffected The CPU is held in the reset condition as long as Reset is applied.

### **RESETOUT(Output):**

IndicatesCPUisbeingreset.CanbeusedasasystemRESET.

### X1, X2 (Input):

Crystal or R/C network connections to set the internal clock generator X1 can also bean external clock input instead of a crystal. The input frequency is divided by 2 to give the internal operating frequency.

### CLK(Output):

Clock Output for use as a system clock when a crystal or R/ C network is used as an input to the CPU. The period of CLK is twice the X1, X2 input period.

#### SID (Input):

Serial input data line the data on this line is loaded into accumulator bit 7 whenever a RIM instruction is executed.

### SOD (output):

Serialoutputdataline.TheoutputSODissetorresetasspecifiedbytheSIM instruction.

#### Vcc:

+5 voltsupply.

Vss:

GroundReference.

# 4.4.Stack,Stackpointer&stacktop

- StackisaportionofRAMmemorydefinedbytheuserfortemporarystorage and retrieve of data while executing a program.
- Themicroprocessorwillhavededicatedinternalregistercalledastackpointer toholdtheaddressofthestack
- Alsotheprocessorwillhavefacilitytoautomaticallydecrement/incrementthe content
   of SP after every Write/read into stack

- ForeverywriteoperationintothestacktheSPautomaticallydecrementedby two
- ForeveryreadoperationintothestacktheSPautomaticallyincrementedby two
- The contents register are moved to certain memory location by PUSH operation, then the register are used for other operations
- Afterpushoperationthosecontentswhichweresavedinthememoryare transferredbacktotheregisterbyPOPoperation
- ThesetofmemorylocationkeptforthisoperationiscalledStack
- ThelastmemorylocationoftheoccupiedportionoftheStackiscalledStack top
- Aspecial16bitregisterisknownasstackpointerholdtheaddressofstacktop
- ThestackpointerisinitializedinbeginningoftheprogrambyLXISPorSPHL instruction
- DataarestoredinthestackonLast-in-first-out(LIFO)principle
- SPregisterholdtheaddressofstacktoplocation

#### REG. C REG. B REG. B PUSH B REG. C 2A 83 83 2A 2602 NEXT AVAILABLE LOCATION 2602 2603 2A NEXT AVAILABLE 2603 SP 2603 LOCATION 2604 2604 83 A1 2605 2605 SP A1 2605 2B 2606 2606 2B 2A 2607 2607 2A 6B 2608 2608 6B Fig. 5.2 (b) Stack after PUSH operation Fig. 5.2 (a) Stack before PUSH operation

#### PUSHOPERATION

#### POPOPERATION

POPoperationisusedtotransferthecontentsfromthestacktotheregister



# Interruptsin8085 microprocessor:

When microprocessor receives any interrupt signal from peripheral(s) which are requesting its services, it stops its current execution and program control is transferred to a sub-routine by generating CALL signal and after executing sub-routine by generating RET signalagainprogramcontrolistransferredtomainprogramfrom where it had stopped.

When microprocessor receives interrupt signals, it sends an acknowledgement (INTA) to the peripheral which is requesting for its service.

# Interrupts can be classified into various categories based on different parameters:

#### 1. HardwareandSoftwareInterrupts-

When microprocessors receive interrupt signals through pins (hardware) of microprocessor, they are known as Hardware Interrupts. There are 5 Hardware Interrupts in 8085 microprocessor.

#### Theyare–INTR,RST7.5,RST6.5,RST5.5,TRAP

Software Interrupts are program instruction those which are inserted in between the program which means these are mnemonics of microprocessor. There are 8 software interrupts in 8085 microprocessor.

They are-RST0,RST1,RST2,RST3,RST4,RST5,RST6,RST7.

#### 2. VectoredandNon-VectoredInterrupts-

VectoredInterrupts arethosewhichhavefixedvectoraddress(startingaddressof subroutine) and after executing these, program control is transferred to that address.

Vector Addresses are calculated by the formula Vector Addresses=Interrupt No.\*8

| INTERRUPT      | VECTORADDRESS |
|----------------|---------------|
| TRAP (RST 4.5) | 24H           |
| RST5.5         | 2CH           |
| RST6.5         | 34H           |
| RST7.5         | 3CH           |

#### ForSoftwareinterruptsvectoraddressesaregivenby:

| INTERRUPT | VECTORADDRESS |
|-----------|---------------|
| RST0      | 00H           |
| RST1      | 08H           |
| RST2      | 10H           |
| RST3      | 18H           |
| RST4      | 20H           |
| RST5      | 28H           |
| RST6      | 30H           |
| RST7      | 38H           |

**Non-Vectored Interrupts** are those in which vector address is not predefined. The interrupting device gives the address of sub-routine for these interrupts. INTR is the only non-vectored interrupt in 8085 microprocessor.

#### 3. MaskableandNon-MaskableInterrupts-

Maskable Interrupts are those which can be disabled or ignored by the microprocessor. These interrupts are either edge-triggered or level-triggered, so they can be disabled.

INTR, RST 7.5, RST 6.5, RST 5.5 are maskable interrupts in 8085 microprocessor

Non-Maskable Interrupts are those which cannot be disabled or ignored by microprocessor.

TRAP is a non-maskable interrupt. It consists of both level as well as edge triggering and is used in critical power failure conditions.

#### PriorityofInterrupts-

Whenmicroprocessorreceivesmultipleinterruptrequestssimultaneously,itwill execute the interrupt service request (ISR) according to the priority of the interrupts.



#### InstructionforInterrupts-

- 5. EnableInterrupt(EI)
- 6. DisableInterrupt(DI)
- 7.
   SetInterruptMask(SIM)–Itisusedtoimplementthehar (RST7.5,RST €.5,RST5.5)bysettingvariousbitsto
   d wareinterrupts

   generateoutputdataviatheSerialOutputData(SOD)line
   formmasksor
- ReadInterrupt Nask(RIM)–Thisinstructionisusedtoreadthestatusof thehardwareinterrupts(RST7.5,RST6.5,RST5.5)bylodingintotheA registerabyte which defines the condition of thema skbits for the interrupts. Italsoreads the condition of SID (Serial Input E ata) bit on the microprocessor.

# 4.60pcode&Operand,

# Whatis Opcode?

Opcodesmean"operationcodes".Anopcodeisthefirstpartofaninstruction which specifies the task to be performed by the computer is called opcode.

Itisaninstructionthattellstheprocessorwhattodowiththevariableordatawritten beside it.

# What isOperand?

An operand is the second part of the instruction, is the data to be operated on and it is called  $\ensuremath{\textit{operand}}$  .

# **InstructionWordSize**

The 8085 instruction set is classified into the following three groups according to word size:

- 1. One-wordor1-byte instructions
- 2. Two-wordor2-byte instructions
- 3. Three-wordor3-byteinstructions

# **One-ByteInstructions**

In 1-byte instruction, the opcode and the operand of an instruction are represented in one byte.

Operand(s) are internal registers and are in the instruction in form of codes. If there is no numeral present in the instruction then that instruction will be ofone-byte.

InstructionarerequiredoneMemorylocationtostoreonebyteinthe memory Example,MOVC,A,RAL,andADDB, etc.

# **Two-wordor2-byteinstructions**

Two-byte instruction is the type of instruction in which the first 8 bits indicates the opcode and the next 8 bits indicates the operand.

In a two-byte instruction, the first byte specifies the operation code and secondbyte specifies the operand.

Source operand is a data byte and immediately following the opcode. If an 8-bit numeral is present in theinstruction then that instruction will be of two-byte. Here, the numeral may be a data or an address.

Instructionare required two Memorylocation to store in the memory

#### Forexample, MVIA, 35H and IN 29H, etc.

In a two-byte instruction, the first byte will be the opcode and the second byte will be for the numeral present in the instruction.

# **Three-wordor3-byteinstructions**

Three-byte instruction is the type of instruction in which the first 8 bits indicates the opcode and the next two bytes specify the 16-bit address. The low-order address is represented in second byte and the high-order address is represented in the third byte.

In a three-byte instruction, the first byte specifies the opcode, and the following two bytes specify the 16-bit operand.

Instructionare required three Memory location to store in the memory

### Example,LXIH,3500HandSTA2500H,etc

# Instructionset of 8085

Aninstructionisabinarypatterndesignedinsideamicroprocessortoperforma specific function.

In microprocessor, the**instruction**set is the collection of the instructions that themicroprocessor is designed to execute.

# ClassificationofInstructionSetof8085

The instruction set of 8085 microprocessor is classified into five types which include the following.



#### **DataTransfer Instruction**

An instruction that is used to transfer the data from one register to another isknown as data transfer instruction. So, the data transfer can be done fromsource to destination without changing the source contents.

Data transfer mainly occurs from one register to another register, from memory location register, register to memory, and between an I/Odevice & accumulator.

#### MOVM, Data

This type of instruction specifies the data transfer immediately to a location of memory. This memory location address can be specified at the H-L registers.

Example:MOVM,28H

#### MVIr,Data (MoveImmediate)

In this type of instruction, the transmission of data can be done immediatelytoward the particular register.

Example:MVIr,32H

#### LDAaddress (Load Accumulator)

LDA is a load accumulator instruction that is mainly used for copying the data available in the address of memory indicated as the instruction's operand to the accumulator. Particularly, in this case, the available data in the 16-bit address memory is transferred toward the accumulator.

Example:LDA500H

#### LDAX(LoadAccumulatorbyextendedRegister Pair)

It is a load accumulator from an address in the register pair. In this type of data transfer instruction, the register holds the address of the data that needs to be loaded to the accumulator.

Example:LDAXC/D

#### LHLD(Load H&LRegistersDirect)

LHLD instruction is a direct load instruction, where it loads the H-L register with the data from the memory. In this type of instruction, the data which is available in the address specified is copied to the L register first and then the available data within the next memory location will be loaded in the H register.

Example:LHLD2500H

#### STAAddress(StoreAccumulatorContentsinMemory)

STA stands for stored accumulator direct instruction. Once this instruction is accepted, then the available data within the accumulator can be transferred to the address of memory indicated within the operand.

#### Example:STA2030H

In the above example data stored in the accumulator will be stored tomemory location 2030. LSB followed by MSB will be stored in the memory location.

#### STAXRegister(StoreAccumulatorbyExtendedRegister)

It is a stored accumulator indirect instruction. In this instruction, the register is available as the operand that holds a memory address. Thus, the accumulator data can be copied to that specific memory location.

Example:STAX D

#### **XCHG**(Exchange)

This type of data transfer instruction can be used to exchange the data available within two registers.

Example: XCHGH-L &D-E.Inthis,thecontentsofH&DandL&Eare exchanged.

#### **SPHL (StackPointerHL Register)**

In this data transfer instruction, the data of H &L can be moved to the stackpointer.

#### PCHL(ProgramCounterwithHL Data)

Similar to SPHL instruction, this PCHL instruction simply copies the H-L register'sdataintotheSPbyloadingthehigh orderbytesatH&loworderbytesat L.

#### PUSH

In this type of instruction, the stack can be loaded with the available data within the register provided in the operand. Initially, the stack pointer gets decreased & high order bytes are copied to the stack. Further stack pointer gets decreased to load the low order register bytes.

Example:PUSHD

#### POP

This instruction indicates the data transfer from the top of the stack to the register provided as the operand.

Example:POPC

#### OUT

In this typeofdatatransfer instruction, thedataavailableattheaccumulatorcanbe copied toward the I/O port. An 8-bit port address at the operand is present.

Example:OUT36H

#### IN

This type of instruction is used to load the data available at the I/O port to the accumulator. The operand simply holds the port address from where the data canbe copied.

Example:IN,6BH

#### ArithmeticInstructionof8085

The arithmetic instructions perform different operations like addition, subtraction, increment & decrement on the data within memory & register in the 8085 microprocessor.

#### ADDr

This arithmetic instruction adds the data which is available in the register to the data available within the accumulator & the final result will be stored in the accumulator.

Example:ADDC

### ADDM

This typeofinstructionis mainly used to add the date in the memory address data denoted at the operand to the data available at the accumulator. So the addition result will be stored within the accumulator.

Example:ADD28H

#### ADIData (Add Immediate)

In this instruction, the 8-bit data is specified as an operand is added immediatelyto the data available at the accumulator & the result is stored at the accumulator.

Example:ADI24H

#### **ACIData**(AddwithCarry Immediate)

This type of instruction simply adds the 8-bit data available at the operand & carries the flag by the data available at the accumulator. After every addition, the flag reproduces the output of the addition.

Example:ACI35H

#### **ADCr (Add with Carry)**

In this type of instruction, the data present at the register can be added to the data available at the accumulator with the carry bit & output is simply reflected at the accumulator.

Example:ADCD

#### AMCM

This type of instruction is mainly used to add the available data at the location of memory whose address is denoted within the operand specified & the carry bitwith the data available within the accumulator. So the output of addition can be stored within the accumulator.

Example:AMC25H

#### SUBr

This type of instruction is used to subtract theavailable data at theregister given at theoperandfromthedatapresentin theaccumulator. The final result will be stored at the accumulator.

#### Example:SUBC SUB M

This instruction is used to subtract the available data at the location of memory whose address is provided by the H-L register from the data present at the accumulator.

Example:SUB128H

#### SUIData(SubtractImmediatefromAccumulator)

This type of instruction is mainly used to instantly subtract the data available as operand within the instruction from the available data at the accumulator. After every subtraction, the flag can be changed to show the result of subtraction.

Example:SUI35H

#### **SBIData**(SubtractwithBorrowImmediatefromAccumulator)

This type of instruction helps subtract the 8-bit data provided as the operand & the borrow bit from the available data at the accumulator, and the result will be stored within the accumulator.

Example:SBI24H

#### <u>SBB r</u>

This instruction is used to subtract the data present at the register & the borrow bit from the data present at the accumulator.

Example:SBBC

#### **SBB M(SubtractionwithBorrow)**

This instruction is used to specify the subtraction of data available at the memory location, whose address is available at the H-L register & the borrow bit from the data present at the accumulator.

Example:SBB1000H

#### INXr (IncrementExtendedRegister)

This type of instruction is used to increase the data by 1 which is availableat theregister provided at the operand. The result will be stored at the same register.

Example:INXC

#### DCXr(DecrementExtendedRegister)

This typeofinstruction decreases the data available at the register by 1 & the result will be stored in the same register.

#### Example:DCXC

#### **DCRM(DecrementRegister)**

In aninstruction, sometimes the operand holds a location of memory. The memory location address is available at the H-Lpair. Thus the data available at that specific location will be decreased by 1.

Example:DCR28H

#### DAA(DecimalAdjust Accumulator)

DAA is a decimal adjust accumulator, used to break the binary number from 8-bit to two 4-bit binary-coded decimal numbers.

#### LogicalInstruction

Logicalinstructions are mainly used to perform different operations likelogical or Boolean over the data available in either memory or register. These instructions will modify the flag bits based on the operation executed.

#### <u>CMPR/M(ComparetheRegister/MemorywiththeAccumulator)</u>

This instruction is used to compare the data at the accumulator with the data present at the register or memory which is given as operand. According to the result obtained by the comparison, the flags are set. While the data that is compared remains unchanged.

#### Example:CMPB

#### **CPI Data**(CompareimmediatethroughtheAccumulator)

This type of instruction compares the 8-bit data provided as operand within the instruction by the data available within the accumulator. This result is shown through the flags.

#### Example:CPI50

#### ANAR/M(LogicalANDregisteror memorywiththeaccumulator)

This instruction executes the AND operation of the data available within the accumulator to the data available in the memory or register. After the operation of AND, S, P, Z will be changed to show the outcome of the comparison.

Example:ANAC

#### ANIdata (AndImmediatewithAccumulator)

This instruction executes AND operation for the immediate 8-bit data provided as operand by the data available in the accumulator.

Example:ANI35H

#### ORAR/M(ORAccumulatorRegisterorMemory)

This instruction is used to perform OR operation of the data available within the accumulator by the data available in the memory location or register.

Example:ORAC

#### ORIdata(ORImmediateData)

The 8-bit data provided as an operand is ORed logically with the data within the accumulator.So,theoutputofthis instruction canbesaved within the accumulator.

Example:ORI36H

#### XRAR/M(ExclusiveOR Immediatewith Accumulator)

This instruction is used to execute XOR operation through data available at the accumulator & the data present at the memory or register.

Example:XRA2030

#### XRIdata (ExclusiveOR Accumulator)

This type of instruction is used to execute the XOR operation of the 8-bit data specified as operand & the data present at the accumulator. The output will be stored at the accumulator.

Example:XRI30

#### RLC(RotateLeftAccumulator)

This instruction holds significance when there exists a need to rotate the bits present in the accumulator. Basically, for an 8-bit value, each bit is rotated or shifted left by one position. Also, the rotation of the last bit of the sequence i.e., D7, sets the CY flag.

#### **RRC(RightRotateAccumulator)**

This instruction is used to rotate the bit toward the right with one position. So, in this case, D0 sets the CY flag.

#### Example:RRC

#### RAL(RotateAccumulatorLeft)

This typeofinstructionisused to rotate the bits toward the left with one of the data available within the accumulator through the carry flag. Here, D7 can be shifted to hold the flag & the bit within the carry flag can be shifted to D0.

Example:RAL

#### **RAR**(RotateAccumulatorRight)

This type of instruction is mainly used to rotate the data bits to the right which are available within the accumulator by the carry flag. Here, D0 can be shifted to hold the flag & the carry bit can be moved to the D7 position.

Example:RAR

#### **STC(SettheCarryFlag)**

This type of instruction is used to set the carry flag (CF) to 1 by not affecting anyother flags.

Example:STC

#### **CMA**(**Complementthe Accumulator**)

This type of instruction generates the complement of data at the accumulator. So,this function does not change any of the flags.

Example:CMA

#### **CMC(ComplementtheCarryFlag)**

This type of instruction is used to complement the data available at the carry flag(CF). So this instruction does not affect any other flag.

Example:CMC

### **Branching Instruction**

These types of instructions are mainly used to transfer or switch themicroprocessor from one location to another. So, it simply changes the general sequential flow.

#### **JMPaddress**(Jump unconditionally)

This type of instruction is mainly used to transfer the series of the current program to thatlocationofmemorywhose16-bitaddress can besimplyspecified within the operand of the instruction.

Example:JMP2014H

#### JxAddress

This is a conditional branching type instruction, where the series of current programs can be transferred to that specific location whose address can beprovidedattheoperand. However this transferring mainly depends on the specified PSX flag.

Example:JZ 1200H

#### **CALL address**

This instruction shifts the control of a series of current programs toward the memory address available at the operand. However the PC gets decreased before transferring,

Example:CALL2400H

#### **RET**(**Returnfromthe Subroutine**)

This type of instruction cancause the unconditional return of the sub-routine to the actual program.

#### **RST**(RestartInstruction)

This typeof instruction is mainly used to transfer the series from the main program to the interrupt service routine. Mostly, the transfer can be performed above one of the 8-bits which are indicated within the operand.

#### ControlInstruction

These instructions are mainly used to control the microprocessor operations. These instructions are discussed below.

#### **NOP**(Nooperation)

NOP stands for no operation. Once the 8085 microprocessor gets this instruction, then it does not perform any operation based on execution.

#### **DI**(**DisableInterrupts**)

DI is the disabling of the interrupt that is generated within the microprocessor. Interrupt resetting will allows to disable all the interrupts apart from TRAP.

#### **EI**(EnableInterrupts)

This type of instruction is mainly used to allow the interrupt. Once the interrupt enable pin is set then leads to enabling the interrupts within the system.

#### HLT (Halt & EnterWait State)

Once the HLT interrupt is decoded through the microprocessor, it stops the current operation and waits for furtherinstruction. To escapefrom he halt condition either a reset or an interrupt is necessary.

#### SIM(SetInterruptMask)

SIM is the set interrupt mask, which is used to execute the hardware interrupts programming & serial output.

#### **RIM(ReadInterrupt Mask)**

RIMisthereadinterruptmaskthatisusedtosituatethepreferreddataatthe accumulator based on the serial input & interrupt.

# Addressingmode

These are the instructions used to transfer the data from one register to another register, from the memory to the register, and from the register to the memory without any alteration in the content

Thetermaddressingmodereferstothewayinwhichtheoperandofthe instruction is specified

# **TypesofAddressingModes**

Intel8085usesthefollowingaddressingmodes:

- 1. DirectAddressingMode
- 2. RegisterAddressingMode
- 3. RegisterIndirectAddressingMode
- 4. ImmediateAddressingMode
- 5. ImplicitAddressingMode

### 1. DirectAddressingMode:-

The address of the operand (data) is directly available in the instruction itself.

Indirectaddressingmode, the data to be operated is available inside a memory location and that memory location is directly specified as an operand

#### Examples:

LDA2050(loadthecontentsofmemorylocationintoaccumulatorA) LHLD address (load contents of 16-bit memory location into H-L register pair)IN 35 (read the data from port whose address is 35)

# 2. RegisterAddressingMode:-

In register addressing the operand is one of the general purpose registers. the opcode specifies the address of the register in addition to the operation to be performed.

In register addressing mode, the data to be operated is available inside the register(s) and register(s) is operands. Therefore the operation is performed within various registers of the microprocessor.

### Examples:

MOVA,B(movethecontentsofregisterBtoregister A) ADDB(add contentsofregistersAand BandstoretheresultinregisterA) INR A (increment the contents of register A by one)

# 3. RegisterIndirectAddressingMode

In this mode of addressing the address of the operand is specified by a register pair.

Inregisterindirectaddressingmode, the data to be operated is available inside a memory location and that memory location is indirectly specified by a register pair.

### Examples:

MOVA,M(movethecontentsofthememorylocation pointedbytheH-Lpairto the accumulator)

LDAXB(movecontentsofB-Cregistertotheaccumulator)

LXIH9570(loadimmediatetheH-Lpairwith theaddressofthelocation9570)

# 4. ImmediateAddressingMode

In immediate addressing mode the source operand is always data. If the data is 8-bit, then the instruction will be of 2 bytes, if the data is of 16-bit then the instruction will be of 3 bytes.

### Examples:

MVIB45(movethedata45Himmediatelytoregister B) LXIH3050(loadtheH-Lpairwiththeoperand3050Himmediately) JMP address (jump to the operand address immediately)

# 5. ImplicitAddressingMode

Inimplied/implicitaddressingmodetheoperandishiddenandthedatatobe operated is available in the instruction itself.

#### Examples:

CMA(findsandstoresthe1'scomplementofthecontentsofaccumulatorAinA) RRC (rotate accumulator A right by one bit) RLC(rotateaccumulatorAleft byonebit)

# TimingDiagram:

Timing Diagram is a graphical representation. It represents the execution time taken by each instruction in a graphical format. The execution time is represented in T-states.

# InstructionCycle:

 $The time required to execute an instruction is called instruction cycle. \ or$ 

The time taken by the processor to complete the execution of an instruction. An

instruction cycle consists of one to six machine cycles.

# Fetchcycle:

The fetch cycle in a microprocessor comprises(consist) of several time states during which the next instruction to be executed is copied (fetched) from the memory location (whose address is in the Program Counter) to the Instruction Register.



IC=FC+EC

# MachineCycle:

The time required to access the memory or input/output devices is called machine cycle.

or

The time required to complete one operation; accessing either the memory or I/Odevice. A machine cycle consists of three to six T-states.

#### **T-State:**

The machine cycle and instruction cycle takes multiple clock periods. A portion of an operation carried out in one system clock period is called as T-state.

#### Or

Time corresponding to one clock period. It is the basic unit to calculate execution of instructions or programs in a processor.

### Rulestoidentifynumberofmachinecyclesinaninstruction:

1. Ifanaddressingmodeisdirect,immediateorimplicitthenNo.ofmachine cycles = No. of bytes.

2. If the addressing mode is indirect then No. of machine cycles=No. of bytes+1. Add +1 to the No. of machine cycles if it is memory read/write operation.

3. If the operand is 8-bitor 16-bit address then, No. of machine cycles=No. of bytes +1.

4. Theserulesareapplicableto80% of the instructions of 8085.

### CONCEPTOFTIMINGDIAGRAM:

The8085microprocessorhas5(seven)basic machinecycles.Theyare

- 1. Opcodefetchcycle(4T)
- 2. Memoryreadcycle(3T)
- 3. Memorywritecycle(3T)
- 4. I/Oreadcycle(3T)
- 5. I/O writecycle(3 T

*Time period*, T = 1/f; where f = Internal clock frequency



Fig 1.7 Clock Signal

# TimingDiagramofOpcodefetchof8085:

The microprocessor requires instructions to perform any particular action. In order to perform these actions microprocessor utilizes Opcode which is a part of an instruction which provides detail(ie. Which operation  $\mu p$  needs to perform) to microprocessor.



Fig 1.8 Opcode fetch machine cycle

Eachinstructionoftheprocessorhasonebyteopcode.

Theopcodesarestoredinmemory.So,theprocessorexecutes theopcode fetch machine cycle to fetch the opcode from memory.

Hence, every instruction starts with opcode fetch machine cycle.

Thetimetakenbytheprocessorto executetheopcodefetchcycleis4T.

In this time, the first, 3 T-states are used for fetching the opcode from memory and the remaining T-states are used for internal operations by the processor.

#### **TimingDiagramofMemoryRead**

The memory readmachine cycle is executed by the processor to read a data bytefrom memory.

Theprocessortakes3Tstatestoexecute this cycle.

Theinstructionswhichhavemore than one byteword size will use the machine cycle after the opcode fetch machine cycle.



Fig 1.10 Memory Write Machine Cycle

#### TimingDiagramofMemoryWrite



Fig 1.10 Memory Write Machine Cycle

The memory write machine cycle is executed by the processor to write a data byte in a memory location.

Theprocessortakes,3Tstatesto executethismachinecycle.

# TimingDiagramofl/ORead

•

The I/O Read cycle is executed by the processor to read a data byte from I/O port or from the peripheral, which is I/O, mapped in the system.

The processor takes 3T states to execute this machine

cycle. The IN instruction uses this machine cycle during the execution



Fig 1.11 I/O Read Cycle

#### TimingdiagramforSTA526AH



Fig 1.12 Timing Diagram for STA 526A H

| Address | Mnemonics             | Op cod e        |
|---------|-----------------------|-----------------|
| 41FF    | STA 526A <sub>H</sub> | 32H             |
| 4200    |                       | 6A <sub>H</sub> |
| 4201    |                       | 52 <sub>H</sub> |

STA means Store Accumulator -Thecontents of the accumulator isstored inthespecified address (526A).

TheopcodeoftheSTAinstructionissaidtobe32H.Itisfetchedfromthe memory 41FFH (see fig). - OF machine cycle

Thenthelowerordermemoryaddressisread(6A).-MemoryReadMachine Cycle

Readthehigherordermemoryaddress(52).-MemoryReadMachine Cycle

The combination of both the addresses are considered and the content from accumulator is written in 526A. - Memory Write Machine Cycle

Assume the memory address for the instruction and let the content of accumulator is C7H. So, C7H from accumulator is now stored in 526A.

# TimingdiagramforINRM

Fetchingthe Opcode34Hfromthememory4105H.(OF cycle)

Let the memory address (M) be 4250H. (MR cycle -To read Memory address and data)

Letthecontentofthatmemoryis12H.

Incrementthe memorycontentfrom12Hto13H.(MWmachine cycle)



Fig 1.13 Timing Diagram for INR M

| Address | Mnemonics | Opcode          |
|---------|-----------|-----------------|
| 4105    | INR M     | 34 <sub>H</sub> |

## Counterandtime delay.

## Counter:

Acounterisdesignedsimplybyloadingappropriatenumberintooneofthe registers and using INR or DNR instructions.

Loopisestablishedtoupdate thecount.

Each count is checked to determine whether it has reached final number ;if not, the loop is repeated.



## Timedelay:

Procedureusedtodesign aspecific delay.'

Aregisterisloaded with a number, depending on the 'time delay required and then the registeris decremented until it reaches zero by setting up conditional aloop with jump instruction.



## Simpleassemblylanguageprogrammingof8085.

76

FC03

| PROGRAM<br>Memory address<br>FC00<br>FC02 | Machine code<br>06,05<br>76 | s Mnemon<br>MVI<br>HLT | ics Opera<br>B, |                             |
|-------------------------------------------|-----------------------------|------------------------|-----------------|-----------------------------|
| Example 2 Of                              | oject: Get 05 ir            | n register A; th       | ien move it     | to register B.              |
| PROGRAM<br>Memory address                 | Machine Codes               | Mnemonics              | Operands        | Comments                    |
| FC00                                      | 3E, 05                      | MVI                    | A, 05           | Get 05 in register A.       |
| FC02                                      | 47                          | MOV                    | B, A            | Transfer 05 from register A |
|                                           |                             |                        | Contraction and |                             |

HLT

Stop.

Object: Load the content of the memory location FC50 H directly to the accumulator, then transfer it to register B. The content of the memory location FC50 H is 05.

| PROGRA            | M                | at the last of the | Operands | Comments                                                        |
|-------------------|------------------|--------------------|----------|-----------------------------------------------------------------|
| Memory<br>address | Machine<br>Codes | Mnemonics          | Operanos |                                                                 |
| FC00              | 3A, 50, FC       | LDA                | FC50     | Get the content of the memory location FC50 H into accumulator. |
| FC03              | 47               | MOV                | B,A      | Move the content of register A to B.                            |
| FC04              | 76               | HLT                |          | Halt.                                                           |
| DATA<br>FC50 — 05 |                  |                    |          | mostly with the content of the                                  |

## AdditionofTwo8-bitNo.;sum8-bit

| PROGRA                |                  | Mnemonics     | Operands       | Comments                                  |
|-----------------------|------------------|---------------|----------------|-------------------------------------------|
| Memory<br>address     | Machine<br>Codes | Whentonics    | oponance       |                                           |
| 2000                  | 21, 01, 25       | LXI           | H, 2501 H      | Get address of 1st number in<br>H-L pair. |
| 2003                  | 7E               | MOV           | A,M            | 1st number in accumulator.                |
| 2004                  | 23               | INX           | Н              | Increment content of H-L pair.            |
| 2005                  | 86               | ADD           | м              | Add 1st and 2nd numbers.                  |
| 2006                  | 32, 03, 25       | STA           | 2503 H         | Store sum in 2503 H.                      |
| 2009                  | 76               | HLT           |                | Stop                                      |
| DATA                  |                  |               |                |                                           |
| 2501 — 49 H           | 1                |               |                |                                           |
| 2502 — 56 H           | 1                |               | and the states |                                           |
| The sum is            | s stored in th   | e memory loca | tion 2503 H.   |                                           |
| Result<br>2503 — 9F H |                  |               |                |                                           |

## 8-bitSubtraction

| PROGR                   | AM               |                     |           |                                                    |
|-------------------------|------------------|---------------------|-----------|----------------------------------------------------|
| Memory<br>address       | Machine<br>Codes | Mnemonics           | Óperands  | Comments                                           |
| 2000                    | 21, 01, 25       | LXI                 | H, 2501 H | Get address of 1st number in H-L pair.             |
| 2003                    | 7E               | MOV                 | A, M      | 1st number in accumulator.                         |
| 2004                    | 23               | INX                 | H         | Content of H-L pair increases from 2501 to 2502 H. |
| 2005                    | 96               | SUB                 | м         | 1st number - 2nd number.                           |
| 2006                    | 23               | INX                 | He Store  | Content of H-L pair becomes 2503 H.                |
| 2007                    | 77               | MOV                 | M, A      | Store result in 2503 H.                            |
| 2008                    | 76               | HLT                 |           | Halt                                               |
| Example                 | 1                |                     |           | Example 2                                          |
| DATA                    | Section Sector   |                     |           | DATA                                               |
| 2501 - 49 H             |                  |                     |           | 2501 — F8 H                                        |
|                         |                  |                     |           | 2502 — 9B H                                        |
| No. of Concession, Name |                  | ory location 2503 H | 1.14      | Result                                             |
|                         |                  |                     |           | 2503 — 5D H                                        |
| 2503 - 1                | /H               | Evenuela 2          |           | tianlaged in H-I pair by the                       |

## ADDITIONOFTWO8-BITNO.;SUM:16-BIT

| PROGR             |                  |        |           |                           | FROGRAM                                          |  |  |
|-------------------|------------------|--------|-----------|---------------------------|--------------------------------------------------|--|--|
| Memory<br>address | Machine<br>Codes | Labels | Mnemonics | Operands                  | Comments                                         |  |  |
| 2000              | 21, 01, 25       |        | LXI       | H, 2501 H                 | Address of 1st number in H-L pair.               |  |  |
| 2003              | 0E, 00           |        | MVI       | C,00                      | MSBs of sum in register C<br>Initial value = 00. |  |  |
| 2005              | 7E               |        | MOV       | A, M                      | 1st number in accumulator.                       |  |  |
| 2006              | 23               |        | INX       | н                         | Address of 2nd number 2502 in<br>H-L pair.       |  |  |
| 2007              | 86               |        | ADD       | м                         | 1st number + 2nd number.                         |  |  |
| 2008              | D2, 0C, 20       |        | JNC       | AHEAD                     | Is carry? No, go to the labe AHEAD.              |  |  |
| 200B              | 00               |        | INR       | С                         | Yes, increment C.                                |  |  |
| 200C              | 32, 03, 25       | AHEAD  | STA       | 2503 H                    | LSBs of sum in 2503 H.                           |  |  |
| 200F              | 79               |        | MOV       | A, C                      | MSBs of sum in accumulator.                      |  |  |
| 2010              | 32, 04, 25       |        | STA       | 2504 H                    | MSBs of sum in 2504 H.                           |  |  |
| 2013              | 76               |        | HLT       |                           | Halt                                             |  |  |
| Example 1         | HICH DORO        |        |           | Example 2                 |                                                  |  |  |
| DATA              |                  |        |           | DATA                      |                                                  |  |  |
| 2501 — 98 H       |                  |        |           | 2501 — F5 H               |                                                  |  |  |
| 2502 — 9A H       |                  |        |           | 2502 — 8A H               |                                                  |  |  |
| Result            |                  |        |           | Result                    |                                                  |  |  |
|                   | 2 H, LSBs of su  |        |           | 2503 — 7F H, LSBs of sum. |                                                  |  |  |
|                   | H, LSBs of sur   |        |           | 2504 — 01 H, MSBs of sum. |                                                  |  |  |

## **CHAPTER-5**

## INTERFACINGANDSUPPORTCHIPS

#### BasicInterfacingConcepts

**Interface** is the path for communication between two components. Interfacing is of two types, memory interfacing and I/O interfacing.

#### Memorymapping&I/Omapping

# Functional block diagram and description of each blockofProgrammableperipheralinterfaceIntel8255

The parallel input-output port chip 8255 is also called as programmable peripheral input- output port. The Intel's 8255 is designed for use with Intel's 8-bit, 16-bitand higher capability microprocessors.

The 8255A is a general purpose programmable I/O device designed to transfer the data from I/O to interrupt I/O under certain conditions as required. It can be used with almost any microprocessor.

#### Portsof8255A

8255Ahasthreeports, i.e., PORTA, PORTB, and PORTC.

PortAcontainsone8-bitparallelporti.ePA0 -PA7

```
PortBcontainsone8-bitparallelporti.ePB0-PB7
```

Port Ccan be split into two parts, i.e. PORT C lower ( $PC_0-PB_3$ ) and PORT C upper( $ePC_4-PC_7$ )bythecontrol word.



Pin Diagram of 8255 PPI

Electronics Desk



#### DataBusBuffer

It is a tri-state 8-bit buffer, which is used to interface the microprocessor to the system data bus. Data is transmitted or received by the buffer as per the instructions by the CPU. Control words and status information is also transferred using this bus.

#### Read/Writecontrollogic:

This unit manages the internal operations of the system. This unit holds theability to control the transfer of data and control or status words both internally and externally.

Wheneverthere exists a need for data fetch then it accepts the address provided by the processor through the bus and immediately generates command to the 2 control groups for the particular operation.

#### Group AandGroupBcontrol:

These two groups are handled by the CPU and functions according to the command generated by the CPU. The CPU sends control words to the group A and group B control and they in turn sends the appropriate command to their respective port.

the group A has the access of the port A and higher order bits of port C. While group B controls port B with the lower order bits of port C.

 $\boxed{22}$ : It stands for chip select. A low signal at this pin shows the enabling of communication between the 8255 and the processor. More specifically we can say that the data transfer operation gets enabled by an active low signal at this pin.

 $\square$  – It is the signal used for read operation. A low signal at this pin shows that CPU is performing read operation at the ports or status word. Or we can say that 8255 is providing data or information to the CPU through data buffer.

 $\boxed{22}$  - It shows write operation. A low signal at this pin allows the CPU to perform write operation over the ports or control register of 8255 using the data bus buffer.

 $A_{o}$  and  $A_{i}$ : These are basically used to select the desired portaon gall the ports of the 8255 and it do so by forming conjunction with RD and WR. It forms connection with the LSB of the address bus.

Thetablebelowshowstheoperationofthecontrolsignals:

| A, | A | Port/Control<br>word<br>Register<br>address | Deviceselected  |
|----|---|---------------------------------------------|-----------------|
| 0  | 0 | 00                                          | Port-A          |
| 0  | 1 | 01                                          | Port-B          |
| 1  | 0 | 02                                          | Port-C          |
| 1  | 1 | 03                                          | ControlRegister |

#### Forthe1<sup>st</sup>unitof8255,i.e8255.1

#### For the 2nd unit of 8255, i.e 8255.2

| A1 | A | Port/Control<br>word<br>Register<br>address | Deviceselected  |
|----|---|---------------------------------------------|-----------------|
| 0  | 0 | 08                                          | Port-A          |
| 0  | 1 | 09                                          | Port-B          |
| 1  | 0 | 0A                                          | Port-C          |
| 1  | 1 | 0B                                          | ControlRegister |

**Reset:** It is an active high signal that shows the resetting of the PPI. A high signal at this pin clears the control registers and the ports are set in the input mode. Initializingtheportstoinputmodeisdonetoprevent circuitbreakdown. Asincase of reset condition, if the ports are initialized to output mode then there exist chances of destruction of 8255 along with the processor.

## Operatingmodeof8255

Operatingmodecanbeclassifiedasfollows **Mode0**:Simpleinput/output **Mode1**:Inputoutput withhandshaking **Mode2**:Bidirectionall/Ohandshaking

#### Mode0:Simpleinput/output:-

In this mode, all the three ports can be programmed either as the input or the output port. Each port can be programmed in either input mode or output mode where outputs are latched and inputs are not latched. Ports do not have interrupt capability. The ports in mode-0 can be used to interface DIP switches, hexakeypad, LEDs and 7-segment LEDs to the processor

#### Mode1:Inputoutputwithhandshaking

In mode 1, only port A and B can be programmed either as theinput or output port . the port-Care used for handshaking and interrupt control signals. Input and output data are latched. Interrupt driven data transfer scheme is possible

#### Mode2:Bidirectionall/Ohandshaking

Inthismode,alltheportwillbeabidirectionalport(i.e.theprocessorcanperform both read and write operations with an IO device connected to a port in mode-2) only port-A can be programmed to work in mode-2. Five pins of port-C are used for handshake signals. This mode is used primarily in applications such as data transfer between two computers or floppy disk controller interface

### **ControlWord:-**

#### 7.7.4 Control Word

According to the requirement a port can be programmed to act either as an input port or an output port. For programming the ports of 8255 a control word is formed. The bits of the control word are as shown in Fig. 7.15. Control word is written 4 3 2 1 0 -BIT NO. into the control word register - CONTROL WORD BITS which is within 8255. No read operation of the control word PORT C LOWER, INPUT = 1, OUTPUT = 0 PORT B, INPUT = 1,OUTPUT = 0 register is allowed. The control MODE SELECTION FOR PORT B, word bit corresponding to a MODE 0 = 0, MODE 1 = 1 PORT C UPPER, INPUT = 1,OUTPUT = 0 particular port is set to either 1 or 0 PORT A, INPUT = 1,OUTPUT = 0 depending upon the definition of MODE SELECTION FOR PORT A the port, whether it is to be made MODE 0 = 00, MODE 1 = 01MODE 2 = 1Xan input port or output port. If a Fig. 7.15 Control Word Bits for Intel 8255 particular port is to be made an input port, the bit corresponding to that port is set to 1. For making a port an output port, the corresponding bit for the port is set to 0. The detailed description of the bits of the control word is as follows: It is for Port Clower. Bit No. 0. To make Port  $C_{lower}$  an input port, the bit is set to 1. To make Port  $C_{lower}$  an output port, the bit is set to 0. Bit No. 1. It is for Port B. To make Port B an input port, the bit is set to 1. To make Port B an output port, the bit is set to 0. Bit No. 2. It is for the selection of the mode for the Port B. If the Port B has to operate in Mode 0, the bit is set to 0. For Mode 1 operation of the port B, it is set to 1. Bit No. 3.

to 1. Bit No. 3. It is for the Port C<sub>upper</sub>. To make Port C<sub>upper</sub> an input port, the bit is set to 1. To make Port C<sub>upper</sub> an output port, the bit is set to 0.

| Bit No. 4. | It is for Port A.<br>To make Port A an  | n input port, the bit is s                                                                                                                                                              | et to 1.             |  |  |  |  |  |  |  |
|------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|--|--|--|--|--|--|
| Bit No. 5  | To make Port A a<br>These bits are to d | To make Port A an output Port, the bit is set to 0.<br>These bits are to define the operating mode of the Port A. For the various<br>modes of Port A these bits are defined as follows: |                      |  |  |  |  |  |  |  |
| and 6.     | Mode of Port A                          | Bit No. 6                                                                                                                                                                               | Bit No. 5            |  |  |  |  |  |  |  |
|            | Mode 0                                  | 0                                                                                                                                                                                       | 0                    |  |  |  |  |  |  |  |
| Reit       | Mode 1                                  | 0                                                                                                                                                                                       |                      |  |  |  |  |  |  |  |
|            | Mode 2                                  | 1                                                                                                                                                                                       | 0 or 1               |  |  |  |  |  |  |  |
|            | For mode 2 bit No                       | o. 5 is set to either 0 or 1                                                                                                                                                            | 1; it is immaterial. |  |  |  |  |  |  |  |

Bit No. 7. It is set to 1 if Port A, B and C are defined as input/output port. It is set to 0 if the individual pins of the Port C are to be set or reset.

Table 7.5 shows control words for various configurations of the ports of 8255 for Mode 0 operation. The following examples will illustrate how to make control words:

| al | 10 est   | Con | trol W | lord E | Bits | Ant |   | Control<br>word | Port<br>A | <i>Port</i><br>C <sub>upper</sub> | Port<br>B  | Port<br>C <sub>lower</sub> |
|----|----------|-----|--------|--------|------|-----|---|-----------------|-----------|-----------------------------------|------------|----------------------------|
| 7  | 6        | 5   | 4      | 3      | 2    | 1   | 0 | hand and        | There     |                                   | uqteo      | Output                     |
| 1  | 0        | 0   | 0      | 0      | 0    | 0   | 0 | 80              | Output    | Output                            | Output     | Output                     |
|    | A SECOND | 0   | 0      | 0      | 0    | 0   | 1 | 81              | Output    | Output                            | Output     | Input                      |
| 1  | 0        |     |        | 0      | 0    | 1   | 0 | 82              | Output    | Output                            | Input      | Output                     |
| 1  | 0        | 0   | 0      |        | 0    | 1   | 1 | 83              | Output    | Output                            | Input      | Input                      |
| 1  | 0        | 0   | 0      | 0      |      | 0   | 0 | 88              | Output    | Input                             | Output     | Output                     |
| 1  | 0        | 0   | 0      | 1      | 0    |     |   | 89              | Output    | Input                             | Output     | Input                      |
| 1  | 0        | 0   | 0      | 1      | 0    | 0   | 1 | 8A              | Output    | Input                             | :<br>Input | Output                     |
| 1  | 0        | 0   | 0      | 1      | 0    | 1   | 0 |                 | Output    | Input                             | Input      | Input                      |
| 1  | 0        | 0   | 0      | 1      | 0    | 1   | 1 | 8B              |           | Output                            | Output     | Output                     |
| 1  | 0        | 0   | 1      | 0      | 0    | 0   | 0 | 90              | Input     |                                   | Output     | Input                      |
| 1  | 0        | 0   | 1      | 0      | 0    | 0   | 1 | 91              | Input     | Output                            |            | Output                     |
| 1  | 0        | 0   | 1      | 0      | 0    | 1   | 0 | 92              | Input     | Output                            | Input      |                            |
|    |          | 0   | 1      | 0      | 0    | 1   | 1 | 93              | Input     | Output                            | Input      | Input                      |
| 1  | 0        |     |        | 1      | 0    | 0   | 0 | 98              | Input     | Input                             | Output     | Output                     |
| 1  | 0        | 0   |        |        | 0    | 0   | 1 | 99              | Input     | Input                             | Output     | Input                      |
| 1  | 0        | 0   | 1      | TAR    | 0    | 1   | 0 | 9A              | Input     | Input                             | Input      | Output                     |
| 1  | 0        | 0   | 1      | 1      | 0    | -   | 1 | 9B              | Input     | Input                             | Input      | Input                      |

## Table 7.5 Control Words for 8255A for Mode 0 Operation

the sector of Intol 8255 are defined as follows:

### **Exampleareasfollows:**



## ProgramforTrafficlightControlusing8085microprocessor



| Memory address | Machine Codes | Lables | Mnemonics | Operands | Comments                    |
|----------------|---------------|--------|-----------|----------|-----------------------------|
| FC00           | 3E, 80        |        | MVI       | A, 80 H  | Get control word for 8255.  |
| FC02           | D3, 0B        |        | OUT       | 0B       | Initialize ports of 8255.2. |
| FC04           | 3E, 01        | LOOP   | MVI       | A, 01    |                             |
| FC06           | D3, 09        |        | OUT       | 09       | Red ON for south.           |
| FC08           | D3, 08        |        | OUT       | 08       | Red ON for north.           |
| FCOA           | 3E, 44        |        | MVI       | A, 44    | Green ON for east and west  |
| FCOC           | D3, 0A        |        | OUT       | 0A       |                             |
| FCOE           | CD, 00, FD    |        | CALL      | DELAY I  |                             |
| FC11           | 3E, 22        |        | MVI       | A, 22    | Yellow ON for east and wes  |

|          | D3, 0A     |            | OUT        | 0A       |                              |
|----------|------------|------------|------------|----------|------------------------------|
| FC13     | 3E, 02     |            | MVI        | A, 02    |                              |
| FC15     | D3, 09     |            | OUT        | 09       | Yellow ON for south          |
| FC17     | D3, 08     | A CONTRACT | OUT        | 08       | Yellow ON for north.         |
| FC19     | CD, 13; FD | 1          | CALL       | DELAY II | 81 76                        |
| FC1B     | 3E, 11     | 1 25       | MVI        | A, 11    |                              |
| FC1E     | D3, 0A     |            | OUT        | OA       | Red ON for east and west.    |
| FC20     | 3E, 04     |            | MVI        | A, 04    |                              |
| FC22     | D3, 08     |            | OUT        | 08       | Green ON for north.          |
| FC24     | D3, 09     |            | OUT        | 09       | Green ON for south.          |
| FC26     |            |            | CALL       | DELAY I  |                              |
| FC28     | CD, 00, FD |            | MVI        | A, 22    | Yellow ON for east and west. |
| FC2B     | 3E, 22     |            | OUT        | 0A       |                              |
| FC2D     | D3, 0A     |            | MVI        | A, 02    |                              |
| FC2F     | 3E, 02     |            | OUT        | 09       | Yellow ON for south.         |
| FC31     | D3, 09     |            | OUT        | 08       | Yellow ON for north.         |
| FC33     | D3, 08     |            | CALL       | DELAY II | 2408 20 20 20 20 20 20       |
| FC35     | CD, 13, FD |            | JMP        | LOOP     |                              |
| FC38     | C3, 04, FC |            | JIVIP      | LOOI     |                              |
| DELAY    |            |            | MVI        | B, 20 H  |                              |
| FD00     | 06, 20     |            |            | C, FF    |                              |
| FD02     | OE, FF     | G03        | MVI        | D, FF    |                              |
| FD04     | 16, FF     | G02        | MVI        | D        |                              |
| FD06     | 15         | G01        | DCR<br>JNZ | G01      |                              |
| FD07     | C2, 06, FD |            | DCR        | C        |                              |
| FDOA     | OD         |            | JNZ        | G02      |                              |
| FD0B     | C2, 04, FD |            | DCR        | B        |                              |
| FDOE     | 05         |            | JNZ        | G03      |                              |
| FDOF     | C2, 02, FD |            | RET        |          |                              |
| FD12     | C9         |            | ne i       |          |                              |
| DELAY II |            |            | MVI        | B, 10    |                              |
| FD13     | 06, 10     |            | JMP        | FD02     | To G03 lable in Delay I      |
| FD15     | C3, 02, FD |            |            |          | nears may be included to     |

## ProgramforSquarewavegeneratorusing8085 microprocessor

| 9.62                                                                                                                      | Micro-<br>processor                                                                                                               | PPI 8255   | 5-2 Port B Buff<br>PB <sub>0</sub> 740                                     |                                                                                               | fore the second                                                                 |
|---------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| 1:                                                                                                                        | Fig. 9.55 To G                                                                                                                    | Generate S | quare Wave us                                                              | sing Microproce                                                                               | essor                                                                           |
| PROGRAM<br>Memory address<br>2400<br>2402<br>2402<br>2404<br>2406<br>2406<br>2408<br>240B<br>240B<br>240D<br>240F<br>2412 | Machine Codes<br>3E, 98<br>D3, 0B<br>3E, 00<br>D3, 09<br>CD, 00, 25<br>3E, 01<br>D3, 09<br>CD, 09, 25<br>CD, 09, 25<br>C3, 04, 24 | LOOP       | Mnemonics<br>MVI<br>OUT<br>MVI<br>OUT<br>CALL<br>MVI<br>OUT<br>CALL<br>JMP | <i>Operands</i><br>A, 98 H<br>OB<br>A, 00<br>09<br>DELAY I<br>A, 01<br>09<br>DELAY II<br>LOOP | Comments<br>Get control word.<br>Initialize ports.<br>Make PB <sub>0</sub> LOW. |
| SUBROUTINSES<br>DELAY I<br>2500<br>2502<br>2503<br>2506                                                                   | 06, 02<br>05<br>C3, 02, 25<br>C9                                                                                                  | GO         | MVI<br>DCR<br>JNZ<br>RET                                                   | B, 02<br>B<br>GO                                                                              | Get count for delay.                                                            |
| DELAY II<br>2509<br>250B<br>250C<br>250F                                                                                  | 0E, 02<br>0D<br>C2, 0B, 25<br>C9                                                                                                  | BACK       | MVI<br>DCR<br>JNZ<br>RET                                                   | C, 02<br>C<br>BACK                                                                            | Get count for delay.                                                            |