PIC16F72-I/SOG Microchip Technology, PIC16F72-I/SOG Datasheet - Page 21

IC PIC MCU FLASH 2KX14 28-SOIC

PIC16F72-I/SOG

Manufacturer Part Number
PIC16F72-I/SOG
Description
IC PIC MCU FLASH 2KX14 28-SOIC
Manufacturer
Microchip Technology
Series
PIC® 16Fr

Specifications of PIC16F72-I/SOG

Core Processor
PIC
Core Size
8-Bit
Speed
20MHz
Connectivity
I²C, SPI
Peripherals
Brown-out Detect/Reset, POR, PWM, WDT
Number Of I /o
22
Program Memory Size
3.5KB (2K x 14)
Program Memory Type
FLASH
Ram Size
128 x 8
Voltage - Supply (vcc/vdd)
4 V ~ 5.5 V
Data Converters
A/D 5x8b
Oscillator Type
External
Operating Temperature
-40°C ~ 85°C
Package / Case
28-SOIC (7.5mm Width)
Lead Free Status / RoHS Status
Lead free / RoHS Compliant
Eeprom Size
-
2.3.1
A computed GOTO is accomplished by adding an offset
to the program counter (ADDWF PCL). When doing a
table read using a computed GOTO method, care
should be exercised if the table location crosses a PCL
memory boundary (each 256-byte block). Refer to the
Application Note, “Implementing a Table Read"
(AN556).
2.3.2
The stack allows a combination of up to eight program
calls and interrupts to occur. The stack contains the
return address from this branch in program execution.
Mid-range devices have an 8-level deep x 13-bit wide
hardware stack. The stack space is not part of either
program or data space and the stack pointer is not
readable or writable. The PC is PUSH’d onto the stack
when a CALL instruction is executed, or an interrupt
causes a branch. The stack is POP’d in the event of a
RETURN, RETLW or a RETFIE instruction execution.
PCLATH is not modified when the stack is PUSH’d or
POP’d.
After the stack has been PUSH’d eight times, the ninth
push overwrites the value that was stored from the first
push. The tenth push overwrites the second push (and
so on). An example of the overwriting of the stack is
shown in Figure 2-4.
FIGURE 2-4:
© 2007 Microchip Technology Inc.
Note 1: There are no status bits to indicate stack
Push1 Push9
Push2 Push10
Push3
Push4
Push5
Push6
Push7
Push8
2: There are no instructions/mnemonics
COMPUTED GOTO
STACK
overflow or stack underflow conditions.
called PUSH or POP. These are actions
that occur from the execution of the
CALL, RETURN, RETLW and RETFIE
instructions, or the vectoring to an
interrupt address.
Stack
STACK MODIFICATION
Top-of-Stack
2.4
The CALL and GOTO instructions provide 11 bits of
address to allow branching within any 2K program
memory page. When doing a CALL or GOTO instruction,
the upper two bits of the address are provided by
PCLATH<4:3>. When doing a CALL or GOTO instruc-
tion, the user must ensure that the page select bits are
programmed so that the desired program memory
page is addressed. If a return from a CALL instruction
(or interrupt) is executed, the entire 13-bit PC is pushed
onto the stack. Therefore, manipulation of the
PCLATH<4:3> bits is not required for the return
instructions (which POPs the address from the stack).
2.5
The INDF register is not a physical register. Address-
ing INDF actually addresses the register whose
address is contained in the FSR register (FSR is a
pointer). This is indirect addressing.
A simple program to clear RAM locations 20h-2Fh
using indirect addressing is shown in Example 2-1.
EXAMPLE 2-1:
the 8-bit FSR register and the IRP bit (STATUS<7>), as
shown in Figure 2-5.
An effective 9-bit address is obtained by concatenating
NEXT
CONTINUE
Note:
Program Memory Paging
Indirect Addressing, INDF and
FSR Registers
The PIC16F72 device ignores the paging
bit
PCLATH<4:3> as a general purpose read/
write bit is not recommended, since this
may affect upward compatibility with future
products.
movlw
movwf
clrf
incf
btfss
goto
:
PCLATH<4:3>.
0x20
FSR
INDF
FSR
FSR,4 ;all done?
NEXT
INDIRECT ADDRESSING
;initialize pointer
;to RAM
;clear INDF register
;inc pointer
;NO, clear next
;YES, continue
PIC16F72
DS39597C-page 19
The
use
of

Related parts for PIC16F72-I/SOG