

# Subject Name Solutions

1333202 – Summer 2024

Semester 1 Study Material

*Detailed Solutions and Explanations*

## Question 1(a) [3 marks]

List common features of 8051 microcontroller.

### Solution

Table 1: Common Features of 8051 Microcontroller

| Feature                   | Description                            |
|---------------------------|----------------------------------------|
| <b>On-chip Oscillator</b> | Built-in clock generator circuit       |
| <b>Program Memory</b>     | 4KB internal ROM for code storage      |
| <b>Data Memory</b>        | 128 bytes internal RAM                 |
| <b>I/O Ports</b>          | 4 bidirectional 8-bit ports (P0-P3)    |
| <b>Timers/Counters</b>    | Two 16-bit Timer/Counter units         |
| <b>Serial Port</b>        | Full duplex UART communication         |
| <b>Interrupts</b>         | 5 interrupt sources with priority      |
| <b>SFRs</b>               | Special Function Registers for control |

### Mnemonic

“On Program Data I/O Timers Serial Interrupts SFRs”

## Question 1(b) [4 marks]

Define T-State, Machine Cycle, Instruction Cycle and Opcode.

### Solution

Table 2: Microprocessor Timing Definitions

| Term                     | Definition                                    | Duration           |
|--------------------------|-----------------------------------------------|--------------------|
| <b>T-State</b>           | One clock period of system clock              | Basic timing unit  |
| <b>Machine Cycle</b>     | Time to complete one memory operation         | 3-6 T-states       |
| <b>Instruction Cycle</b> | Time to fetch, decode and execute instruction | 1-4 Machine cycles |
| <b>Opcode</b>            | Operation code specifying instruction type    | 1-3 bytes          |

- **T-State:** Smallest unit of time in microprocessor operation
- **Machine Cycle:** Contains multiple T-states for memory access
- **Instruction Cycle:** Complete instruction execution time
- **Opcode:** Binary code identifying specific instruction

### Mnemonic

“Time Machine Instruction Operation”

## Question 1(c) [7 marks]

Compare Von-Neumann and Harvard Architecture.

## Solution

Table 3: Von-Neumann vs Harvard Architecture Comparison

| Parameter                  | Von-Neumann                     | Harvard                           |
|----------------------------|---------------------------------|-----------------------------------|
| <b>Memory Organization</b> | Single memory for code and data | Separate memory for code and data |
| <b>Bus Structure</b>       | Single bus system               | Dual bus system                   |
| <b>Speed</b>               | Slower due to bus sharing       | Faster parallel access            |
| <b>Cost</b>                | Lower cost implementation       | Higher cost due to dual memory    |
| <b>Flexibility</b>         | More flexible memory usage      | Less flexible, fixed allocation   |
| <b>Examples</b>            | 8085, x86 processors            | 8051, DSP processors              |



### Key Differences:

- **Memory Access:** Von-Neumann uses sequential access, Harvard allows simultaneous
- **Performance:** Harvard is faster for embedded applications
- **Applications:** Von-Neumann for general computing, Harvard for real-time systems

## Mnemonic

“Von-Single Harvard-Dual”

## Question 1(c) OR [7 marks]

Explain Microcomputer System with block diagram.

## Solution

**Microcomputer System Components:**



Table 4: Microcomputer System Components

| Component         | Function                       | Examples               |
|-------------------|--------------------------------|------------------------|
| <b>CPU</b>        | Central processing and control | 8085, 8086             |
| <b>Memory</b>     | Program and data storage       | RAM, ROM, EPROM        |
| <b>I/O Unit</b>   | Interface with external world  | Keyboard, Display      |
| <b>System Bus</b> | Data transfer pathway          | Address, Data, Control |

- **CPU:** Executes instructions and controls system operation
- **Memory:** Stores programs and data for processing
- **I/O:** Provides communication with external devices
- **Bus:** Connects all components for data transfer

### Mnemonic

“CPU Memory I/O Bus”

### Question 2(a) [3 marks]

Draw Bus organization in 8085 Microprocessor.

### Solution

```

1 +-----+
2 | 8085  |
3 | CPU   |
4 +-----+
5 |
6 +---+---+
7 |       |
8 v       v
9 +---+ +---+
0 |Address| | Data  |
1 | Bus   | | Bus   |
2 |16-bit | | 8-bit |
3 +---+ +---+
4 |       |
5 v       v
  
```

```

6 |-----+ +-----+
7 |Memory | | I/O   |
8 |System  | | Devices |
9 |-----+ +-----+

```

Table 5: 8085 Bus Organization

