All trademarks mentioned in this document
are trademarks of their respective owners.
Copyright 1999-2007 DCD – Digital Core Design. All Rights Reserved.
http://www.DigitalCoreDesign.com
http://www.dcd.pl
BLOCK DIAGRAM
ALU – Arithmetic Logic Unit performs arithme-
tic and logic operations during execution of an
instruction. This module contains work register
(W) and Status register.
Control Unit – It performs the core synchroni-
zation and data flow control. This module
manages execution of all instructions. Per-
forms decode and control functions for all
other blocks. It contains program counter (PC)
and hardware stack.
Hardware Stack – The DFPIC1655X config-
urable hardware stack. The stack space is not
a part of either program or data space and the
stack pointer is not readable or writable. The
PC is pushed onto the stack when CALL in-
struction is executed or an interrupt causes a
branch. The stack is popped while RETURN,
RETFIE and RETLW instruction execution.
The stack operates as a circular buffer. This
means that after the stack has been pushed
eight times, the ninth push overwrites the
value that was stored from the first push.
portao
trisb
trisa
portbo
ramdatai
clk
por
ramdatao
RAM
Controller
I/O
Ports
Hardware
Stack
Control
Unit
Interrupt
Controller
intr
sleep
ramwe
ramaddr
mclr
portai
portbi
Timer 0
t0cki
LU
prgdata
prgaddr
Watchdog
Timer
clkwdt
ramoe
docddatai
docddatao
DoCD
Debugger
prgwe
docdclk
prgdatao
RAM Controller – It performs interface func-
tions between Data Memory and DFPIC1655X
internal logic. It assures correct Data memory
addressing and data transfers. The
DFPIC1655X supports two addressing modes:
direct or indirect. In Direct Addressing the 9-bit
direct address is computed from RP(1:0) bits
(STATUS) and 7 least significant bits of in-
struction word. Indirect addressing is possible
by using the INDF register. Any instruction
using INDF register actually accesses data
pointed to by the file select register FSR.
Reading INDF register indirectly will produce
00h. Writing to the INDF register indirectly
results in a no-operation. An effective 9-bit
address is obtained by concatenating the IRP
bit (STATUS) and the 8-bit FSR register.
Interrupt Controller – Interrupt Controller
module is responsible for interrupt manage
system for the external and internal interrupt
sources. It contains interrupt related register
called INTCON The DFPIC1655X has three
interrupt sources:
♦
♦
♦
External interrupt INT
TMR0 overflow interrupt
PORTB change interrupt (pins B7:B4)
The interrupt control register INTCON records
individual interrupt requests in flag bits.
A global interrupt enable bit, GIE enables all
unmasked interrupts. Each interrupt source
has an individual enable bit, which can enable
or disable corresponding interrupt.
When an interrupt is responded to, the GIE is
cleared to disable any further interrupt, the
return address is pushed into the stack and
the PC is loaded with 0004h. The interrupt flag
bits must be cleared in software before re-
enabling interrupts.
Timer 0 – Main system’s timer and prescaler.
The DFPIC1655X Timer operates in two
modes: 8-bit timer or 8-bit counter. In the
“timer mode”, timer registers are incremented
every 2 CLK periods. When the prescaler is
assigned into the TIMER prescale ration can
be divided by 2, 4 .. 256. In the “counter
mode” the timer register is incremented every
falling or rising edge of T0CKI pin, dependent
on T0SE bit in OPTION register.
Watchdog Timer– it’s a free running timer.
WDT has own clock input separate from sys-
tem clock. It means that the WDT will run
even if the system clock is stopped by execu-
tion of SLEEP instruction. During normal op-
eration, a WDT time-out generates a Watch-
dog reset. If the device is in SLEEP mode the
WDT time-out causes the device to wake-up
and continue with normal operation.