

# **SNS COLLEGE OF TECHNOLOGY**

**Coimbatore-35 An Autonomous Institution** 

Accredited by NBA – AICTE and Accredited by NAAC – UGC with 'A+' Grade Approved by AICTE, New Delhi & Affiliated to Anna University, Chennai

# **DEPARTMENT OF ELECTRONICS AND COMMUNICATION ENGINEERING**

### **19ECB211 – MICROCONTROLLER PROGRAMMING & INTERFACING**

**II YEAR IV SEM** 

**UNIT II – PIC TIMER, SERIAL PORT AND INTERRUPT** 

**TOPIC 2 – PIC Time Delay and Instruction Pipeline** 







### **PIC Instruction Pipeline**

> The control unit in all Central Processing Units (CPUs) follows the same basic instruction processing sequence: **fetch** the instruction **decode** the instruction **execute** the instruction > Modern, high-performance CPUs (like MIPS<sup>®</sup>) use a technique called Pipelining



2/8



### **PIC Instruction Pipeline**

phases of instruction processing are executed in independent overlapping stages



N-stage pipelines therefore have n-instructions at different stages of execution moving through the pipeline, similar to an automotive assembly line.





### **General Instruction Pipeline**

### PIC32MZ Pipelined Instruction Execution (E) (M) (A) (W) (I) Instruction #1 Align Writeback Fetch Execute Memory (A) (M) (l)(E) Instruction #2 Fetch Align Execute Memory (1) (M) (E) Instruction #3 Execute Memory Fetch (1) (E) Instruction #4 Fetch Execute (0)Instruction #5 Fetch







### **PIC Clock & Instruction Cycle**

- Clock from the oscillator enters a microcontroller via OSC1 pin where internal circuit of a microcontroller divides the clock into four even clocks Q1, Q2, Q3 and Q4 which do not overlap.
  These four clocks make up one instruction code (also called)
- These four clocks make up one instruction cycle (also called machine cycle) during which one instruction is executed.







## **PIC Clock & Instruction Cycle**

- Execution of instruction starts by calling an instruction that is next in string.
- Instruction is called from program memory on every Q1 and is written in Instruction Register (IR) on Q4.
- Decoding and execution of instruction are done between the next Q1 and Q4 cycles. The following diagram shows the relationship between instruction cycle and clock of the oscillator (OSC1) as well as that of internal clocks Q1 – Q4.
- Program Counter (PC) holds information about the address of the next instruction.







### **Pipelining in PIC16F877A**

- There are 35 single word instructions. A two-stage pipeline overlaps fetch and execution of instructions. As a result, all instructions execute in a single cycle except for program branches. These take two cycles since the fetch instruction is "flushed" from the pipeline while the new instruction is being fetched and then executed.
- A typical picture of the pipeline is shown in Figure 3.

### Figure3: Instruction Pipeline Flow





TCY4 TCY5

| Flush     |                 |
|-----------|-----------------|
| tch SUB_1 | Execute SUB_1   |
|           | Fetch SUB_1 + 1 |



# References

https://www.embedded.com/the-evolution-of-embedded-devices-addressing-complex-design-challenges/

http://iamtechnical.com/org-origin-end-list-include-config-radix-directives

https://www.electronicspecifier.com/products/design-automation/embedded-systems-the-evolution-of-embeddedsystem-design

Mazidi M. A., McKinlay R. D., Causey D. "PIC Microcontroller And Embedded Systems" Pearson Education International, 2008(Unit I,II,III, IV & V)