| Bus Type           | Width    | Function                 |
|--------------------|----------|--------------------------|
| <b>Address Bus</b> | 16-bit   | Memory addressing (64KB) |
| <b>Data Bus</b>    | 8-bit    | Data transfer            |
| <b>Control Bus</b> | Multiple | Control signals          |

### Mnemonic

“Address Data Control”

## Question 2(b) [4 marks]

List Flags used in 8085 and Explain working of each flags.

### Solution

Table 6: 8085 Flags Register

| Flag      | Name            | Bit Position | Function                      |
|-----------|-----------------|--------------|-------------------------------|
| <b>S</b>  | Sign            | D7           | Set if result is negative     |
| <b>Z</b>  | Zero            | D6           | Set if result is zero         |
| <b>AC</b> | Auxiliary Carry | D4           | Set if carry from bit 3 to 4  |
| <b>P</b>  | Parity          | D2           | Set if result has even parity |
| <b>CY</b> | Carry           | D0           | Set if carry/borrow occurs    |

```

1 D7 D6 D5 D4 D3 D2 D1 D0
2 +---+---+---+---+---+---+
3 | S | Z | - | AC | - | P | - | CY |
4 +---+---+---+---+---+---+

```

- Sign Flag:** Indicates negative result (MSB = 1)
- Zero Flag:** Set when arithmetic result is zero
- Auxiliary Carry:** Used for BCD arithmetic operations
- Parity Flag:** Checks even number of 1's in result
- Carry Flag:** Indicates overflow in arithmetic operations

### Mnemonic

“Sign Zero Auxiliary Parity Carry”

## Question 2(c) [7 marks]

Draw and Explain Block Diagram of 8085.

## Solution



Table 7: 8085 Block Components

| Block                  | Function                          | Size       |
|------------------------|-----------------------------------|------------|
| <b>ALU</b>             | Arithmetic and logical operations | 8-bit      |
| <b>Accumulator</b>     | Primary register for operations   | 8-bit      |
| <b>Registers</b>       | Data storage (B,C,D,E,H,L)        | 8-bit each |
| <b>Program Counter</b> | Points to next instruction        | 16-bit     |
| <b>Stack Pointer</b>   | Points to stack top               | 16-bit     |
| <b>Control Unit</b>    | Instruction decode and control    | -          |

- **Data Flow:** Instructions fetched via PC, decoded by CU, executed in ALU
- **Register Operations:** Accumulator works with ALU, other registers store data
- **Address Generation:** PC and SP provide 16-bit addresses
- **Control Signals:** CU generates timing and control signals

## Mnemonic

“ALU Accumulator Registers Program Stack Control”

## Question 2(a) OR [3 marks]

Explain Instruction Fetching, Decoding and Execution Operation in microprocessor.

## Solution



Table 8: Instruction Cycle Phases

| Phase          | Operation                    | Duration           |
|----------------|------------------------------|--------------------|
| <b>Fetch</b>   | Get instruction from memory  | 1 machine cycle    |
| <b>Decode</b>  | Interpret instruction opcode | Part of execute    |
| <b>Execute</b> | Perform required operation   | 1-3 machine cycles |

## Mnemonic

“Fetch Decode Execute”

## Question 2(b) OR [4 marks]

What is Demultiplexing of Lower order Address and Data lines in 8085? Explain using neat sketch.

## Solution



### Demultiplexing Process:

- ALE Signal:** Controls separation of address and data
- Latch IC:** 74LS373 stores address when ALE is high
- Timing:** Address appears first, then data on same lines

Table 9: Demultiplexing Components

| Component      | Function                    | Timing         |
|----------------|-----------------------------|----------------|
| <b>ALE</b>     | Address Latch Enable signal | High during T1 |
| <b>74LS373</b> | Octal latch IC              | Stores A7-A0   |

**Mnemonic**

“Address Latch Enable Demultiplexes Lines”

**Question 2(c) OR [7 marks]**

Draw and Explain Pin Diagram of 8085.

**Solution**

| 8085 PIN DIAGRAM |              |
|------------------|--------------|
| X1   1           | 40  VCC      |
| X2   2           | 39  HOLD     |
| RST   3          | 38  HLDA     |
| SOD   4          | 37  CLK      |
| SID   5          | 36  RESET IN |
| TRAP  6          | 35  READY    |
| RST7  7          | 34  IO/M     |
| RST6  8          | 33  S1       |
| RST5  9          | 32  RD       |
| INTR  10         | 31  WR       |
| INTA  11         | 30  ALE      |
| AD0   12         | 29  S0       |
| AD1   13         | 28  A15      |
| AD2   14         | 27  A14      |
| AD3   15         | 26  A13      |
| AD4   16         | 25  A12      |
| AD5   17         | 24  A11      |
| AD6   18         | 23  A10      |
| AD7   19         | 22  A9       |
| VSS   20         | 21  A8       |

