English
Language : 

PIC17C44 Datasheet, PDF (14/241 Pages) Microchip Technology – High-Performance 8-Bit CMOS EPROM/ROM Microcontroller
PIC17C4X
3.1 Clocking Scheme/Instruction Cycle
The clock input (from OSC1) is internally divided by
four to generate four non-overlapping quadrature
clocks, namely Q1, Q2, Q3, and Q4. Internally, the pro-
gram counter (PC) is incremented every Q1, and the
instruction is fetched from the program memory and
latched into the instruction register in Q4. The instruc-
tion is decoded and executed during the following Q1
through Q4. The clocks and instruction execution flow
are shown in Figure 3-3.
3.2 Instruction Flow/Pipelining
An “Instruction Cycle” consists of four Q cycles (Q1,
Q2, Q3, and Q4). The instruction fetch and execute are
pipelined such that fetch takes one instruction cycle
while decode and execute takes another instruction
cycle. However, due to the pipelining, each instruction
effectively executes in one cycle. If an instruction
causes the program counter to change (e.g.GOTO) then
two cycles are required to complete the instruction
(Example 3-2).
A fetch cycle begins with the program counter incre-
menting in Q1.
In the execution cycle, the fetched instruction is latched
into the “Instruction Register (IR)” in cycle Q1. This
instruction is then decoded and executed during the
Q2, Q3, and Q4 cycles. Data memory is read during Q2
(operand read) and written during Q4 (destination
write).
FIGURE 3-3: CLOCK/INSTRUCTION CYCLE
Q1 Q2 Q3 Q4
OSC1
Q1
Q2
Q3
Q4
PC
PC
OSC2/CLKOUT
(RC mode)
Fetch INST (PC)
Execute INST (PC-1)
Q1 Q2 Q3 Q4
PC+1
Fetch INST (PC+1)
Execute INST (PC)
Q1 Q2 Q3 Q4
PC+2
Fetch INST (PC+2)
Execute INST (PC+1)
Internal
phase
clock
EXAMPLE 3-2: INSTRUCTION PIPELINE FLOW
Tcy0
Tcy1
1. MOVLW 55h
Fetch 1 Execute 1
2. MOVWF PORTB
Fetch 2
3. CALL SUB_1
4. BSF PORTA, BIT3 (Forced NOP)
5. Instruction @ address SUB_1
Tcy2
Execute 2
Fetch 3
Tcy3
Tcy4
Tcy5
Execute 3
Fetch 4
Flush
Fetch SUB_1 Execute SUB_1
All instructions are single cycle, except for any 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.
DS30412C-page 14
© 1996 Microchip Technology Inc.