Table 10: 8085 Pin Functions

| Pin Group              | Function                           | Count  |
|------------------------|------------------------------------|--------|
| <b>Address Bus</b>     | A8-A15 (Higher order)              | 8 pins |
| <b>Address/Data</b>    | AD0-AD7 (Multiplexed)              | 8 pins |
| <b>Control Signals</b> | ALE, RD, WR, IO/M                  | 4 pins |
| <b>Interrupts</b>      | TRAP, RST7.5, RST6.5, RST5.5, INTR | 5 pins |
| <b>Power</b>           | VCC, VSS                           | 2 pins |
| <b>Clock</b>           | X1, X2, CLK                        | 3 pins |

- **Address Lines:** 16-bit addressing capability (64KB)
- **Data Lines:** 8-bit data transfer
- **Control Lines:** Memory and I/O operation control
- **Interrupt Lines:** Hardware interrupt handling

**Mnemonic**

“Address Data Control Interrupt Power Clock”

**Question 3(a) [3 marks]**

Draw IP SFR of 8051 and Explain function of each bit.

## Solution

```

1 IP Register (Interrupt Priority) - Address B8H
2 MSB                               LSB
3 +---+---+---+---+---+---+
4 | - | - | - | PT2| PS| PT1| PX1| PX0|
5 +---+---+---+---+---+---+
6 D7  D6  D5  D4  D3  D2  D1  D0

```

Table 11: IP Register Bit Functions

| Bit | Name | Function                       |
|-----|------|--------------------------------|
| D4  | PT2  | Timer 2 interrupt priority     |
| D3  | PS   | Serial port interrupt priority |
| D2  | PT1  | Timer 1 interrupt priority     |
| D1  | PX1  | External interrupt 1 priority  |
| D0  | PX0  | External interrupt 0 priority  |

- **Priority Levels:** 1 = High priority, 0 = Low priority
- **Default:** All interrupts have low priority (00H)
- **Usage:** Set bit to 1 for high priority interrupt

## Mnemonic

"Timer2 Serial Timer1 External1 External0"

## Question 3(b) [4 marks]

Draw and explain Timer/Counter Logic diagram for 8051.

## Solution



Table 12: Timer Components

| Component      | Function                        | Size       |
|----------------|---------------------------------|------------|
| <b>TH0/TL0</b> | Timer 0 high/low byte registers | 8-bit each |
| <b>TMOD</b>    | Timer mode register             | 8-bit      |
| <b>TCON</b>    | Timer control register          | 8-bit      |
| <b>TF0</b>     | Timer 0 overflow flag           | 1-bit      |

- **Clock Source:** Internal (system clock/12) or External (T0 pin)
- **Operation:** Counts up from loaded value to FFH
- **Overflow:** Sets TF0 flag and generates interrupt
- **Modes:** 4 different timer modes available

### Mnemonic

“Timer High-Low Mode Control Flag”

### Question 3(c) [7 marks]

Draw and Explain Block Diagram of 8051.

### Solution



Table 13: 8051 Block Components

| Block                 | Function                | Specification                     |
|-----------------------|-------------------------|-----------------------------------|
| <b>CPU</b>            | Central processing unit | 8-bit processor                   |
| <b>Program Memory</b> | Code storage            | 4KB internal ROM                  |
| <b>Data Memory</b>    | Variable storage        | 128 bytes RAM                     |
| <b>I/O Ports</b>      | External interface      | 4 ports (32 I/O lines)            |
| <b>Timers</b>         | Timing operations       | $2 \times 16 - \text{bit timers}$ |
| <b>Serial Port</b>    | Communication           | Full duplex UART                  |
| <b>Interrupts</b>     | Event handling          | 5 interrupt sources               |

- **Architecture:** Harvard architecture with separate program/data memory
- **I/O Capability:** 32 bidirectional I/O lines
- **On-chip Features:** Timers, serial port, interrupt system
- **Memory:** Von-Neumann for data, Harvard for program

### Mnemonic

“CPU Program Data I/O Timer Serial Interrupt”

### Question 3(a) OR [3 marks]

Draw PCON SFR of 8051 and Explain function of each bit.

### Solution

```

1 PCON Register (Power Control) - Address 87H
2 MSB           LSB
3 +---+---+---+---+---+---+
4 |SMOD| - | - | - |GF1|GF0| PD|IDL|
5 +---+---+---+---+---+---+
6 D7  D6  D5  D4  D3  D2  D1  D0
  
```

Table 14: PCON Register Bit Functions

| Bit       | Name | Function                   |
|-----------|------|----------------------------|
| <b>D7</b> | SMOD | Serial port mode modifier  |
| <b>D3</b> | GF1  | General purpose flag bit 1 |
| <b>D2</b> | GF0  | General purpose flag bit 0 |
| <b>D1</b> | PD   | Power down mode control    |
| <b>D0</b> | IDL  | Idle mode control          |

- **SMOD:** Doubles serial port baud rate when set
- **GF1, GF0:** User-defined flag bits
- **PD:** Activates power-down mode
- **IDL:** Activates idle mode

#### Mnemonic

“Serial General Power Idle”

### Question 3(b) OR [4 marks]

In 8051 Serial communication Mode 1, For XTAL=11.0592 MHz, find TH1 value needed to have for 9600 and 4800 baud rate.

#### Solution

##### Formula for Mode 1 Baud Rate:

```

1 Baud Rate = (2^SMOD/32) \times (Timer1 Overflow Rate)
2 Timer1 Overflow Rate = XTAL/(12 \times (256 - TH1))

```

##### For 9600 Baud Rate:

```

1 9600 = (1/32) \times (11059200/(12 \times (256 - TH1)))
2 9600 = 28800/(256 - TH1)
3 256 - TH1 = 3
4 TH1 = 253 = FDH

```

##### For 4800 Baud Rate:

```

1 4800 = (1/32) \times (11059200/(12 \times (256 - TH1)))
2 4800 = 28800/(256 - TH1)
3 256 - TH1 = 6
4 TH1 = 250 = FAH

```

Table 15: TH1 Values for Baud Rates

| Baud Rate   | TH1 Value (Hex) | TH1 Value (Decimal) |
|-------------|-----------------|---------------------|
| <b>9600</b> | FDH             | 253                 |
| <b>4800</b> | FAH             | 250                 |

#### Mnemonic

“Higher Baud Higher TH1”

### Question 4(a) [3 marks]

What are the differences in LCALL and LJMP instructions in 8051?

#### Solution

Table 16: LCALL vs LJMP Comparison

| Parameter            | LCALL                  | LJMP               |
|----------------------|------------------------|--------------------|
| <b>Function</b>      | Long subroutine call   | Long jump          |
| <b>Stack Usage</b>   | Pushes return address  | No stack operation |
| <b>Return</b>        | RET instruction needed | Direct jump only   |
| <b>Bytes</b>         | 3 bytes                | 3 bytes            |
| <b>Address Range</b> | 16-bit (64KB)          | 16-bit (64KB)      |
| <b>PC Action</b>     | Saved then loaded      | Directly loaded    |

- **LCALL:** Calls subroutine, saves return address on stack
- **LJMP:** Unconditional jump to specified address
- **Stack Impact:** LCALL uses 2 stack bytes, LJMP uses none
- **Usage:** LCALL for functions, LJMP for program flow control

### Mnemonic

“Call Saves Jump Goes”

## Question 4(b) [4 marks]

Write 8051 Assembly Language Program to generate square wave on port 1.0 using Timer0.

### Solution

```

1 ORG 0000H      ; Start address
2 LJMP MAIN      ; Jump to main program
3
4 ORG 0030H      ; Main program start
MAIN:
5   MOV TMOD, #01H ; Timer0 mode1 (16-bit)
6   MOV TH0, #HIGH(-50000) ; Load high byte
7   MOV TL0, #LOW(-50000) ; Load low byte
8   SETB TR0        ; Start Timer0
9
LOOP:
10  JNB TF0, LOOP  ; Wait for overflow
11  CLR TF0        ; Clear overflow flag
12  CPL P1.0        ; Toggle P1.0
13  MOV TH0, #HIGH(-50000) ; Reload timer
14  MOV TL0, #LOW(-50000) ; Reload timer
15  SJMP LOOP      ; Repeat
16
END

```

### Program Explanation:

- **Timer Setup:** Mode 1 (16-bit timer)
- **Count Value:** -50000 for specific delay
- **Square Wave:** Toggle P1.0 on each overflow
- **Continuous:** Loop maintains square wave

### Mnemonic

“Mode Load Start Wait Toggle Reload”

## Question 4(c) [7 marks]

Explain any three Logical and any four Data Transfer Instruction of 8051 with example.

## Solution

Table 17: Logical Instructions

| Instruction | Function    | Example     | Result        |
|-------------|-------------|-------------|---------------|
| <b>ANL</b>  | Logical AND | ANL A, #0FH | A = A AND 0FH |
| <b>ORL</b>  | Logical OR  | ORL A, #F0H | A = A OR F0H  |
| <b>XRL</b>  | Logical XOR | XRL A, #FFH | A = A XOR FFH |

Table 18: Data Transfer Instructions

| Instruction | Function       | Example       | Operation                     |
|-------------|----------------|---------------|-------------------------------|
| <b>MOV</b>  | Move data      | MOV A, #50H   | Load 50H into A               |
| <b>MOVX</b> | Move external  | MOVX A, @DPTR | Load from external memory     |
| <b>PUSH</b> | Push to stack  | PUSH ACC      | Push accumulator to stack     |
| <b>POP</b>  | Pop from stack | POP ACC       | Pop from stack to accumulator |

### Detailed Examples:

```

1 ; Logical Instructions
2 ANL A, #0FH      ; Mask upper nibble
3 ORL P1, #80H     ; Set bit 7 of Port1
4 XRL A, #FFH      ; Complement accumulator
5
6 ; Data Transfer Instructions
7 MOV R0, #30H      ; Load immediate data
8 MOVX @DPTR, A    ; Store to external memory
9 PUSH B           ; Save B register
0 POP PSW          ; Restore status word

```

## Mnemonic

“AND OR XOR Move External Push Pop”

### Question 4(a) OR [3 marks]

Explain Instructions: (i) RRC A (ii) POP (iii) CLR PSW.7

## Solution

Table 19: Instruction Explanations

| Instruction      | Function                   | Operation | Example                       |
|------------------|----------------------------|-----------|-------------------------------|
| <b>RRC A</b>     | Rotate right through carry | A, C(MSB) | A=85H,C=0<br>→ A = 42H, C = 1 |
| <b>POP</b>       | Pop from stack             | SP, SP-1  | POP ACC                       |
| <b>CLR PSW.7</b> | Clear bit 7 of PSW         | PSW.7 = 0 | Clear CY flag                 |

```

1 RRC A Operation:
2 Before:
3
4 A = [D7 D6 D5 D4 D3 D2 D1 D0]
5
6 C = [C]
7
8 After:
9
10 A = [C D7 D6 D5 D4 D3 D2 D1]
11
12 C = [D0]

```

- **RRC A:** Rotates accumulator right through carry flag
- **POP:** Removes top stack element into specified register
- **CLR PSW.7:** Clears carry flag (bit 7 of Program Status Word)

### Mnemonic

“Rotate Pop Clear”

## Question 4(b) OR [4 marks]

Write 8051 Assembly Language Program to Divide data stored in location 30H by data stored in location 31H and store remainder in 40h and quotient in 41h memory location.

### Solution

```

1 ORG 0000H ; Program start
2 LJMP MAIN
3
4 ORG 0030H
5 MAIN:
6     MOV A, 30H ; Load dividend
7     MOV B, 31H ; Load divisor
8     DIV AB ; Divide A by B
9     MOV 41H, A ; Store quotient
10    MOV 40H, B ; Store remainder
11    SJMP $ ; Stop here
12
13 END

```

### Program Steps:

1. **Load Data:** Move dividend and divisor to A and B
2. **Division:** Use DIV AB instruction
3. **Store Results:** Quotient in A, remainder in B
4. **Save:** Store results in specified memory locations

Table 20: DIV AB Instruction

| Before       | After         |
|--------------|---------------|
| A = Dividend | A = Quotient  |
| B = Divisor  | B = Remainder |

### Mnemonic

“Load Divide Store”

## Question 4(c) OR [7 marks]

List Addressing Modes of 8051 Microcontroller and Explain each with Example.

## Solution

Table 21: 8051 Addressing Modes

| Mode             | Description              | Example            | Explanation             |
|------------------|--------------------------|--------------------|-------------------------|
| <b>Immediate</b> | Data in instruction      | MOV A, #50H        | Load 50H into A         |
| <b>Register</b>  | Use register             | MOV A, R0          | Move R0 content to A    |
| <b>Direct</b>    | Memory address specified | MOV A, 30H         | Load from address 30H   |
| <b>Indirect</b>  | Address in register      | MOV A, @R0         | Load from address in R0 |
| <b>Indexed</b>   | Base + offset            | MOVC A,<br>@A+DPTR | A = content of (A+DPTR) |
| <b>Relative</b>  | PC + offset              | SJMP HERE          | Jump relative to PC     |
| <b>Bit</b>       | Bit address              | SETB P1.0          | Set bit 0 of Port 1     |

### Detailed Examples:

```
1 ; Immediate Addressing
2 MOV A, #25H      ; Load immediate value 25H
3
4 ; Register Addressing
5 MOV A, R7       ; Move register R7 to A
6
7 ; Direct Addressing
8 MOV A, 40H      ; Load from memory location 40H
9
10 ; Indirect Addressing
11 MOV R0, #50H    ; R0 points to address 50H
12 MOV A, @R0      ; Load from address pointed by R0
13
14 ; Indexed Addressing
15 MOV DPTR, #TABLE ; Point to lookup table
16 MOVC A, @A+DPTR ; Load from table[A]
17
18 ; Relative Addressing
19 SJMP NEXT      ; Jump to label NEXT
20
21 ; Bit Addressing
22 SETB P2.5      ; Set bit 5 of Port 2
```

## Mnemonic

“Immediate Register Direct Indirect Indexed Relative Bit”

## Question 5(a) [3 marks]

Draw Interfacing of Relay with 8051 microcontroller.

## Solution

```
1 8051 Port Pin
2   |
3   |
4   +---+---+
5   | 2.2K  | Resistor
6   +---+---+
7   |
8   +---+---+ Base
9   | NPN    | Transistor
10  | BC547 |
11  +---+---+
12  |     Collector
13  |
14  +---+---+
```

```

5 | Relay   | 12V Relay
6 | Coil    |
7 +----+----+
8 |          |
9 +VCC (12V)

10
11 Relay Contacts
12 +----+----+
13 | NO  | NC  | Load Connection
14 +----+----+

```

Table 22: Interface Components

| Component         | Function               | Value     |
|-------------------|------------------------|-----------|
| <b>Transistor</b> | Current amplifier      | BC547 NPN |
| <b>Resistor</b>   | Base current limiter   | 2.2KΩ     |
| <b>Relay</b>      | Electromagnetic switch | 12V DC    |
| <b>Diode</b>      | Back EMF protection    | 1N4007    |

- **Operation:** Port pin HIGH → *TransistorON* → *Relayenergized*
- **Protection:** Diode prevents back EMF damage
- **Isolation:** Relay provides electrical isolation

### Mnemonic

“Transistor Resistor Relay Diode”

## Question 5(b) [4 marks]

Interface 7 Segment display with 8051 microcontroller and write a program to print “1” on it.

### Solution

```

1 8051 Port 1
2 P1.0 Ω---[330]---- a
3 P1.1 Ω---[330]---- b
4 P1.2 Ω---[330]---- c
5 P1.3 Ω---[330]---- d
6 P1.4 Ω---[330]---- e
7 P1.5 Ω---[330]---- f
8 P1.6 Ω---[330]---- g
9 P1.7 Ω---[330]---- dp

10
11 7-Segment Display
12     aaaa
13     f      b
14     f      b
15     gggg
16     e      c
17     e      c
18     dddd  dp

```

Program to Display “1”:

```

1 ORG 0000H
2 LJMP MAIN
3
4 ORG 0030H
5 MAIN:
6     MOV P1, #06H ; Display "1" (segments b,c ON)
7     SJMP $        ; Stop here
8
9 ; Pattern for "1": 00000110 = 06H

```

```

0 ; Only segments b and c are ON
1
2 END

```

Table 23: 7-Segment Display Components

| Component                        | Function               | Value          |
|----------------------------------|------------------------|----------------|
| <b>Current Limiting Resistor</b> | Protect LED segments   | 330Ω           |
| <b>Port Connection</b>           | Digital output control | Port 1         |
| <b>Display Pattern</b>           | Segment control        | Binary pattern |

### Mnemonic

“Current Limit Segment Pattern”

## Question 5(c) [7 marks]

Interface DAC 0808 with 8051 microcontroller and write a program to generate Square wave.

### Solution



### Program to Generate Square Wave:

```

1 ORG 0000H
2 LJMP MAIN
3
4 ORG 0030H
5 MAIN:
6     MOV A, #00H      ; Minimum value (0V)
7     MOV P2, A        ; Output to DAC
8     CALL DELAY      ; Wait period
9
10    MOV A, #0FFH    ; Maximum value (approx 5V)
11    MOV P2, A        ; Output to DAC
12    CALL DELAY      ; Wait period
13
14    SJMP MAIN      ; Repeat for square wave
15
16 DELAY:
17    MOV R0, #200      ; Delay counter
18 LOOP1:
19    MOV R1, #250      ; Inner loop counter
20 LOOP2:
21    DJNZ R1, LOOP2  ; Inner delay loop
22    DJNZ R0, LOOP1  ; Outer delay loop
23    RET
24
25 END

```

Table 24: DAC Interface Specifications

| Parameter                | Value    | Function             |
|--------------------------|----------|----------------------|
| <b>Resolution</b>        | 8-bit    | 256 output levels    |
| <b>Reference Voltage</b> | 5V       | Full scale output    |
| <b>Output Range</b>      | 0-5V     | Analog voltage range |
| <b>Interface Type</b>    | Parallel | 8-bit data bus       |

**Square Wave Generation:**

- **Low Level:** 00H produces approximately 0V output
- **High Level:** FFH produces approximately 5V output
- **Frequency:** Determined by delay routine duration
- **Output:** Clean analog square wave at DAC output

**Mnemonic**

“Digital Analog Convert Square”

**Question 5(a) OR [3 marks]**

Interface of Push button Switch with 8051 microcontroller.

**Solution**



Table 25: Push Button Interface Components

| Component               | Value          | Function                            |
|-------------------------|----------------|-------------------------------------|
| <b>Pull-up Resistor</b> | 10KΩ           | Ensures logic HIGH when switch open |
| <b>Push Button</b>      | SPST Momentary | User input device                   |
| <b>Logic Levels</b>     | HIGH=1, LOW=0  | Switch open=1, pressed=0            |

### Sample Program:

```
1 CHECK_SWITCH:  
2     JB P1.0, SW_RELEASED    ; Jump if switch not pressed  
3     ; Switch pressed code here  
4     CALL SWITCH_PRESSED  
5     SJMP CHECK_SWITCH  
6  
7 SW_RELEASED:  
8     ; Switch not pressed code here  
9     SJMP CHECK_SWITCH  
0  
1 SWITCH_PRESSED:  
2     ; Action when switch is pressed  
3     RET
```

### Operation:

- **Switch Open:** Pull-up resistor makes pin HIGH (logic 1)
- **Switch Pressed:** Pin connected to GND, becomes LOW (logic 0)
- **Debouncing:** May require software debouncing for reliable operation

### Mnemonic

“Pull-up Switch Ground”

## Question 5(b) OR [4 marks]

Interface DC Motor with 8051 microcontroller.

### Solution

```
1 8051 Port Pin (P1.0)  
2      |  
3      +---+---+  
4      | 1K      | Base Resistor  
5      +---+---+  
6      |  
7      +---+---+ Base  
8      | NPN      | Power Transistor  
9      | TIP122   | (Darlington)  
0      +---+---+  
1          | Collector  
2          |  
3      +---+---+  
4      | DC       | 12V DC Motor  
5      | Motor    |  
6      +---+---+  
7          |  
8          +VCC (12V)  
9  
0      +---+---+ Freewheeling Diode  
1      | 1N4007  | (Across Motor)  
2      +---+---+
```

### Motor Control Program:

```
1 MOTOR_ON:  
2     SETB P1.0      ; Turn motor ON  
3     RET  
4  
5 MOTOR_OFF:  
6     CLR P1.0      ; Turn motor OFF  
7     RET  
8  
9 MOTOR_SPEED_CONTROL:  
0     ; PWM for speed control
```

```

1 SETB P1.0      ; Motor ON
2 CALL DELAY_ON   ; ON time duration
3 CLR P1.0       ; Motor OFF
4 CALL DELAY_OFF  ; OFF time duration
5 RET
6
7 DELAY_ON:
8     MOV R0, #100    ; ON time delay
9     DJNZ R0, $
10    RET
11
12 DELAY_OFF:
13    MOV R0, #50     ; OFF time delay
14    DJNZ R0, $
15    RET

```

Table 26: DC Motor Interface Components

| Component                 | Function              | Specification            |
|---------------------------|-----------------------|--------------------------|
| <b>Power Transistor</b>   | Current amplification | TIP122 (Darlington pair) |
| <b>Base Resistor</b>      | Current limiting      | 1KΩ                      |
| <b>Freewheeling Diode</b> | Back EMF protection   | 1N4007                   |
| <b>DC Motor</b>           | Load device           | 12V DC Motor             |

#### Operation Principle:

- **Motor ON:** Port pin HIGH → *Transistor saturated* → *Motor runs*
- **Motor OFF:** Port pin LOW → *Transistor cut-off* → *Motor stops*
- **Speed Control:** PWM technique varies average power to motor
- **Protection:** Diode protects transistor from back EMF

#### Mnemonic

“Transistor Resistor Diode Motor”

### Question 5(c) OR [7 marks]

Interface LCD with 8051 microcontroller and write a program to display “Hello”.

#### Solution

```

1 8051      16x2 LCD Display
2 Port 2      +-----+
3 P2.0 ----->| D4      VCC  |---(+5V)
4 P2.1 ----->| D5      VDD  |---(GND)
5 P2.2 ----->| D6      VO   |---(Contrast Adj)
6 P2.3 ----->| D7      RS   |<--- P3.0
7           |      EN   |<--- P3.1
8           |      R/W  |---(GND)
9 +-----+

```

#### Complete LCD Interface Program:

```

1 ORG 0000H
2 LJMP MAIN
3
4 ORG 0030H
5 MAIN:
6     CALL LCD_INIT      ; Initialize LCD
7     MOV DPTR, #MESSAGE ; Point to message string
8     CALL DISPLAY_STRING ; Display the message
9     SJMP $              ; Stop execution
0
1 LCD_INIT:
2     CALL DELAY_15MS    ; Wait 15ms after power on

```

```

3 MOV A, #38H      ; Function set: 8-bit mode, 2 lines, 5x7 matrix
4 CALL COMMAND_WRITE
5 MOV A, #OEH      ; Display on, cursor on, blink off
6 CALL COMMAND_WRITE
7 MOV A, #01H      ; Clear display
8 CALL COMMAND_WRITE
9 MOV A, #06H      ; Entry mode: increment cursor, no shift
10 CALL COMMAND_WRITE
11 RET

12 COMMAND_WRITE:
13     MOV P2, A      ; Send command to data lines (D4-D7)
14     CLR P3.0      ; RS = 0 for command
15     SETB P3.1      ; Enable pulse high
16     CALL DELAY_1MS
17     CLR P3.1      ; Enable pulse low
18     CALL DELAY_1MS
19     RET

20 DATA_WRITE:
21     MOV P2, A      ; Send data to data lines (D4-D7)
22     SETB P3.0      ; RS = 1 for data
23     SETB P3.1      ; Enable pulse high
24     CALL DELAY_1MS
25     CLR P3.1      ; Enable pulse low
26     CALL DELAY_1MS
27     RET

28 DISPLAY_STRING:
29     CLR A
30     MOVC A, @A+DPTR ; Get character from string
31     JZ STRING_END    ; If zero, end of string
32     CALL DATA_WRITE  ; Display character
33     INC DPTR         ; Point to next character
34     SJMP DISPLAY_STRING ; Continue until end

35 STRING_END:
36     RET

37 MESSAGE: DB "HELLO", 0 ; Message string with null terminator

38 DELAY_1MS:
39     MOV R0, #4      ; Outer loop counter
40 DEL1:
41     MOV R1, #250    ; Inner loop counter
42 DEL2:
43     DJNZ R1, DEL2  ; Inner delay loop
44     DJNZ R0, DEL1  ; Outer delay loop
45     RET

46 DELAY_15MS:
47     MOV R2, #15     ; 15ms delay counter
48 DEL15:
49     CALL DELAY_1MS  ; Call 1ms delay
50     DJNZ R2, DEL15 ; Repeat 15 times
51     RET

52 END

```

Table 27: LCD Control Signals

| Signal       | Pin       | Function                                |
|--------------|-----------|-----------------------------------------|
| <b>RS</b>    | P3.0      | Register Select (0=Command, 1=Data)     |
| <b>EN</b>    | P3.1      | Enable pulse for data latch             |
| <b>R/W</b>   | GND       | Read/Write (tied to GND for write only) |
| <b>D4-D7</b> | P2.0-P2.3 | 4-bit data bus (upper nibble)           |

Table 28: Important LCD Commands

| Command                | Hex Code | Function                           |
|------------------------|----------|------------------------------------|
| <b>Function Set</b>    | 38H      | 8-bit mode, 2 lines, 5x7 matrix    |
| <b>Display Control</b> | 0EH      | Display ON, cursor ON, blink OFF   |
| <b>Clear Display</b>   | 01H      | Clear entire display               |
| <b>Entry Mode</b>      | 06H      | Increment cursor, no display shift |

#### LCD Display Process:

1. **Initialization:** Configure LCD parameters and clear display
2. **Command Mode:** Send commands with RS=0
3. **Data Mode:** Send characters with RS=1
4. **Enable Pulse:** Latch data/command with EN signal
5. **String Display:** Loop through message characters until null terminator

#### Character Display Steps:

- Set RS=1 for data mode
- Put character code on data bus
- Generate enable pulse (HIGH to LOW)
- Wait for LCD to process (1ms delay)
- Repeat for next character

#### Mnemonic

“Initialize Command Data Enable Display”