Академический Документы
Профессиональный Документы
Культура Документы
PDIP, SOIC, Windowed CERDIP SDIP, SOIC, SSOP, Windowed CERDIP (300 mil)
RA2 1 18 RA1 MCLR/VPP 1 28 RB7
RA3 2 17 RA0 RA0 2 27 RB6
RA1 3 26 RB5
RA4/T0CKI 3 16 OSC1/CLKIN
RA2 4 25 RB4
MCLR/VPP 4 15 OSC2/CLKOUT RA3 RB3
5 24
VSS 5 14 VDD RA4/T0CKI 6 23 RB2
RB0/INT 6 13 RB7 RA5/SS 7 22 RB1
VSS 8 21 RB0/INT
RB1 7 12 RB6
OSC1/CLKIN 9 20 VDD
RB2 8 11 RB5
OSC2/CLKOUT 10 19 VSS
RB3 9 10 RB4 RC0/T1OSI/T1CKI 11 18 RC7
RC1/T1OSO 12 17 RC6
RC2/CCP1 13 16 RC5/SDO
PIC16C61 RC3/SCK/SCL 14 15 RC4/SDI/SDA
PIC16C62
SDIP, SOIC, SSOP, Windowed CERDIP (300 mil) SDIP, SOIC, Windowed CERDIP (300 mil)
MCLR/VPP 1 28 RB7 MCLR/VPP 1 28 RB7
RA0 2 27 RB6 RA0 2 27 RB6
RA1 3 26 RB5 RA1 3 26 RB5
RA2 4 25 RB4 RA2 4 25 RB4
RA3 5 24 RB3 RA3 5 24 RB3
RA4/T0CKI 6 23 RB2 RA4/T0CKI 6 23 RB2
RA5/SS 7 22 RB1 RA5/SS 7 22 RB1
VSS 8 21 RB0/INT VSS 8 21 RB0/INT
OSC1/CLKIN 9 20 VDD OSC1/CLKIN 9 20 VDD
OSC2/CLKOUT 10 19 VSS OSC2/CLKOUT 10 19 VSS
RC0/T1OSO/T1CKI 11 18 RC7 RC0/T1OSO/T1CKI 11 18 RC7/RX/DT
RC1/T1OSI 12 17 RC6 RC1/T1OSI/CCP2 12 17 RC6/TX/CK
RC2/CCP1 13 16 RC5/SDO RC2/CCP1 13 16 RC5/SDO
RC3/SCK/SCL 14 15 RC4/SDI/SDA RC3/SCK/SCL 14 15 RC4/SDI/SDA
PIC16C62A PIC16C63
PIC16CR62 PIC16CR63
PIC16C66
RC3/SCK/SCL
MCLR/VPP
RC4/SDI/SDA
MQFP PLCC
RC1/T1OSO
RC2/CCP1
RD3/PSP3
RD2/PSP2
RD1/PSP1
RD0/PSP0
RC5/SDO
RA3
RA2
RA1
RA0
RB7
RB6
RB5
RB4
NC
NC
RC6
NC
44
43
42
41
40
6
5
4
3
2
1
44
43
42
41
40
39
38
37
36
35
34
RA4/T0CKI 7 39 RB3
RC7 1 33 NC RA5/SS 8 38 RB2
RD4/PSP4 2 32 RC0/T1OSI/T1CKI RE0/RD 9 37 RB1
RD5/PSP5 3 31 OSC2/CLKOUT RE1/WR 10 36 RB0/INT
RD6/PSP6 4 30 OSC1/CLKIN RE2/CS 11 35 VDD
RD7/PSP7 5 29
VSS 6 PIC16C64 28
VSS
VDD
VDD
VSS
12
13
PIC16C64 34
33
VSS
RD7/PSP7
VDD 7 27 RE2/CS OSC1/CLKIN 14 32 RD6/PSP6
RB0/INT 8 26 RE1/WR OSC2/CLKOUT RD5/PSP5
15 31
RB1 9 25 RE0/RD RC0/T1OSI/T1CKI 16 30 RD4/PSP4
RB2 10 24 RA5/SS RC7
NC 17 29
RB3 11 23 RA4/T0CKI
12
13
14
15
16
17
18
19
20
21
22
18
19
20
21
22
23
24
25
26
27
28
RC1/T1OSO
RC2/CCP1
RC3/SCK/SCL
RD0/PSP0
RD1/PSP1
RD2/PSP2
RD3/PSP3
RC4/SDI/SDA
RC5/SDO
RC6
NC
RB4
RB5
RB6
RB7
MCLR/VPP
RA0
RA1
RA2
RA3
NC
NC
MQFP,
TQFP (PIC16C64A only) PLCC
MCLR/VPP
RC3/SCK/SCL
RC4/SDI/SDA
RC1/T1OSI
RC2/CCP1
RD3/PSP3
RD2/PSP2
RD1/PSP1
RD0/PSP0
RA3
RA2
RA1
RA0
RB7
RB6
RB5
RB4
RC5/SDO
NC
NC
RC6
NC
44
43
42
41
40
6
5
4
3
2
1
RA4/T0CKI 7 39 RB3
RA5/SS RB2
44
43
42
41
40
39
38
37
36
35
34
8 38
RC7 1 33 NC RE0/RD 9 37 RB1
RD4/PSP4 2 32 RC0/T1OSO/T1CKI RE1/WR 10 36 RB0/INT
RD5/PSP5 3 31 OSC2/CLKOUT RE2/CS 11 35 VDD
RD6/PSP6
RD7/PSP7
4
5
30
29
OSC1/CLKIN
VSS
VDD 12 PIC16C64A 34 VSS
VSS 13 33 RD7/PSP7
VSS 6
7
PIC16C64A 28
27
VDD OSC1/CLKIN 14 PIC16CR64 32 RD6/PSP6
VDD RE2/CS OSC2/CLKOUT 15 31 RD5/PSP5
RB0/INT 8 PIC16CR64 26 RE1/WR
RC0/T1OSO/T1CKI 16 30 RD4/PSP4
RB1 9 25 RE0/RD NC 17 29 RC7
RB2 10 24 RA5/SS
18
19
20
21
22
23
24
25
26
27
28
RB3 11 23 RA4/T0CKI
12
13
14
15
16
17
18
19
20
21
22
RC1/T1OSI
RC2/CCP1
RC3/SCK/SCL
RD0/PSP0
RD1/PSP1
RD2/PSP2
RD3/PSP3
RC4/SDI/SDA
RC5/SDO
RC6
NC
NC
NC
RB4
RB5
RB6
RB7
MCLR/VPP
RA0
RA1
RA2
RA3
MQFP,
TQFP (Not on PIC16C65)
PLCC
RC1/T1OSI/CCP2
MCLR/VPP
RC3/SCK/SCL
RC4/SDI/SDA
RC6/TX/CK
RC2/CCP1
RD3/PSP3
RD2/PSP2
RD1/PSP1
RD0/PSP0
RA3
RA2
RA1
RA0
RB7
RB6
RB5
RB4
RC5/SDO
NC
NC
NC
44
43
42
41
40
6
5
4
3
2
1
RA4/T0CKI 7 39 RB3
44
43
42
41
40
39
38
37
36
35
34
RA5/SS 8 38 RB2
RC7/RX/DT 1 33 NC RE0/RD 9 37 RB1
RD4/PSP4 2 32 RC0/T1OSO/T1CKI RE1/WR 10 36 RB0/INT
RD5/PSP5 3 31
RD6/PSP6 4 PIC16C65 30
OSC2/CLKOUT
OSC1/CLKIN
RE2/CS 11 PIC16C65 35 VDD
VDD 12 34 VSS
RD7/PSP7 5
PIC16C65A
29 VSS VSS 13 PIC16C65A 33 RD7/PSP7
VSS 6 28 VDD OSC1/CLKIN 14 32 RD6/PSP6
VDD 7
PIC16CR65 27 RE2/CS OSC2/CLKOUT 15
PIC16CR65 31 RD5/PSP5
RB0/INT 8 26 RE1/WR
RB1 9 PIC16C67 25 RE0/RD
RC0/T1OSO/T1CKI
NC
16
17
PIC16C67 30
29
RD4/PSP4
RC7/RX/DT
RB2 10 24 RA5/SS
18
19
20
21
22
23
24
25
26
27
28
RB3 11 23 RA4/T0CKI
12
13
14
15
16
17
18
19
20
21
22
RC1/T1OSI /CCP2
RC2/CCP1
RC3/SCK/SCL
RD0/PSP0
RD1/PSP1
RD2/PSP2
RD3/PSP3
RC4/SDI/SDA
RC5/SDO
RC6/TX/CK
NC
NC
NC
RB4
RB5
RB6
RB7
MCLR/VPP
RA0
RA1
RA2
RA3
For register and module descriptions in this data sheet, device legends show which devices apply to those sections. For
example, the legend below shows that some features of only the PIC16C62A, PIC16CR62, PIC16C63, PIC16C64A,
PIC16CR64, and PIC16C65A are described in this section.
Applicable Devices
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67
Serial Port(s) (SPI/I2C, USART) SPI/I2C SPI/I2C SPI/I2C, SPI/I2C, SPI/I2C, SPI/I2C,
USART USART USART USART
Parallel Slave Port Yes Yes Yes Yes — Yes
Interrupt Sources 8 8 11 11 10 11
I/O Pins 33 33 33 33 22 33
Voltage Range (Volts) 2.5-6.0 2.5-6.0 2.5-6.0 2.5-6.0 2.5-6.0 2.5-6.0
In-Circuit Serial Programming Yes Yes Yes Yes Yes Yes
Features Brown-out Reset Yes Yes Yes Yes Yes Yes
Packages 40-pin DIP; 40-pin DIP; 40-pin DIP; 40-pin DIP; 28-pin SDIP, 40-pin DIP;
44-pin PLCC, 44-pin PLCC, 44-pin PLCC, 44-pin SOIC 44-pin
MQFP, TQFP MQFP, TQFP MQFP, TQFP PLCC, PLCC,
MQFP, MQFP,
TQFP TQFP
All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current
capability. All PIC16C6X Family devices use serial programming with clock pin RB6 and data pin RB7.
STATUS reg
8
3
Power-up MUX
Timer
Instruction Oscillator
Decode & Start-up Timer ALU
Control
Power-on
Reset 8
Timing Watchdog
Generation Timer W reg
OSC1/CLKIN
OSC2/CLKOUT
Timer0
MCLR VDD, VSS
STATUS reg
8 PORTC
RC0/T1OSO/T1CKI(4)
3 RC1/T1OSI(4)
Power-up MUX RC2/CCP1
Timer RC3/SCK/SCL
Instruction Oscillator RC4/SDI/SDA
Decode & Start-up Timer RC5/SDO
ALU
Control RC6
Power-on
Reset 8 RC7
Timing Watchdog
Generation Timer W reg
OSC1/CLKIN Brown-out PORTD
OSC2/CLKOUT Reset(3) RD0/PSP0
RD1/PSP1
RD2/PSP2
RD3/PSP3
RD4/PSP4
RD5/PSP5
MCLR VDD, VSS RD6/PSP6
RD7/PSP7
Parallel Slave PORTE
Port
RE0/RD
RE1/WR
Timer1 Timer2 CCP1
RE2/CS
(Note 2)
Synchronous
Timer0 Serial Port
STATUS reg
8 PORTC
RC0/T1OSO/T1CKI
3 RC1/T1OSI/CCP2
Power-up MUX RC2/CCP1
Timer RC3/SCK/SCL
Instruction Oscillator RC4/SDI/SDA
Decode & Start-up Timer RC5/SDO
ALU
Control RC6/TX/CK
Power-on
Reset 8 RC7/RX/DT
Timing Watchdog
Generation Timer W reg
OSC1/CLKIN PORTD
Brown-out RD0/PSP0
OSC2/CLKOUT Reset(3) RD1/PSP1
RD2/PSP2
RD3/PSP3
RD4/PSP4
RD5/PSP5
MCLR VDD, VSS RD6/PSP6
RD7/PSP7
Parallel Slave
Port PORTE
RE0/RD
RE1/WR
Timer0 Timer1 Timer2
RE2/CS
(Note 2)
Synchronous
USART Serial Port CCP1 CCP2
STATUS reg
8 PORTC
RC0/T1OSO/T1CKI
3 RC1/T1OSI/CCP2
Power-up MUX RC2/CCP1
Timer RC3/SCK/SCL
Instruction Oscillator RC4/SDI/SDA
Decode & Start-up Timer RC5/SDO
ALU
Control RC6/TX/CK
Power-on
Reset 8 RC7/RX/DT
Timing Watchdog
Generation Timer W reg
OSC1/CLKIN PORTD
Brown-out RD0/PSP0
OSC2/CLKOUT Reset RD1/PSP1
RD2/PSP2
RD3/PSP3
RD4/PSP4
RD5/PSP5
MCLR VDD, VSS RD6/PSP6
RD7/PSP7
Parallel Slave
Port PORTE
RE0/RD
RE1/WR
Timer0 Timer1 Timer2
RE2/CS
(Note 2)
Synchronous
USART Serial Port CCP1 CCP2
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
OSC1
Q1
Q2 Internal
Phase
Q3 Clock
Q4
PC PC PC+1 PC+2
(Program counter)
OSC2/CLKOUT
(RC mode)
Fetch INST (PC)
Execute INST (PC-1) Fetch INST (PC+1)
Execute INST (PC) Fetch INST (PC+2)
Execute INST (PC+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.
User Memory
Peripheral Interrupt Vector 0004h
PIC16C61 1K x 14 0000h-03FFh 0005h
Space
PIC16C62 2K x 14 0000h-07FFh On-chip Program
PIC16C62A 2K x 14 0000h-07FFh Memory
PIC16CR62 2K x 14 0000h-07FFh
07FFh
PIC16C63 4K x 14 0000h-0FFFh 0800h
PIC16CR63 4K x 14 0000h-0FFFh
PIC16C64 2K x 14 0000h-07FFh
PIC16C64A 2K x 14 0000h-07FFh
PIC16CR64 2K x 14 0000h-07FFh 1FFFh
PIC16C65 4K x 14 0000h-0FFFh
PIC16C65A 4K x 14 0000h-0FFFh FIGURE 4-3: PIC16C63/R63/65/65A/R65
PIC16CR65 4K x 14 0000h-0FFFh PROGRAM MEMORY MAP
PIC16C66 8K x 14 0000h-1FFFh AND STACK
PIC16C67 8K x 14 0000h-1FFFh
PC<12:0>
For those devices with less than 8K program memory, CALL, RETURN 13
accessing a location above the physically implemented RETFIE, RETLW
address will cause a wraparound. Stack Level 1
•
•
The reset vector is at 0000h and the interrupt vector is •
at 0004h. Stack Level 8
•
•
• 07FFh
Stack Level 8 0800h
On-chip Program
0FFFh
Memory 1000h
03FFh
0400h
1FFFh
1FFFh
0800h
07h 87h
On-chip Program
Memory (Page 1) 08h 88h
0FFFh
1000h 09h 89h
On-chip Program PCLATH PCLATH 8Ah
0Ah
Memory (Page 2) INTCON INTCON
0Bh 8Bh
17FFh
0Ch 8Ch
1800h
On-chip Program
General Mapped
Memory (Page 3) Purpose in Bank 0(2)
Register
1FFFh
2Fh AFh
4.2 Data Memory Organization B0h
30h
Applicable Devices
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67
The data memory is partitioned into multiple banks
which contain the General Purpose Registers and the
Special Function Registers. Bits RP1 and RP0 are the
bank select bits.
RP1:RP0 (STATUS<6:5>)
= 00 → Bank0
= 01 → Bank1
= 10 → Bank2
7Fh FFh
= 11 → Bank3
Each bank extends up to 7Fh (128 bytes). The lower Bank 0 Bank 1
locations of each bank are reserved for the Special Unimplemented data memory location; read as '0'.
Function Registers. Above the Special Function Regis- Note 1: Not a physical register.
ters are General Purpose Registers, implemented as 2: These locations are unimplemented in
static RAM. All implemented banks contain special Bank 1. Any access to these locations will
function registers. Some “high use” special function access the corresponding Bank 0 register.
registers from one bank may be mirrored in another
bank for code reduction and quicker access.
Indirect addr.(*) 00h Indirect addr.(*) 80h Indirect addr.(*) 100h Indirect addr.(*) 180h
TMR0 01h OPTION 81h TMR0 101h OPTION 181h
PCL 02h PCL 82h PCL 102h PCL 182h
STATUS 03h STATUS 83h STATUS 103h STATUS 183h
FSR 04h FSR 84h FSR 104h FSR 184h
PORTA 05h TRISA 85h 105h 185h
PORTB 06h TRISB 86h PORTB 106h TRISB 186h
PORTC 07h TRISC 87h 107h 187h
PORTD (1) 08h TRISD (1) 88h 108h 188h
PORTE (1) 09h TRISE (1) 89h 109h 189h
PCLATH 0Ah PCLATH 8Ah PCLATH 10Ah PCLATH 18Ah
INTCON 0Bh INTCON 8Bh INTCON 10Bh INTCON 18Bh
PIR1 0Ch PIE1 8Ch 10Ch 18Ch
PIR2 0Dh PIE2 8Dh 10Dh 18Dh
TMR1L 0Eh PCON 8Eh 10Eh 18Eh
TMR1H 0Fh 8Fh 10Fh 18Fh
T1CON 10h 90h 110h 190h
TMR2 11h 91h 111h 191h
T2CON 12h PR2 92h 112h 192h
SSPBUF 13h SSPADD 93h 113h 193h
SSPCON 14h SSPSTAT 94h 114h 194h
CCPR1L 15h 95h 115h 195h
CCPR1H 16h 96h 116h 196h
CCP1CON 17h 97h General 117h General 197h
Purpose Purpose
RCSTA 18h TXSTA 98h Register 118h Register 198h
TXREG 19h SPBRG 99h 16 Bytes 119h 16 Bytes 199h
RCREG 1Ah 9Ah 11Ah 19Ah
CCPR2L 1Bh 9Bh 11Bh 19Bh
CCPR2H 1Ch 9Ch 11Ch 19Ch
CCP2CON 1Dh 9Dh 11Dh 19Dh
1Eh 9Eh 11Eh 19Eh
1Fh 9Fh 11Fh 19Fh
20h A0h 120h 1A0h
Note: The upper 16 bytes of data memory in banks 1, 2, and 3 are mapped in Bank 0. This may require
relocation of data memory usage in the user application code if upgrading to the PIC16C66/67.
Bank 0
00h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
02h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
04h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
05h PORTA — — — PORTA Data Latch when written: PORTA pins when read ---x xxxx ---u uuuu
06h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
07h — Unimplemented — —
08h — Unimplemented — —
09h — Unimplemented — —
0Ah(1,2) PCLATH — — — Write Buffer for the upper 5 bits of the Program Counter ---0 0000 ---0 0000
0Bh(1) INTCON GIE — T0IE INTE RBIE T0IF INTF RBIF 0-00 000x 0-00 000u
Bank 1
80h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
81h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
82h
(1) STATUS IRP(4) (4) RP0 TO PD Z DC C 0001 1xxx 000q quuu
83h RP1
(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
84h
85h TRISA — — — PORTA Data Direction Register ---1 1111 ---1 1111
86h TRISB PORTB Data Direction Control Register 1111 1111 1111 1111
87h – Unimplemented — —
88h – Unimplemented — —
89h – Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
8Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE — T0IE INTE RBIE T0IF INTF RBIF 0-00 000x 0-00 000u
8Bh
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented locations read as '0'.
Shaded locations are unimplemented and read as ‘0’
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose con-
tents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer Reset.
4: The IRP and RP1 bits are reserved on the PIC16C61, always maintain these bits clear.
Bank 0
00h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
04h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
05h PORTA — — PORTA Data Latch when written: PORTA pins when read --xx xxxx --uu uuuu
06h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
07h PORTC PORTC Data Latch when written: PORTC pins when read xxxx xxxx uuuu uuuu
08h — Unimplemented — —
09h — Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
0Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
0Bh
0Ch PIR1 (6) (6) — — SSPIF CCP1IF TMR2IF TMR1IF 00-- 0000 00-- 0000
0Dh — Unimplemented — —
0Eh TMR1L Holding register for the Least Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
0Fh TMR1H Holding register for the Most Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
10h T1CON — — T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON --00 0000 --uu uuuu
12h T2CON — TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 -000 0000 -000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
17h CCP1CON — — CCP1X CCP1Y CCP1M3 CCP1M2 CCP1M1 CCP1M0 --00 0000 --00 0000
18h-1Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The BOR bit is reserved on the PIC16C62, always maintain this bit set.
5: The IRP and RP1 bits are reserved on the PIC16C62/62A/R62, always maintain these bits clear.
6: PIE1<7:6> and PIR1<7:6> are reserved on the PIC16C62/62A/R62, always maintain these bits clear.
Bank 1
80h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
81h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
82h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
84h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
85h TRISA — — PORTA Data Direction Register --11 1111 --11 1111
86h TRISB PORTB Data Direction Register 1111 1111 1111 1111
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
88h — Unimplemented — —
89h — Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
8Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
8Bh
8Ch PIE1 (6) (6) — — SSPIE CCP1IE TMR2IE TMR1IE 00-- 0000 00-- 0000
8Dh — Unimplemented — —
8Fh — Unimplemented — —
90h — Unimplemented — —
91h — Unimplemented — —
95h-9Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The BOR bit is reserved on the PIC16C62, always maintain this bit set.
5: The IRP and RP1 bits are reserved on the PIC16C62/62A/R62, always maintain these bits clear.
6: PIE1<7:6> and PIR1<7:6> are reserved on the PIC16C62/62A/R62, always maintain these bits clear.
Bank 0
00h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
04h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
05h PORTA — — PORTA Data Latch when written: PORTA pins when read --xx xxxx --uu uuuu
06h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
07h PORTC PORTC Data Latch when written: PORTC pins when read xxxx xxxx uuuu uuuu
08h — Unimplemented — —
09h — Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
0Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
0Bh
0Ch PIR1 (5) (5) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
0Eh TMR1L Holding register for the Least Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
0Fh TMR1H Holding register for the Most Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
10h T1CON — — T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON --00 0000 --uu uuuu
12h T2CON — TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 -000 0000 -000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
17h CCP1CON — — CCP1X CCP1Y CCP1M3 CCP1M2 CCP1M1 CCP1M0 --00 0000 --00 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
19h TXREG USART Transmit Data Register 0000 0000 0000 0000
1Ah RCREG USART Receive Data Register 0000 0000 0000 0000
1Dh CCP2CON — — CCP2X CCP2Y CCP2M3 CCP2M2 CCP2M1 CCP2M0 --00 0000 --00 0000
1Eh-1Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The IRP and RP1 bits are reserved on the PIC16C63/R63, always maintain these bits clear.
5: PIE1<7:6> and PIR1<7:6> are reserved on the PIC16C63/R63, always maintain these bits clear.
Bank 1
80h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
81h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
82h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
84h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
85h TRISA — — PORTA Data Direction Register --11 1111 --11 1111
86h TRISB PORTB Data Direction Register 1111 1111 1111 1111
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
88h — Unimplemented — —
89h — Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
8Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
8Bh
8Ch PIE1 (5) (5) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
8Fh — Unimplemented — —
90h — Unimplemented — —
91h — Unimplemented — —
93h SSPADD Synchronous Serial Port (I2C mode) Address Register 0000 0000 0000 0000
95h — Unimplemented — —
96h — Unimplemented — —
97h — Unimplemented — —
(2) TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
98h
(2) SPBRG Baud Rate Generator Register 0000 0000 0000 0000
99h
9Ah — Unimplemented — —
9Bh — Unimplemented — —
9Ch — Unimplemented — —
9Dh — Unimplemented — —
9Eh — Unimplemented — —
9Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The IRP and RP1 bits are reserved on the PIC16C63/R63, always maintain these bits clear.
5: PIE1<7:6> and PIR1<7:6> are reserved on the PIC16C63/R63, always maintain these bits clear.
Bank 0
00h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
04h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
05h PORTA — — PORTA Data Latch when written: PORTA pins when read --xx xxxx --uu uuuu
06h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
07h PORTC PORTC Data Latch when written: PORTC pins when read xxxx xxxx uuuu uuuu
08h PORTD PORTD Data Latch when written: PORTD pins when read xxxx xxxx uuuu uuuu
0Ch PIR1 PSPIF (6) — — SSPIF CCP1IF TMR2IF TMR1IF 00-- 0000 00-- 0000
0Dh — Unimplemented — —
0Eh TMR1L Holding register for the Least Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
0Fh TMR1H Holding register for the Most Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
10h T1CON — — T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON --00 0000 --uu uuuu
12h T2CON — TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 -000 0000 -000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
17h CCP1CON — — CCP1X CCP1Y CCP1M3 CCP1M2 CCP1M1 CCP1M0 --00 0000 --00 0000
18h-1Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The BOR bit is reserved on the PIC16C64, always maintain this bit set.
5: The IRP and RP1 bits are reserved on the PIC16C64/64A/R64, always maintain these bits clear.
6: PIE1<6> and PIR1<6> are reserved on the PIC16C64/64A/R64, always maintain these bits clear.
Bank 1
80h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
81h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
82h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
84h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
85h TRISA — — PORTA Data Direction Register --11 1111 --11 1111
86h TRISB PORTB Data Direction Register 1111 1111 1111 1111
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
88h TRISD PORTD Data Direction Register 1111 1111 1111 1111
89h TRISE IBF OBF IBOV PSPMODE — PORTE Data Direction Bits 0000 -111 0000 -111
(1,2) PCLATH — — — ---0 0000 ---0 0000
8Ah Write Buffer for the upper 5 bits of the Program Counter
8Bh(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
8Ch PIE1 PSPIE (6) — — SSPIE CCP1IE TMR2IE TMR1IE 00-- 0000 00-- 0000
8Dh — Unimplemented — —
8Fh — Unimplemented — —
90h — Unimplemented — —
91h — Unimplemented — —
93h SSPADD Synchronous Serial Port (I2C mode) Address Register 0000 0000 0000 0000
95h-9Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The BOR bit is reserved on the PIC16C64, always maintain this bit set.
5: The IRP and RP1 bits are reserved on the PIC16C64/64A/R64, always maintain these bits clear.
6: PIE1<6> and PIR1<6> are reserved on the PIC16C64/64A/R64, always maintain these bits clear.
Bank 0
00h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
06h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
07h PORTC PORTC Data Latch when written: PORTC pins when read xxxx xxxx uuuu uuuu
08h PORTD PORTD Data Latch when written: PORTD pins when read xxxx xxxx uuuu uuuu
0Ah(1,2) PCLATH — — — Write Buffer for the upper 5 bits of the Program Counter ---0 0000 ---0 0000
0Bh(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
0Ch PIR1 PSPIF (6) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
0Eh TMR1L Holding register for the Least Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
0Fh TMR1H Holding register for the Most Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
10h T1CON — — T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON --00 0000 --uu uuuu
12h T2CON — TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 -000 0000 -000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
17h CCP1CON — — CCP1X CCP1Y CCP1M3 CCP1M2 CCP1M1 CCP1M0 --00 0000 --00 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
19h TXREG USART Transmit Data Register 0000 0000 0000 0000
1Ah RCREG USART Receive Data Register 0000 0000 0000 0000
1Dh CCP2CON — — CCP2X CCP2Y CCP2M3 CCP2M2 CCP2M1 CCP2M0 --00 0000 --00 0000
1Eh-1Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The BOR bit is reserved on the PIC16C65, always maintain this bit set.
5: The IRP and RP1 bits are reserved on the PIC16C65/65A/R65, always maintain these bits clear.
6: PIE1<6> and PIR1<6> are reserved on the PIC16C65/65A/R65, always maintain these bits clear.
Bank 1
80h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
81h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
82h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
84h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
85h TRISA — — PORTA Data Direction Register --11 1111 --11 1111
86h TRISB PORTB Data Direction Register 1111 1111 1111 1111
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
88h TRISD PORTD Data Direction Register 1111 1111 1111 1111
89h TRISE IBF OBF IBOV PSPMODE — PORTE Data Direction Bits 0000 -111 0000 -111
(1,2) PCLATH — — — ---0 0000 ---0 0000
8Ah Write Buffer for the upper 5 bits of the Program Counter
8Bh(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
8Ch PIE1 PSPIE (6) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
8Fh — Unimplemented — —
90h — Unimplemented — —
91h — Unimplemented — —
93h SSPADD Synchronous Serial Port (I2C mode) Address Register 0000 0000 0000 0000
95h — Unimplemented — —
96h — Unimplemented — —
97h — Unimplemented — —
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
9Ah — Unimplemented — —
9Bh — Unimplemented — —
9Ch — Unimplemented — —
9Dh — Unimplemented — —
9Eh — Unimplemented — —
9Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from either bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: The BOR bit is reserved on the PIC16C65, always maintain this bit set.
5: The IRP and RP1 bits are reserved on the PIC16C65/65A/R65, always maintain these bits clear.
6: PIE1<6> and PIR1<6> are reserved on the PIC16C65/65A/R65, always maintain these bits clear.
Bank 0
00h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
04h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
05h PORTA — — PORTA Data Latch when written: PORTA pins when read --xx xxxx --uu uuuu
06h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
07h PORTC PORTC Data Latch when written: PORTC pins when read xxxx xxxx uuuu uuuu
(5) PORTD Data Latch when written: PORTD pins when read xxxx xxxx uuuu uuuu
08h PORTD
(5) — — — — — RE2 RE1 RE0 ---- -xxx ---- -uuu
09h PORTE
(1,2) PCLATH — — — ---0 0000 ---0 0000
0Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
0Bh
0Ch PIR1 (6) (4) SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
PSPIF RCIF TXIF
0Eh TMR1L Holding register for the Least Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
0Fh TMR1H Holding register for the Most Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
10h T1CON — — T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON --00 0000 --uu uuuu
12h T2CON — TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 -000 0000 -000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
17h CCP1CON — — CCP1X CCP1Y CCP1M3 CCP1M2 CCP1M1 CCP1M0 --00 0000 --00 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
19h TXREG USART Transmit Data Register 0000 0000 0000 0000
1Ah RCREG USART Receive Data Register 0000 0000 0000 0000
1Dh CCP2CON — — CCP2X CCP2Y CCP2M3 CCP2M2 CCP2M1 CCP2M0 --00 0000 --00 0000
1Eh-1Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from any bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: PIE1<6> and PIR1<6> are reserved on the PIC16C66/67, always maintain these bits clear.
5: PORTD, PORTE, TRISD, and TRISE are not implemented on the PIC16C66, read as '0'.
6: PSPIF (PIR1<7>) and PSPIE (PIE1<7>) are reserved on the PIC16C66, maintain these bits clear.
Bank 1
80h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
81h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
82h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
84h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
85h TRISA — — PORTA Data Direction Register --11 1111 --11 1111
86h TRISB PORTB Data Direction Register 1111 1111 1111 1111
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
(5) PORTD Data Direction Register 1111 1111 1111 1111
88h TRISD
(5) IBF OBF IBOV PSPMODE — PORTE Data Direction Bits 0000 -111 0000 -111
89h TRISE
(1,2) PCLATH — — — ---0 0000 ---0 0000
8Ah Write Buffer for the upper 5 bits of the Program Counter
8Bh(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
8Ch PIE1 PSPIE(6) (4) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
8Fh — Unimplemented — —
90h — Unimplemented — —
91h — Unimplemented — —
93h SSPADD Synchronous Serial Port (I2C mode) Address Register 0000 0000 0000 0000
94h SSPSTAT SMP CKE D/A P S R/W UA BF 0000 0000 0000 0000
95h — Unimplemented — —
96h — Unimplemented — —
97h — Unimplemented — —
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
9Ah — Unimplemented — —
9Bh — Unimplemented — —
9Ch — Unimplemented — —
9Dh — Unimplemented — —
9Eh — Unimplemented — —
9Fh — Unimplemented — —
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from any bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: PIE1<6> and PIR1<6> are reserved on the PIC16C66/67, always maintain these bits clear.
5: PORTD, PORTE, TRISD, and TRISE are not implemented on the PIC16C66, read as '0'.
6: PSPIF (PIR1<7>) and PSPIE (PIE1<7>) are reserved on the PIC16C66, maintain these bits clear.
Bank 2
100h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
102h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
104h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
105h — Unimplemented — —
106h PORTB PORTB Data Latch when written: PORTB pins when read xxxx xxxx uuuu uuuu
107h — Unimplemented — —
108h — Unimplemented — —
109h — Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
10Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
10Bh
10Ch-
— Unimplemented — —
10Fh
Bank 3
180h(1) INDF Addressing this location uses contents of FSR to address data memory (not a physical register) 0000 0000 0000 0000
181h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
182h(1) PCL Program Counter's (PC) Least Significant Byte 0000 0000 0000 0000
184h(1) FSR Indirect data memory address pointer xxxx xxxx uuuu uuuu
185h — Unimplemented — —
186h TRISB PORTB Data Direction Register 1111 1111 1111 1111
187h — Unimplemented — —
188h — Unimplemented — —
189h — Unimplemented — —
(1,2) PCLATH — — — ---0 0000 ---0 0000
18Ah Write Buffer for the upper 5 bits of the Program Counter
(1) INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
18Bh
18Ch-
— Unimplemented — —
19Fh
Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'.
Shaded locations are unimplemented, read as ‘0’.
Note 1: These registers can be addressed from any bank.
2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose
contents are transferred to the upper byte of the program counter. (PC<12:8>)
3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.
4: PIE1<6> and PIR1<6> are reserved on the PIC16C66/67, always maintain these bits clear.
5: PORTD, PORTE, TRISD, and TRISE are not implemented on the PIC16C66, read as '0'.
6: PSPIF (PIR1<7>) and PSPIE (PIE1<7>) are reserved on the PIC16C66, maintain these bits clear.
Note 1: For the PIC16C61/62/64/65, if an interrupt occurs while the GIE bit is being cleared, the GIE bit may unintentionally
be re-enabled by the RETFIE instruction in the user’s Interrupt Service Routine. Refer to Section 13.5 for a detailed
description.
2: The PEIE bit (bit6) is unimplemented on the PIC16C61, read as '0'.
Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the
global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to
enabling an interrupt.
Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the
global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to
enabling an interrupt.
Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the
global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to
enabling an interrupt.
Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the
global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to
enabling an interrupt.
Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the
global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to
enabling an interrupt.
Applicable Devices Note: Interrupt flag bits get set when an interrupt
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 condition occurs regardless of the state of
its corresponding enable bit or the global
This register contains the CCP2 interrupt flag bit.
enable bit, GIE (INTCON<7>). User soft-
ware should ensure the appropriate inter-
rupt flag bits are clear prior to enabling an
interrupt.
Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the
global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to
enabling an interrupt.
4.3.2 STACK
Data
Memory
For memory map detail see Figure 4-5, Figure 4-6, Figure 4-7, and Figure 4-8.
RD TRIS
Q D
EN
EN
RD PORT
05h PORTA — — RA5(1) RA4 RA3 RA2 RA1 RA0 --xx xxxx --uu uuuu
85h TRISA — — PORTA Data Direction Register(1) --11 1111 --11 1111
Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTA.
Note 1: PORTA<5> and TRISA<5> are not implemented on the PIC16C61, read as '0'.
PORTB is an 8-bit wide bi-directional port. The corre- a) Any read or write of PORTB. This will end the
sponding data direction register is TRISB. Setting a bit mismatch condition.
in the TRISB register puts the corresponding output b) Clear flag bit RBIF.
driver in a hi-impedance mode. Clearing a bit in the A mismatch condition will continue to set flag bit RBIF.
TRISB register puts the contents of the output latch on Reading PORTB will end the mismatch condition, and
the selected pin(s). allow flag bit RBIF to be cleared.
This interrupt on mismatch feature, together with soft-
EXAMPLE 5-2: INITIALIZING PORTB
ware configurable pull-ups on these four pins allow
BCF STATUS, RP0 ; easy interface to a keypad and make it possible for
CLRF PORTB ; Initialize PORTB by wake-up on key-depression. Refer to the Embedded
; clearing output Control Handbook, Application Note, “Implementing
; data latches Wake-up on Key Stroke” (AN552).
BSF STATUS, RP0 ; Select Bank 1
MOVLW 0xCF ; Value used to
Note: For PIC16C61/62/64/65, if a change on the
; initialize data
; direction
I/O pin should occur when a read operation
MOVWF TRISB ; Set RB<3:0> as inputs is being executed (start of the Q2 cycle),
; RB<5:4> as outputs then interrupt flag bit RBIF may not get set.
; RB<7:6> as inputs
The interrupt on change feature is recommended for
Each of the PORTB pins has a weak internal pull-up. A wake-up on key depression operation and operations
single control bit can turn on all the pull-ups. This is where PORTB is only used for the interrupt on change
performed by clearing bit RBPU (OPTION<7>). The feature. Polling of PORTB is not recommended while
weak pull-up is automatically turned off when the port using the interrupt on change feature.
pin is configured as an output. The pull-ups are also FIGURE 5-3: BLOCK DIAGRAM OF THE
disabled on a Power-on Reset.
RB7:RB4 PINS FOR
Four of PORTB’s pins, RB7:RB4, have an interrupt on PIC16C61/62/64/65
change feature. Only pins configured as inputs can VDD
cause this interrupt to occur (i.e., any RB7:RB4 pin RBPU(2) weak
configured as an output is excluded from the interrupt P pull-up
on change comparison). The input pins (of RB7:RB4) Data bus
Data Latch
are compared with the old value latched on the last D Q
read of PORTB. The “mismatch” outputs of RB7:RB4 WR Port
I/O
are OR’ed together to generate the RB port change CK pin(1)
interrupt with flag bit RBIF (INTCON<0>). TRIS Latch
D Q
WR TRIS TTL
CK Input
Buffer ST
Buffer
RD TRIS Latch
Q D
RD Port EN
Set RBIF
From other Q D
RB7:RB4 pins
EN
RD Port
RB7:RB6 in serial programming mode
WR TRIS TTL
CK Input
Buffer ST RD TRIS
Buffer
Q D
RD TRIS Latch
RD Port EN
Q D
RD Port EN Q1 RB0/INT
Set RBIF
Schmitt Trigger RD Port
Buffer
From other Q D
RB7:RB4 pins RD Port
EN Note 1: I/O pins have diode protection to VDD and VSS.
Q3 2: To enable weak pull-ups, set the appropriate TRIS bit(s)
RB7:RB6 in serial programming mode and clear the RPBU bit (OPTION<7>).
Note 1: I/O pins have diode protection to VDD and VSS.
2: To enable weak pull-ups, set the appropriate TRIS bit(s)
and clear the RPBU bit (OPTION<7>).
06h, 106h PORTB RB7 RB6 RB5 RB4 RB3 RB2 RB1 RB0 xxxx xxxx uuuu uuuuu
86h, 186h TRISB PORTB Data Direction Register 1111 1111 1111 1111
81h, 181h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
Legend: x = unknown, u = unchanged. Shaded cells are not used by PORTB.
07h PORTC RC7 RC6 RC5 RC4 RC3 RC2 RC1 RC0 xxxx xxxx uuuu uuuu
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
Legend: x = unknown, u = unchanged.
RD TRIS
Q D
EN
EN
RD PORT
08h PORTD RD7 RD6 RD5 RD4 RD3 RD2 RD1 RD0 xxxx xxxx uuuu uuuu
88h TRISD PORTD Data Direction Register 1111 1111 1111 1111
89h TRISE IBF OBF IBOV PSPMODE — PORTE Data Direction Bits 0000 -111 0000 -111
Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTD.
Q D
EN
EN
RD PORT
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Note:
PC PC PC + 1 PC + 2 PC + 3 This example shows a write to PORTB
Instruction followed by a read from PORTB.
fetched MOVWF PORTB MOVF PORTB,W
write to NOP NOP
PORTB Note that:
RB7:RB0 data setup time = (0.25TCY - TPD)
where TCY = instruction cycle
Port pin
sampled here TPD = propagation delay
TPD Therefore, at higher clock frequencies,
Instruction
executed NOP
a write followed by a read may be prob-
MOVWF PORTB MOVF PORTB,W
write to lematic.
PORTB
CS
WR
RD
PORTD<7:0>
IBF
OBF
PSPIF
CS
WR
RD
PORTD<7:0>
IBF
OBF
PSPIF
08h PORTD PSP7 PSP6 PSP5 PSP4 PSP3 PSP2 PSP1 PSP0 xxxx xxxx uuuu uuuu
09h PORTE — — — — — RE2 RE1 RE0 ---- -xxx ---- -uuu
89h TRISE IBF OBF IBOV PSPMODE — PORTE Data Direction Bits 0000 -111 0000 -111
0Ch PIR1 PSPIF (1) RCIF(2) TXIF(2) SSPIF CCP1IF TMR2IF TRM1IF 0000 0000 0000 0000
8Ch PIE1 PSPIE (1) RCIE(2) TXIE(2) SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by the PSP.
Note 1: These bits are reserved, always maintain these bits clear.
2: These bits are implemented on the PIC16C65/65A/R65/67 only.
The Timer0 module has the following features: The prescaler is mutually exclusively shared between
the Timer0 module and the Watchdog Timer. The pres-
• 8-bit timer/counter register, TMR0 caler assignment is controlled in software by control bit
- Read and write capability PSA (OPTION<3>). Clearing bit PSA will assign the
- Interrupt on overflow from FFh to 00h prescaler to the Timer0 module. The prescaler is not
• 8-bit software programmable prescaler readable or writable. When the prescaler is assigned to
• Internal or external clock select the Timer0 module, prescale values of 1:2, 1:4, ...,
1:256 are selectable. Section 7.3 details the operation
- Edge select for external clock
of the prescaler.
Figure 7-1 is a simplified block diagram of the Timer0
module. 7.1 TMR0 Interrupt
Timer mode is selected by clearing bit T0CS Applicable Devices
(OPTION<5>). In timer mode, the Timer0 module will 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67
increment every instruction cycle (without prescaler). If The TMR0 interrupt is generated when the register
TMR0 register is written, the increment is inhibited for (TMR0) overflows from FFh to 00h. This overflow sets
the following two instruction cycles (Figure 7-2 and interrupt flag bit T0IF (INTCON<2>). The interrupt can
Figure 7-3). The user can work around this by writing be masked by clearing enable bit T0IE (INTCON<5>).
an adjusted value to the TMR0 register. Flag bit T0IF must be cleared in software by the TImer0
Counter mode is selected by setting bit T0CS. In this interrupt service routine before re-enabling this inter-
mode, Timer0 will increment either on every rising or rupt. The TMR0 interrupt cannot wake the processor
falling edge of pin RA4/T0CKI. The incrementing edge from SLEEP since the timer is shut off during SLEEP.
is determined by the source edge select bit T0SE Figure 7-4 displays the Timer0 interrupt timing.
Data bus
RA4/T0CKI FOSC/4 0
pin PSout 8
1
Sync with
1 Internal TMR0 reg
clocks
Programmable 0 PSout
Prescaler
T0SE (2 cycle delay)
3
Set bit T0IF
PS2, PS1, PS0 PSA on overflow
T0CS
Note 1: Bits, T0CS, T0SE, PSA, and PS2, PS1, PS0 are (OPTION<5:0).
2: The prescaler is shared with Watchdog Timer (refer to Figure 7-6 for detailed diagram).
PC Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
(Program
Counter) PC-1 PC PC+1 PC+2 PC+3 PC+4 PC+5 PC+6
Instruction MOVWF TMR0 MOVF TMR0,W MOVF TMR0,W MOVF TMR0,W MOVF TMR0,W MOVF TMR0,W
Fetch
Instruction
Executed
Write TMR0 Read TMR0 Read TMR0 Read TMR0 Read TMR0 Read TMR0
executed reads NT0 reads NT0 reads NT0 reads NT0 + 1 reads NT0 + 2
PC Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
(Program
Counter) PC-1 PC PC+1 PC+2 PC+3 PC+4 PC+5 PC+6
Instruction MOVWF TMR0 MOVF TMR0,W MOVF TMR0,W MOVF TMR0,W MOVF TMR0,W MOVF TMR0,W
Fetch
Instruction
Execute Write TMR0 Read TMR0 Read TMR0 Read TMR0 Read TMR0 Read TMR0
executed reads NT0 reads NT0 reads NT0 reads NT0 reads NT0 + 1
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
OSC1
CLKOUT(3)
GIE bit
(INTCON<7>)
INSTRUCTION
FLOW
PC PC PC +1 PC +1 0004h 0005h
Instruction
fetched Inst (PC) Inst (PC+1) Inst (0004h) Inst (0005h)
Instruction Inst (PC-1) Inst (PC) Dummy cycle Dummy cycle Inst (0004h)
executed
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Small pulse
External Clock Input or misses sampling
Prescaler output (2)
(1)
(3)
External Clock/Prescaler
Output after sampling
Increment Timer0 (Q4)
Timer0 T0 T0 + 1 T0 + 2
Note 1: Delay from clock input change to Timer0 increment is 3Tosc to 7Tosc. (Duration of Q = Tosc).
Therefore, the error in measuring the interval between two edges on Timer0 input = ±4Tosc max.
2: External clock if no prescaler selected, prescaler output otherwise.
3: The arrows indicate the points in time where sampling occurs.
8
M 1
0
RA4/T0CKI U M
X SYNC
pin U 2 TMR0 reg
1 0
X Cycles
T0SE
T0CS
PSA Set flag bit T0IF
on Overflow
0
M 8-bit Prescaler
U
Watchdog 1 X 8
Timer
8 - to - 1MUX PS2:PS0
PSA
0 1
WDT Enable bit
MUX PSA
WDT
Time-out
01h, 101h TMR0 Timer0 module’s register xxxx xxxx uuuu uuuu
0Bh,8Bh, INTCON GIE PEIE(1) T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
10Bh,18Bh
81h, 181h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0 1111 1111 1111 1111
85h TRISA — — PORTA Data Direction Register(1) --11 1111 --11 1111
Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by Timer0.
Note 1: TRISA<5> and bit PEIE are not implemented on the PIC16C61, read as '0'.
0Bh,8Bh INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
10Bh,18Bh
0Ch PIR1 PSPIF(2) (3) RCIF(1) TXIF(1) SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
8Ch PIE1 PSPIE(2) (3) RCIE(1) TXIE(1) SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
0Eh TMR1L Holding register for the Least Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
0Fh TMR1H Holding register for the Most Significant Byte of the 16-bit TMR1 register xxxx xxxx uuuu uuuu
10h T1CON — — T1CKPS1 T1CKPS0 T1OSCEN T1SYNC TMR1CS TMR1ON --00 0000 --uu uuuu
Legend: x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used by the Timer1 module.
Note 1: The USART is implemented on the PIC16C63/R63/65/65A/R65/66/67 only.
2: Bits PSPIE and PSPIF are reserved on the PIC16C62/62A/R62/63/R63/66, always maintain these bits clear.
3: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
Note: If the RC2/CCP1 pin is configured as an When the Capture event is changed, a false capture
output, a write to PORTC can cause a cap- interrupt may be generated. The user should clear
ture condition. enable bit CCP1IE (PIE1<2>) to avoid false interrupts
and should clear flag bit CCP1IF following any such
change in operating mode.
There are four prescaler settings, specified by bits The user must configure the RC2/CCP1 pin as an out-
CCP1M3:CCP1M0. Whenever the CCP module is put by clearing the TRISC<2> bit.
turned off, or the CCP module is not in Capture mode,
Note: Clearing the CCP1CON register will force
the prescaler counter is cleared. This means that any
the RC2/CCP1 compare output latch to the
reset will clear the prescaler counter.
default low level. This is not the data latch.
Switching from one capture prescaler to another may
generate an interrupt. Also, the prescaler counter will 10.2.1 TIMER1 MODE SELECTION
not be cleared, therefore the first capture may be from
a non-zero prescaler. Example 10-1 shows the recom- Timer1 must be running in Timer mode or Synchro-
mended method for switching between capture pres- nized Counter mode if the CCP module is using the
calers. This example also clears the prescaler counter compare feature. In Asynchronous Counter mode, the
and will not generate the “false” interrupt. compare operation may not work.
Set CCP1IF
PIR1<2>
CCPR1H CCPR1L
Q S Output
Logic Comparator
RC2/CCP1 R match
Note: Clearing the CCP1CON register will force When TMR2 is equal to PR2, the following three events
the CCP1 PWM output latch to the default occur on the next increment cycle:
low level. This is not the PORTC I/O data • TMR2 is cleared
latch. • The PWM duty cycle is latched from CCPR1L into
Figure 10-4 shows a simplified block diagram of the CCPR1H
CCP module in PWM mode. • The CCP1 pin is set (exception: if PWM duty
For a step by step procedure on how to set up the CCP cycle = 0%, the CCP1 pin will not be set)
module for PWM operation, see Section 10.3.3.
Note: The Timer2 postscaler (see Section 9.1) is
FIGURE 10-4: SIMPLIFIED PWM BLOCK not used in the determination of the PWM
DIAGRAM frequency. The postscaler could be used to
have a servo update rate at a different fre-
CCP1CON<5:4>
Duty cycle registers quency than the PWM output.
CCPR1L
10.3.2 PWM DUTY CYCLE
TMR2 = PR2
Note: If the PWM duty cycle value is longer than
TMR2 = Duty Cycle the PWM period the CCP1 pin will not be
forced to the low level.
TMR2 = PR2
PWM Frequency 1.22 kHz 4.88 kHz 19.53 kHz 78.12 kHz 156.3 kHz 208.3 kHz
Timer Prescaler (1, 4, 16) 16 4 1 1 1 1
PR2 Value 0xFF 0xFF 0xFF 0x3F 0x1F 0x17
Maximum Resolution (bits) 10 10 10 8 7 5.5
TABLE 10-4: REGISTERS ASSOCIATED WITH TIMER1, CAPTURE AND COMPARE
FIGURE 11-1: SSPSTAT: SYNC SERIAL PORT STATUS REGISTER (ADDRESS 94h)
11.2.1 OPERATION OF SSP MODULE IN SPI EXAMPLE 11-1: LOADING THE SSPBUF
MODE (SSPSR) REGISTER
BSF STATUS, RP0 ;Specify Bank 1
Applicable Devices
LOOP BTFSS SSPSTAT, BF ;Has data been
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 ;received
The SPI mode allows 8-bits of data to be synchro- ;(transmit
nously transmitted and received simultaneously. To ;complete)?
accomplish communication, typically three pins are GOTO LOOP ;No
used: BCF STATUS, RP0 ;Specify Bank 0
MOVF SSPBUF, W ;W reg = contents
• Serial Data Out (SDO) ;of SSPBUF
• Serial Data In (SDI) MOVWF RXDATA ;Save in user RAM
• Serial Clock (SCK) MOVF TXDATA, W ;W reg = contents
Additionally a fourth pin may be used when in a slave ; of TXDATA
mode of operation: MOVWF SSPBUF ;New data to xmit
• Slave Select (SS) The block diagram of the SSP module, when in SPI
mode (Figure 11-3), shows that the SSPSR register is
When initializing the SPI, several options need to be
not directly readable or writable, and can only be
specified. This is done by programming the appropriate
accessed from addressing the SSPBUF register. Addi-
control bits in the SSPCON register (SSPCON<5:0>).
tionally, the SSP status register (SSPSTAT) indicates
These control bits allow the following to be specified:
the various status conditions.
• Master Mode (SCK is the clock output)
FIGURE 11-3: SSP BLOCK DIAGRAM
• Slave Mode (SCK is the clock input)
(SPI MODE)
• Clock Polarity (Output/Input data on the Rising/
Falling edge of SCK)
• Clock Rate (Master mode only)
Internal
• Slave Select Mode (Slave mode only) data bus
The SSP consists of a transmit/receive Shift Register Read Write
(SSPSR) and a Buffer register (SSPBUF). The SSPSR
shifts the data in and out of the device, MSb first. The SSPBUF reg
SSPBUF holds the data that was written to the SSPSR,
until the received data is ready. Once the 8-bits of data
have been received, that byte is moved to the SSPBUF
register. Then the Buffer Full bit, BF (SSPSTAT<0>)
SSPSR reg
and flag bit SSPIF are set. This double buffering of the
RC4/SDI/SDA bit0 shift
received data (SSPBUF) allows the next byte to start clock
reception before reading the data that was just
received. Any write to the SSPBUF register during RC5/SDO
transmission/reception of data will be ignored, and the
write collision detect bit, WCOL (SSPCON<7>) will be
set. User software must clear bit WCOL so that it can SS Control
be determined if the following write(s) to the SSPBUF Enable
completed successfully. When the application software RA5/SS Edge
is expecting to receive valid data, the SSPBUF register Select
should be read before the next byte of data to transfer
is written to the SSPBUF register. The Buffer Full bit BF 2
(SSPSTAT<0>) indicates when the SSPBUF register Clock Select
has been loaded with the received data (transmission
is complete). When the SSPBUF is read, bit BF is SSPM3:SSPM0
TMR2 output
cleared. This data may be irrelevant if the SPI is only a 4 2
transmitter. Generally the SSP Interrupt is used to
Edge
determine when the transmission/reception has com- Select Prescaler TCY
pleted. The SSPBUF register must be read and/or writ- RC3/SCK/ 4, 16, 64
ten. If the interrupt method is not going to be used, then SCL
software polling can be done to ensure that a write col-
TRISC<3>
lision does not occur. Example 11-1 shows the loading
of the SSPBUF (SSPSR) register for data transmis-
sion. The shaded instruction is only required if the
received data is meaningful.
SDO SDI
SDI SDO
Shift Register Shift Register
(SSPSR) (SSPSR)
PROCESSOR 1 PROCESSOR 2
The SS pin allows a synchronous slave mode. The point at which it was taken high. External pull-up/
SPI must be in slave mode (SSPCON<3:0> = 04h) pull-down resistors may be desirable, depending on the
and the TRISA<5> bit must be set the for synchro- application.
nous slave mode to be enabled. When the SS pin is To emulate two-wire communication, the SDO pin can
low, transmission and reception are enabled and be connected to the SDI pin. When the SPI needs to
the SDO pin is driven. When the SS pin goes high, operate as a receiver the SDO pin can be configured as
the SDO pin is no longer driven, even if in the mid- an input. This disables transmissions from the SDO.
dle of a transmitted byte, and becomes a floating The SDI can always be left as an input (SDI function)
output. If the SS pin is taken low without resetting since it cannot create a bus conflict.
SPI mode, the transmission will continue from the
FIGURE 11-5: SPI MODE TIMING, MASTER MODE OR SLAVE MODE W/O SS CONTROL
SCK
(CKP = 0)
SCK
(CKP = 1)
SDI
bit7 bit0
SSPIF
SCK
(CKP = 0)
SCK
(CKP = 1)
SDI
bit7 bit0
SSPIF
FIGURE 11-7: SSPSTAT: SYNC SERIAL PORT STATUS REGISTER (ADDRESS 94h)(PIC16C66/67)
FIGURE 11-8: SSPCON: SYNC SERIAL PORT CONTROL REGISTER (ADDRESS 14h)(PIC16C66/67)
To enable the serial port, SSP Enable bit, SSPEN The master can initiate the data transfer at any time
(SSPCON<5>) must be set. To reset or reconfigure SPI because it controls the SCK. The master determines
mode, clear bit SSPEN, re-initialize the SSPCON reg- when the slave (Processor 2) is to broadcast data by
ister, and then set bit SSPEN. This configures the SDI, the firmware protocol.
SDO, SCK, and SS pins as serial port pins. For the pins In master mode the data is transmitted/received as
to behave as the serial port function, they must have soon as the SSPBUF register is written to. If the SPI is
their data direction bits (in the TRISC register) appro- only going to receive, the SCK output could be disabled
priately programmed. That is: (programmed as an input). The SSPSR register will
• SDI must have TRISC<4> set continue to shift in the signal present on the SDI pin at
• SDO must have TRISC<5> cleared the programmed clock rate. As each byte is received, it
• SCK (Master mode) must have TRISC<3> will be loaded into the SSPBUF register as if a normal
cleared received byte (interrupts and status bits appropriately
set). This could be useful in receiver applications as a
• SCK (Slave mode) must have TRISC<3> set
“line activity monitor” mode.
• SS must have TRISA<5> set
In slave mode, the data is transmitted and received as
Any serial port function that is not desired may be over- the external clock pulses appear on SCK. When the
ridden by programming the corresponding data direc- last bit is latched the interrupt flag bit SSPIF (PIR1<3>)
tion (TRIS) register to the opposite value. An example is set.
would be in master mode where you are only sending
data (to a display driver), then both SDI and SS could The clock polarity is selected by appropriately program-
be used as general purpose outputs by clearing their ming bit CKP (SSPCON<4>). This then would give
corresponding TRIS register bits. waveforms for SPI communication as shown in
Figure 11-11, Figure 11-12, and Figure 11-13 where
Figure 11-10 shows a typical connection between two the MSB is transmitted first. In master mode, the SPI
microcontrollers. The master controller (Processor 1) clock rate (bit rate) is user programmable to be one of
initiates the data transfer by sending the SCK signal. the following:
Data is shifted out of both shift registers on their pro-
grammed clock edge, and latched on the opposite edge • FOSC/4 (or TCY)
of the clock. Both processors should be programmed to • FOSC/16 (or 4 • TCY)
same Clock Polarity (CKP), then both controllers would • FOSC/64 (or 16 • TCY)
send and receive data at the same time. Whether the • Timer2 output/2
data is meaningful (or dummy data) depends on the
This allows a maximum bit clock frequency (at 20 MHz)
application firmware. This leads to three scenarios for
of 5 MHz. When in slave mode the external clock must
data transmission:
meet the minimum high and low times.
• Master sends data — Slave sends dummy data
In sleep mode, the slave can transmit and receive data
• Master sends data — Slave sends data and wake the device from sleep.
• Master sends dummy data — Slave sends data
FIGURE 11-10: SPI MASTER/SLAVE CONNECTION (PIC16C66/67)
SDO SDI
SDI SDO
Shift Register Shift Register
(SSPSR) (SSPSR)
PROCESSOR 1 PROCESSOR 2
SCK (CKP = 0,
CKE = 0)
SCK (CKP = 0,
CKE = 1)
SCK (CKP = 1,
CKE = 0)
SCK (CKP = 1,
CKE = 1)
SDI (SMP = 0)
bit7 bit0
SDI (SMP = 1)
bit7 bit0
SSPIF
FIGURE 11-12: SPI MODE TIMING (SLAVE MODE WITH CKE = 0) (PIC16C66/67)
SS (optional)
SCK (CKP = 0)
SCK (CKP = 1)
SDI (SMP = 0)
bit7 bit0
SSPIF
FIGURE 11-13: SPI MODE TIMING (SLAVE MODE WITH CKE = 1) (PIC16C66/67)
SS
(not optional)
SCK (CKP = 0)
SCK (CKP = 1)
SDI (SMP = 0)
bit7 bit0
SSPIF
0Bh,8Bh, INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
10Bh,18Bh
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
85h TRISA — — PORTA Data Direction register --11 1111 --11 1111
87h TRISC PORTC Data Direction register 1111 1111 1111 1111
94h SSPSTAT SMP CKE D/A P S R/W UA BF 0000 0000 0000 0000
Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'.
Shaded cells are not used by SSP module in SPI mode.
Note 1: PSPIF and PSPIE are reserved on the PIC16C66, always maintain these bits clear.
2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
Term Description
Receiver The device that receives the data from the bus.
Master The device which initiates the transfer, generates the clock and terminates the transfer.
Multi-master More than one master device in a system. These masters can attempt to control the bus at the
same time without corrupting the message.
Arbitration Procedure that ensures that only one of the master devices will control the bus. This ensure that
the transfer data does not get corrupted.
Synchronization Procedure where the clock signals of two or more devices are synchronized.
S
MSb LSb Start Clock Pulse for
Condition Acknowledgment
S R/W ACK
SDA
MSB acknowledgment acknowledgment
signal from receiver byte complete signal from receiver
interrupt with receiver
clock line held low while
interrupts are serviced
SCL S 1 2 7 8 9 1 2 3•8 9 P
Start Stop
Condition Address R/W ACK Wait Data ACK
State Condition
S Slave Address R/W A Data A/A Sr Slave Address R/W A Data A/A P
Combined format:
Sr Slave Address R/W A Slave Address A Data A Data A/A Sr Slave Address R/W A Data A Data A P
First 7 bits Second byte First 7 bits
(write) (read)
Combined format - A master addresses a slave with a 10-bit address, then transmits
data to this slave and reads data from this slave.
A = acknowledge (SDA low)
From master to slave A = not acknowledge (SDA high)
S = Start Condition
From slave to master P = Stop Condition
The I2C protocol allows a system to have more than Clock synchronization occurs after the devices have
one master. This is called multi-master. When two or started arbitration. This is performed using a wired-
more masters try to transfer data at the same time, arbi- AND connection to the SCL line. A high to low transition
tration and synchronization occur. on the SCL line causes the concerned devices to start
counting off their low period. Once a device clock has
11.4.4.1 ARBITRATION gone low, it will hold the SCL line low until its SCL high
state is reached. The low to high transition of this clock
Arbitration takes place on the SDA line, while the SCL may not change the state of the SCL line, if another
line is high. The master which transmits a high when device clock is still within its low period. The SCL line is
the other master transmits a low loses arbitration held low by the device with the longest low period.
(Figure 11-22), and turns off its data output stage. A Devices with shorter low periods enter a high wait-
master which lost arbitration can generate clock pulses state, until the SCL line comes high. When the SCL line
until the end of the data byte where it lost arbitration. comes high, all devices start counting off their high
When the master devices are addressing the same periods. The first device to complete its high period will
device, arbitration continues into the data. pull the SCL line low. The SCL line high time is deter-
mined by the device with the shortest high period,
FIGURE 11-22: MULTI-MASTER Figure 11-23.
ARBITRATION
(TWO MASTERS) FIGURE 11-23: CLOCK SYNCHRONIZATION
DATA 2 CLK
1
SDA counter
CLK reset
2
SCL
SCL
11.5.1 SLAVE MODE address is compared on the falling edge of the eighth
clock (SCL) pulse. If the addresses match, and the BF
In slave mode, the SCL and SDA pins must be config- and SSPOV bits are clear, the following events occur:
ured as inputs (TRISC<4:3> set). The SSP module will
override the input state with the output data when a) The SSPSR register value is loaded into the
required (slave-transmitter). SSPBUF register.
b) The buffer full bit, BF is set.
When an address is matched or the data transfer after
an address match is received, the hardware automati- c) An ACK pulse is generated.
cally will generate the acknowledge (ACK) pulse, and d) SSP interrupt flag bit, SSPIF (PIR1<3>) is set
then load the SSPBUF register with the received value (interrupt is generated if enabled) - on the falling
currently in the SSPSR register. edge of the ninth SCL pulse.
There are certain conditions that will cause the SSP In 10-bit address mode, two address bytes need to be
module not to give this ACK pulse. These are if either received by the slave (Figure 11-16). The five Most Sig-
(or both): nificant bits (MSbs) of the first address byte specify if
this is a 10-bit address. Bit R/W (SSPSTAT<2>) must
a) The buffer full bit BF (SSPSTAT<0>) was set
specify a write so the slave device will receive the sec-
before the transfer was received.
ond address byte. For a 10-bit address the first byte
b) The overflow bit SSPOV (SSPCON<6>) was set would equal ‘1111 0 A9 A8 0’, where A9 and A8 are
before the transfer was received. the two MSbs of the address. The sequence of events
In this case, the SSPSR register value is not loaded for 10-bit address is as follows, with steps 7- 9 for slave-
into the SSPBUF, but bit SSPIF (PIR1<3>) is set. transmitter:
Table 11-4 shows what happens when a data transfer 1. Receive first (high) byte of Address (bits SSPIF,
byte is received, given the status of bits BF and SSPOV. BF, and bit UA (SSPSTAT<1>) are set).
The shaded cells show the condition where user soft-
2. Update the SSPADD register with second (low)
ware did not properly clear the overflow condition. Flag
byte of Address (clears bit UA and releases the
bit BF is cleared by reading the SSPBUF register while
SCL line).
bit SSPOV is cleared through software.
3. Read the SSPBUF register (clears bit BF) and
The SCL clock input must have a minimum high and clear flag bit SSPIF.
low for proper operation. The high and low times of the
4. Receive second (low) byte of Address (bits
I2C specification as well as the requirement of the SSP
SSPIF, BF, and UA are set).
module is shown in timing parameter #100 and param-
eter #101. 5. Update the SSPADD register with the first (high)
byte of Address, if match releases SCL line, this
11.5.1.1 ADDRESSING will clear bit UA.
6. Read the SSPBUF register (clears bit BF) and
Once the SSP module has been enabled, it waits for a clear flag bit SSPIF.
START condition to occur. Following the START condi-
7. Receive repeated START condition.
tion, the 8-bits are shifted into the SSPSR register. All
incoming bits are sampled with the rising edge of the 8. Receive first (high) byte of Address (bits SSPIF
clock (SCL) line. The value of register SSPSR<7:1> is and BF are set).
compared to the value of the SSPADD register. The 9. Read the SSPBUF register (clears bit BF) and
clear flag bit SSPIF.
SCL S 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 P
SSPOV (SSPCON<6>)
Bit SSPOV is set because the SSPBUF register is still full.
ACK is not sent.
SCL 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
S P
Data in SCL held low
sampled while CPU
responds to SSPIF
SSPIF (PIR1<3>)
BF (SSPSTAT<0>)
cleared in software From SSP interrupt
SSPBUF is written in software service routine
CKP (SSPCON<4>)
Master mode of operation is supported in firmware In multi-master mode, the interrupt generation on the
using interrupt generation on the detection of the detection of the START and STOP conditions allows
START and STOP conditions. The STOP (P) and the determination of when the bus is free. The STOP
START (S) bits are cleared from a reset or when the (P) and START (S) bits are cleared from a reset or
SSP module is disabled. The STOP (P) and START (S) when the SSP module is disabled. The STOP (P) and
bits will toggle based on the START and STOP condi- START (S) bits will toggle based on the START and
tions. Control of the I 2C bus may be taken when the P STOP conditions. Control of the I2C bus may be taken
bit is set, or the bus is idle and both the S and P bits are when bit P (SSPSTAT<4>) is set, or the bus is idle and
clear. both the S and P bits clear. When the bus is busy,
In master mode the SCL and SDA lines are manipu- enabling the SSP Interrupt will generate the interrupt
lated by clearing the corresponding TRISC<4:3> bit(s). when the STOP condition occurs.
The output level is always low, irrespective of the In multi-master operation, the SDA line must be moni-
value(s) in PORTC<4:3>. So when transmitting data, a tored to see if the signal level is the expected output
'1' data bit must have the TRISC<4> bit set (input) and level. This check only needs to be done when a high
a '0' data bit must have the TRISC<4> bit cleared (out- level is output. If a high level is expected and a low level
put). The same scenario is true for the SCL line with the is present, the device needs to release the SDA and
TRISC<3> bit. SCL lines (set TRISC<4:3>). There are two stages
The following events will cause SSP Interrupt Flag bit, where this arbitration can be lost, these are:
SSPIF, to be set (SSP Interrupt if enabled): • Address Transfer
• START condition • Data Transfer
• STOP condition When the slave logic is enabled, the slave continues to
• Data transfer byte transmitted/received receive. If arbitration was lost during the address trans-
fer stage, communication to the device may be in
Master mode of operation can be done with either the
progress. If addressed an ACK pulse will be generated.
slave mode idle (SSPM3:SSPM0 = 1011) or with the
If arbitration was lost during the data transfer stage, the
slave active. When both master and slave modes are
device will need to re-transfer the data at a later time.
enabled, the software needs to differentiate the
source(s) of the interrupt.
Value on
Value on all
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 POR,
other resets
BOR
0Bh, 8Bh, INTCON GIE PEIE T0IE INTE RBIE T0IF INTF RBIF 0000 000x 0000 000u
10Bh, 18Bh
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
13h SSPBUF Synchronous Serial Port Receive Buffer/Transmit Register xxxx xxxx uuuu uuuu
93h SSPADD Synchronous Serial Port (I2C mode) Address Register 0000 0000 0000 0000
14h SSPCON WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0 0000 0000 0000 0000
94h SSPSTAT SMP(3) CKE(3) D/A P S R/W UA BF 0000 0000 0000 0000
87h TRISC PORTC Data Direction register 1111 1111 1111 1111
Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'.
Shaded cells are not used by SSP module in SPI mode.
Note 1: PSPIF and PSPIE are reserved on the PIC16C66, always maintain these bits clear.
2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
3: The SMP and CKE bits are implemented on the PIC16C66/67 only. All other PIC16C6X devices have these two bits unim-
plemented, read as '0'.
IDLE_MODE (7-bit):
if (Addr_match) { Set interrupt;
if (R/W = 1) { Send ACK = 0;
set XMIT_MODE;
}
else if (R/W = 0) set RCV_MODE;
}
RCV_MODE:
if ((SSPBUF=Full) OR (SSPOV = 1))
{ Set SSPOV;
Do not acknowledge;
}
else { transfer SSPSR → SSPBUF;
send ACK = 0;
}
Receive 8-bits in SSPSR;
Set interrupt;
XMIT_MODE:
While ((SSPBUF = Empty) AND (CKP=0)) Hold SCL Low;
Send byte;
Set interrupt;
if ( ACK Received = 1) { End of transmission;
Go back to IDLE_MODE;
}
else if ( ACK Received = 0) Go back to XMIT_MODE;
IDLE_MODE (10-Bit):
If (High_byte_addr_match AND (R/W = 0))
{ PRIOR_ADDR_MATCH = FALSE;
Set interrupt;
if ((SSPBUF = Full) OR ((SSPOV = 1))
{ Set SSPOV;
Do not acknowledge;
}
else { Set UA = 1;
Send ACK = 0;
While (SSPADD not updated) Hold SCL low;
Clear UA = 0;
Receive Low_addr_byte;
Set interrupt;
Set UA = 1;
If (Low_byte_addr_match)
{ PRIOR_ADDR_MATCH = TRUE;
Send ACK = 0;
while (SSPADD not updated) Hold SCL low;
Clear UA = 0;
Set RCV_MODE;
}
}
}
else if (High_byte_addr_match AND (R/W = 1)
{ if (PRIOR_ADDR_MATCH)
{ send ACK = 0;
set XMIT_MODE;
}
else PRIOR_ADDR_MATCH = FALSE;
}
FIGURE 12-1: TXSTA: TRANSMIT STATUS AND CONTROL REGISTER (ADDRESS 98h)
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used by the BRG.
Note: For the PIC16C63/R63/65/65A/R65 the asynchronous high speed mode (BRGH = 1) may experience a
high rate of receive errors. It is recommended that BRGH = 0. If you desire a higher baud rate than BRGH
= 0 can support, refer to the device errata for additional information or use the PIC16C66/67.
x16 CLK
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 1 2 3
Samples
RC7/RX/DT pin
Start Bit bit0 bit1
baud clk
First falling edge after RX pin goes low
Second rising edge
x4 clk
1 2 3 4 1 2 3 4 1 2
Q2, Q4 clk
Q2, Q4 clk
Samples
x16 CLK
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 1 2 3
Samples
TX9
Baud Rate Generator
TX9D
RC6/TX/CK (pin)
Start Bit Bit 0 Bit 1 Bit 7/8 Stop Bit
WORD 1
TXIF bit
(Transmit buffer
reg. empty flag)
WORD 1
TRMT bit Transmit Shift Reg
(Transmit shift
reg. empty flag)
Value on Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 POR, all other
BOR Resets
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Transmission.
Note 1: PSPIF and PSPIE are reserved on the PIC16C63/R63/66, always maintain these bits clear.
2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
SPBRG
÷ 64 MSb RSR register LSb
or
÷ 16
Baud Rate Generator Stop (8) 7 • • • 1 0 Start
RC7/RX/DT
Pin Buffer Data
and Control Recovery RX9
Interrupt RCIF
Data Bus
RCIE
RCIF
(interrupt flag)
OERR bit
CREN bit
Note: This timing diagram shows three words appearing on the RX input. The RCREG (receive buffer) is read after the third word,
causing overrun error bit OERR to be set.
Value on Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 POR, all other
BOR Resets
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
1Ah RCREG USART Receive Register 0000 0000 0000 0000
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Reception.
Note 1: PSPIE and PSPIF are reserved on the PIC16C63/R63/66, always maintain these bits clear.
2: PIE1<6> and PIR1<6> are reserved, always maintain these bits clear.
Value on Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 POR, all other
BOR Resets
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
19h TXREG USART Transmit Register 0000 0000 0000 0000
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Synchronous Master Transmission.
Note 1: PSPIE and PSPIF are reserved on the PIC16C63/R63/66, always maintain these bits clear.
2: PIE1<6> and PIR1<6> are reserved, always maintain these bits clear.
Q1Q2 Q3Q4 Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2 Q3Q4 Q3Q4 Q1Q2 Q3Q4 Q1Q2 Q3Q4 Q1Q2 Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4
Write to
TXREG reg
Write word1 Write word2
TXIF bit
(Interrupt flag)
TRMT
TRMT bit
'1' '1'
TXEN bit
Note: Sync master mode; SPBRG = '0'. Continuous transmission of two 8-bit words
RC6/TX/CK pin
Write to
TXREG reg
TXIF bit
TRMT bit
TXEN bit
Once Synchronous Mode is selected, reception is 1. Initialize the SPBRG register for the appropriate
enabled by setting either enable bit SREN baud rate (Section 12.1).
(RCSTA<5>) bit or enable bit CREN (RCSTA<4>). 2. Enable the synchronous master serial port by
Data is sampled on the DT pin on the falling edge of the setting bits SYNC, SPEN, and CSRC.
clock. If enable bit SREN is set, then only a single word 3. Ensure bits CREN and SREN are clear.
is received. If enable bit CREN is set, the reception is 4. If interrupts are desired, then set enable bit
continuous until bit CREN is cleared. If both the bits are RCIE.
set then bit CREN takes precedence. After clocking the 5. If 9-bit reception is desired, then set bit RX9.
last bit, the received data in the Receive Shift Register
6. If a single reception is required, set enable bit
(RSR) is transferred to the RCREG register (if it is
SREN. For continuous reception set enable bit
empty). When the transfer is complete, interrupt bit
CREN.
RCIF (PIR1<5>) is set. The actual interrupt can be
enabled/disabled by setting/clearing enable bit RCIE 7. Flag bit RCIF will be set when reception is com-
(PIE1<5>). Flag bit RCIF is a read only bit which is plete and an interrupt will be generated if enable
reset by the hardware. In this case, it is reset when the bit RCIE was set.
RCREG register has been read and is empty. The 8. Read the RCSTA register to get the ninth bit (if
RCREG is a double buffered register, i.e., it is a two enabled) and determine if any error occurred
deep FIFO. It is possible for two bytes of data to be during reception.
received and transferred to the RCREG FIFO and a 9. Read the 8-bit received data by reading the
third byte to begin shifting into the RSR register. On the RCREG register.
clocking of the last bit of the third byte, if the RCREG 10. If any error occurred, clear the error by clearing
register is still full, then overrun error bit, OERR enable bit CREN.
(RCSTA<1>) is set. The word in the RSR register will
be lost. The RCREG register can be read twice to
retrieve the two bytes in the FIFO. Overrun error bit
OERR has to be cleared in software (by clearing bit
CREN). If bit OERR is set, transfers from the RSR to
the RCREG are inhibited, so it is essential to clear bit
OERR if it is set. The 9th receive bit is buffered the
same way as the receive data. Reading the RCREG
register will load bit RX9D with a new value. Therefore
it is essential for the user to read the RCSTA register
before reading the RCREG register in order not to lose
the old RX9D bit information.
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
1Ah RCREG USART Receive Register 0000 0000 0000 0000
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Synchronous Master Reception.
Note 1: PSPIF and PSPIE are reserved on the PIC16C63/R63/66, always maintain these bits clear.
2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
RC7/RX/DT pin bit0 bit1 bit2 bit3 bit4 bit5 bit6 bit7
RC6/TX/CK pin
Write to
bit SREN
SREN bit
CREN bit '0' '0'
RCIF bit
(interrupt)
Read
RXREG
Note: Timing diagram demonstrates SYNC master mode with bit SREN = '1' and bit BRG = '0'.
Value on Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 POR, all other
BOR Resets
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Synchronous Slave Transmission.
Note 1: PSPIF and PSPIE are reserved on the PIC16C63/R63/66, always maintain these bits clear.
2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
0Ch PIR1 PSPIF(1) (2) RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
18h RCSTA SPEN RX9 SREN CREN — FERR OERR RX9D 0000 -00x 0000 -00x
8Ch PIE1 PSPIE(1) (2) RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
98h TXSTA CSRC TX9 TXEN SYNC — BRGH TRMT TX9D 0000 -010 0000 -010
99h SPBRG Baud Rate Generator Register 0000 0000 0000 0000
Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Synchronous Slave Reception.
Note 1: PSPIF and PSPIE are reserved on the PIC16C63/R63/66, always maintain these bits clear.
2: PIR1<6> and PIE1<6> are reserved, always maintain these bits clear.
CP1 CP0 CP1 CP0 CP1 CP0 — BODEN CP1 CP0 PWRTE WDTE FOSC1 FOSC0 Register: CONFIG
bit13 bit0 Address 2007h
Note 1: Enabling Brown-out Reset automatically enables Power-up Timer (PWRT) regardless of the value of bit PWRTE.
Ensure the Power-up Timer is enabled anytime Brown-out Reset is enabled.
2: All of the CP1:CP0 pairs have to be given the same value to implement the code protection scheme listed.
Note 1: Recommended values of C1 and C2 are identical to the ranges tested Table 13-1 and Table 13-2.
2: Higher capacitance increases the stability of oscillator but also increases the start-up time.
3: Since each resonator/crystal has its own characteristics, the user should consult the resonator/crystal man-
ufacturer for appropriate values of external components.
4: Rs may be required in HS mode as well as XT mode to avoid overdriving crystals with low drive level speci-
fication.
External Reset
MCLR/VPP pin
SLEEP
WDT
Module WDT
Time-out
VDD rise
detect
Power-on Reset
VDD pin
(2)
Brown-out
Reset
BODEN S
OST/PWRT
OST
Chip Reset
10-bit Ripple counter R Q
OSC1/
CLKIN
pin (1) PWRT
On-chip
RC OSC 10-bit Ripple counter
Enable PWRT
(3)
Enable OST
Note 1: This is a separate oscillator from the RC oscillator of the CLKIN pin.
2: Brown-out Reset is NOT implemented on the PIC16C61/62/64/65.
3: See Table 13-5 and Table 13-6 for time-out situations.
VDD
BVDD Max.
BVDD Min.
Internal
72 ms
Reset
VDD
BVDD Max.
BVDD Min.
Internal <72 ms
Reset 72 ms
VDD
BVDD Max.
BVDD Min.
Internal
72 ms
Reset
TO PD
1 1 Power-on Reset or MCLR reset during normal operation
0 1 WDT Reset
0 0 WDT Wake-up
1 0 MCLR reset during SLEEP or interrupt wake-up from SLEEP
TABLE 13-8: STATUS BITS AND THEIR SIGNIFICANCE, PIC16C62/64/65
POR TO PD
0 1 1 Power-on Reset
0 0 x Illegal, TO is set on a Power-on Reset
0 x 0 Illegal, PD is set on a Power-on Reset
1 0 1 WDT Reset
1 0 0 WDT Wake-up
1 u u MCLR reset during normal operation
1 1 0 MCLR reset during SLEEP or interrupt wake-up from SLEEP
Legend: x = unknown, u = unchanged
POR BOR TO PD
0 x 1 1 Power-on Reset
0 x 0 x Illegal, TO is set on a Power-on Reset
0 x x 0 Illegal, PD is set on a Power-on Reset
1 0 x x Brown-out Reset
1 1 0 1 WDT Reset
1 1 0 0 WDT Wake-up
1 1 u u MCLR reset during normal operation
1 1 1 0 MCLR reset during SLEEP or interrupt wake-up from SLEEP
Legend: x = unknown, u = unchanged
TABLE 13-10: RESET CONDITION FOR SPECIAL REGISTERS ON PIC16C61/62/64/65
Program Counter STATUS PCON(2)
Power-on Reset 000h 0001 1xxx ---- --0-
MCLR reset during normal operation 000h 000u uuuu ---- --u-
MCLR reset during SLEEP 000h 0001 0uuu ---- --u-
WDT Reset 000h 0000 1uuu ---- --u-
WDT Wake-up PC + 1 uuu0 0uuu ---- --u-
Interrupt wake-up from SLEEP PC + 1(1) uuu1 0uuu ---- --u-
Legend: u = unchanged, x = unknown, - = unimplemented bit read as '0'.
Note 1: When the wake-up is due to an interrupt and the global enable bit, GIE is set, the PC is loaded with the inter-
rupt vector (0004h) after execution of PC+1.
2: The PCON register is not implemented on the PIC16C61.
VDD
MCLR
INTERNAL POR
TPWRT
OST TIME-OUT
INTERNAL RESET
FIGURE 13-12: TIME-OUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD): CASE 2
VDD
MCLR
INTERNAL POR
TPWRT
OST TIME-OUT
INTERNAL RESET
VDD
MCLR
INTERNAL POR
TPWRT
OST TIME-OUT
INTERNAL RESET
D R 10k MCLR
R1
MCLR 40k PIC16CXX
C PIC16CXX
Note 1: External Power-on Reset circuit is required Note 1: This circuit will activate reset when VDD
only if VDD power-up slope is too slow. The goes below (Vz + 0.7V) where Vz = Zener
diode D helps discharge the capacitor voltage.
quickly when VDD powers down.
2: Internal brown-out detection on the
2: R < 40 kΩ is recommended to make sure PIC16C62A/R62/63/R63/64A/R64/65A/
that voltage drop across R does not violate R65/66/67 should be disabled when using
the devices electrical specifications. this circuit.
3: R1 = 100Ω to 1 kΩ will limit any current 3: Resistors should be adjusted for the
flowing into MCLR from external capacitor characteristics of the transistors.
C in the event of MCLR/VPP pin break-
down due to Electrostatic Discharge
(ESD) or Electrostatic Overstress (EOS).
FIGURE 13-16: EXTERNAL BROWN-OUT
PROTECTION CIRCUIT 2
VDD VDD
R1
Q1
MCLR
R2 40k PIC16CXX
The PIC16C6X family has up to 11 sources of interrupt. Note: For the PIC16C61/62/64/65, if an interrupt
The interrupt control register (INTCON) records individ- occurs while the Global Interrupt Enable
ual interrupt requests in flag bits. It also has individual bit, GIE is being cleared, bit GIE may unin-
and global interrupt enable bits. tentionally be re-enabled by the user’s
Interrupt Service Routine (the RETFIE
Note: Individual interrupt flag bits are set regard- instruction). The events that would cause
less of the status of their corresponding this to occur are:
mask bit or global enable bit, GIE.
1. An instruction clears the GIE bit while
Global interrupt enable bit, GIE (INTCON<7>) enables an interrupt is acknowledged
(if set) all un-masked interrupts or disables (if cleared)
all interrupts. When bit GIE is enabled, and an interrupt 2. The program branches to the Interrupt
flag bit and mask bit are set, the interrupt will vector vector and executes the Interrupt Ser-
immediately. Individual interrupts can be disabled vice Routine.
through their corresponding enable bits in the INTCON 3. The Interrupt Service Routine com-
register. GIE is cleared on reset. pletes with the execution of the RET-
The “return from interrupt” instruction, RETFIE, exits FIE instruction. This causes the GIE
the interrupt routine as well as sets the GIE bit, which bit to be set (enables interrupts), and
re-enable interrupts. the program returns to the instruction
after the one which was meant to dis-
The RB0/INT pin interrupt, the RB port change interrupt able interrupts.
and the TMR0 overflow interrupt flag bits are contained
in the INTCON register. 4. Perform the following to ensure that
interrupts are globally disabled.
The peripheral interrupt flag bits are contained in spe-
cial function registers PIR1 and PIR2. The correspond- LOOP BCF INTCON,GIE ;Disable Global
;Interrupt bit
ing interrupt enable bits are contained in special
BTFSC INTCON,GIE ;Global Interrupt
function registers PIE1 and PIE2 and the peripheral ;Disabled?
interrupt enable bit is contained in special function reg- GOTO LOOP ;NO, try again
ister INTCON. : ;Yes, continue
When an interrupt is responded to, bit GIE is cleared to ;with program flow
disable any further interrupts, the return address is
pushed onto the stack and the PC is loaded with
0004h. Once in the interrupt service routine the
source(s) of the interrupt can be determined by polling
the interrupt flag bits. The interrupt flag bit(s) must be
cleared in software before re-enabling interrupts to
avoid recursive interrupts.
For external interrupt events, such as the RB0/INT pin
or RB port change interrupt, the interrupt latency will be
three or four instruction cycles. The exact latency
depends when the interrupt event occurs (Figure 13-
19). The latency is the same for one or two cycle
instructions. Once in the interrupt service routine the
source(s) of the interrupt can be determined by polling
the interrupt flag bits. The interrupt flag bit(s) must be
cleared in software before re-enabling interrupts to
Wake-up
T0IF (If in SLEEP mode)
T0IE
INTF
INTE
Interrupt to CPU
RBIF
RBIE
GIE
PSPIF
PSPIE
RCIF T0IF Wake-up (If in SLEEP mode)
RCIE T0IE
TXIF INTF
TXIE INTE
Interrupt to CPU
SSPIF RBIF
SSPIE RBIE
PEIE
CCP1IF
CCP1IE GIE
TMR2IF
TMR2IE
TMR1IF
TMR1IE
CCP2IF
CCP2IE
External interrupt on RB0/INT pin is edge triggered: An overflow (FFh → 00h) in the TMR0 register will set
either rising if edge select bit INTEDG (OPTION<6>) is flag bit T0IF (INTCON<2>). The interrupt can be
set, or falling, if bit INTEDG is clear. When a valid edge enabled/disabled by setting/clearing enable bit T0IE
appears on the RB0/INT pin, flag bit INTF (INTCON<5>) (Section 7.0).
(INTCON<1>) is set. This interrupt can be disabled by
clearing enable bit INTE (INTCON<4>). The INTF bit 13.5.3 PORTB INTERRUPT ON CHANGE
must be cleared in software in the interrupt service rou-
An input change on PORTB<7:4> sets flag bit RBIF
tine before re-enabling this interrupt. The INT interrupt
(INTCON<0>). The interrupt can be enabled/disabled
can wake the processor from SLEEP, if enable bit INTE
by setting/clearing enable bit RBIE (INTCON<4>)
was set prior to going into SLEEP. The status of global
(Section 5.2).
enable bit GIE decides whether or not the processor
branches to the interrupt vector following wake-up. See Note: For the PIC16C61/62/64/65, if a change on
Section 13.8 for details on SLEEP mode. the I/O pin should occur when the read
operation is being executed (start of the Q2
cycle), then flag bit RBIF may not get set.
CLKOUT(3)
4
INT pin
1
1
INTF flag 5 Interrupt Latency (2)
(INTCON<1>)
GIE bit
(INTCON<7>)
INSTRUCTION FLOW
PC PC PC+1 PC+1 0004h 0005h
Instruction
fetched Inst (PC) Inst (PC+1) — Inst (0004h) Inst (0005h)
The Watchdog Timer is a free running on-chip RC oscil- The CLRWDT and SLEEP instructions clear the WDT
lator which does not require any external components. and the postscaler, if assigned to the WDT, and prevent
This RC oscillator is separate from the RC oscillator of it from timing out and generating a device RESET con-
the OSC1/CLKIN pin. That means that the WDT will dition.
run, even if the clock on the OSC1/CLKIN and OSC2/ The TO bit in the STATUS register will be cleared upon
CLKOUT pins of the device has been stopped, for a WDT time-out.
example, by execution of a SLEEP instruction. During
normal operation, a WDT time-out generates a device 13.7.2 WDT PROGRAMMING CONSIDERATIONS
reset. If the device is in SLEEP mode, a WDT time-out
It should also be taken in account that under worst case
causes the device to wake-up and continue with normal
conditions (VDD = Min., Temperature = Max., max.
operation (WDT Wake-up). The WDT can be perma-
WDT prescaler) it may take several seconds before a
nently disabled by clearing configuration bit WDTE
WDT time-out occurs.
(Section 13.1).
Note: When a CLRWDT instruction is executed
13.7.1 WDT PERIOD and the prescaler is assigned to the WDT,
The WDT has a nominal time-out period of 18 ms, (with the prescaler count will be cleared, but the
no prescaler). The time-out periods vary with tempera- prescaler assignment is not changed.
ture, VDD and process variations from part to part (see
DC specs). If longer time-out periods are desired, a
prescaler with a division ratio of up to 1:128 can be
0
M Postscaler
Watchdog U
Timer 1 X 8
8- to -1 MUX PS2:PS0
PSA
WDT
Enable bit
To TMR0 (Figure 7-6)
0 1
MUX PSA
WDT
Time-out
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
2007h Config. bits (1) BODEN(1) CP1 CP0 PWRTE(1) WDTE FOSC1 FOSC0
81h,181h OPTION RBPU INTEDG T0CS T0SE PSA PS2 PS1 PS0
Legend: Shaded cells are not used by the Watchdog Timer.
Note 1: See Figure 13-1, Figure 13-2, and Figure 13-3 for details of these bits for the specific device.
CLKOUT(4) TOST(2)
INT pin
INTF flag
(INTCON<1>) Interrupt Latency
(Note 2)
GIE bit Processor in
(INTCON<7>)
SLEEP
INSTRUCTION FLOW
PC PC PC+1 PC+2 PC+2 PC + 2 0004h 0005h
Instruction
fetched Inst(PC) = SLEEP Inst(PC + 1) Inst(PC + 2) Inst(0004h) Inst(0005h)
13.9 Program Verification/Code Protection The device is placed into a program/verify mode by
Applicable Devices
holding pins RB6 and RB7 low while raising the MCLR
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67
(VPP) pin from VIL to VIHH (see programming specifica-
tion). RB6 becomes the programming clock and RB7
If the code protection bit(s) have not been pro- becomes the programming data. Both RB6 and RB7
grammed, the on-chip program memory can be read are Schmitt Trigger inputs in this mode.
out for verification purposes.
After reset, to place the device in program/verify mode,
Note: Microchip does not recommend code pro- the program counter (PC) is at location 00h. A 6-bit
tecting windowed devices. command is then supplied to the device. Depending on
the command, 14-bits of program data are then sup-
13.10 ID Locations plied to or from the device, depending if the command
Applicable Devices was a load or a read. For complete details of serial pro-
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 gramming, please refer to the PIC16C6X/7X Program-
Four memory locations (2000h - 2003h) are designated ming Specifications (Literature #DS30228).
as ID locations where the user can store checksum or
FIGURE 13-23: TYPICAL IN-CIRCUIT SERIAL
other code-identification numbers. These locations are
PROGRAMMING
not accessible during normal execution but are read-
able and writable during program/verify. It is recom- CONNECTION
mended that only the 4 least significant bits of the ID
location are used. To Normal
Connections
External
For ROM devices, these values are submitted along Connector PIC16CXX
with the ROM code. Signals
+5V VDD
13.11 In-Circuit Serial Programming
0V VSS
Applicable Devices
VPP MCLR/VPP
61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67
The PIC16CXX microcontrollers can be serially pro- CLK RB6
grammed while in the end application circuit. This is
simply done with two lines for clock and data, and three Data I/O RB7
other lines for power, ground, and the programming
voltage. This allows customers to manufacture boards VDD
with unprogrammed devices, and then program the
microcontroller just before shipping the product. This
To Normal
also allows the most recent firmware or a custom firm- Connections
ware to be programmed.
Description: The contents of the W register are Description: The contents of W register are
added to the eight bit literal 'k' and the AND’ed with the eight bit literal 'k'. The
result is placed in the W register. result is placed in the W register.
Words: 1 Words: 1
Cycles: 1 Cycles: 1
Q Cycle Activity: Q1 Q2 Q3 Q4 Q Cycle Activity: Q1 Q2 Q3 Q4
Decode Read Process Write to Decode Read Process Write to
literal 'k' data W literal "k" data W
Example CLRWDT
Before Instruction
WDT counter = ?
After Instruction
WDT counter = 0x00
WDT prescaler= 0
TO = 1
PD = 1
DECF Decrement f
Example HERE DECFSZ CNT, 1
Syntax: [label] DECF f,d
GOTO LOOP
Operands: 0 ≤ f ≤ 127 CONTINUE •
d ∈ [0,1] •
•
Operation: (f) - 1 → (destination) Before Instruction
Status Affected: Z PC = address HERE
After Instruction
Encoding: 00 0011 dfff ffff
CNT = CNT - 1
Description: Decrement register 'f'. If 'd' is 0 the if CNT = 0,
result is stored in the W register. If 'd' is PC = address CONTINUE
1 the result is stored back in register 'f'.
if CNT ≠ 0,
Words: 1 PC = address HERE+1
Cycles: 1
Q Cycle Activity: Q1 Q2 Q3 Q4
Decode Read Process Write to
register data destination
'f'
Words: 1 Words: 1
Cycles: 2 Cycles: 1
Q Cycle Activity: Q1 Q2 Q3 Q4 Q Cycle Activity: Q1 Q2 Q3 Q4
1st Cycle Decode Read Process Write to Decode Read Process Write to
literal 'k' data PC register data destination
'f'
2nd Cycle No- No- No- No-
Operation Operation Operation Operation
Example INCF CNT, 1
Example GOTO THERE Before Instruction
CNT = 0xFF
After Instruction
Z = 0
PC = Address THERE
After Instruction
CNT = 0x00
Z = 1
Cycles: 1(2)
Example IORLW 0x35
Q Cycle Activity: Q1 Q2 Q3 Q4
Before Instruction
Decode Read Process Write to
W = 0x9A
register 'f' data destination
After Instruction
If Skip: (2nd Cycle) W = 0xBF
Z = 1
Q1 Q2 Q3 Q4
No- No- No- No-
Operation Operation Operation Operation
Example RETFIE
After Interrupt
PC = TOS
GIE = 1
1st Cycle Decode Read No- Write to W, 2nd Cycle No- No- No- No-
literal 'k' Operation Pop from Operation Operation Operation Operation
the Stack
Before Instruction
W = 0x07
After Instruction
W = value of k8
RLF Rotate Left f through Carry RRF Rotate Right f through Carry
Syntax: [ label ] RLF f,d Syntax: [ label ] RRF f,d
Operands: 0 ≤ f ≤ 127 Operands: 0 ≤ f ≤ 127
d ∈ [0,1] d ∈ [0,1]
Operation: See description below Operation: See description below
Status Affected: C Status Affected: C
Encoding: 00 1101 dfff ffff Encoding: 00 1100 dfff ffff
Description: The contents of register 'f' are rotated Description: The contents of register 'f' are rotated
one bit to the left through the Carry one bit to the right through the Carry
Flag. If 'd' is 0 the result is placed in the Flag. If 'd' is 0 the result is placed in the
W register. If 'd' is 1 the result is stored W register. If 'd' is 1 the result is placed
back in register 'f'. back in register 'f'.
C Register f C Register f
Words: 1 Words: 1
Cycles: 1 Cycles: 1
Q Cycle Activity: Q1 Q2 Q3 Q4 Q Cycle Activity: Q1 Q2 Q3 Q4
Decode Read Process Write to Decode Read Process Write to
register data destination register data destination
'f' 'f'
DS30234D-page 162
ICEPIC Low-Cost
In-Circuit Emulator
✔ ✔ ✔ ✔ ✔ ✔
PIC16C6X
Emulator Products
MPLAB
Integrated
Development
Environment ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔
MPLAB C
Compiler ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔
fuzzyTECH-MP
Explorer/Edition
Fuzzy Logic
Dev. Tool ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔
Software Tools
MP-DriveWay
Applications
Code Generator ✔ ✔ ✔ ✔ ✔ ✔
Total Endurance
Software Model ✔
PICSTART
DEVELOPMENT TOOLS FROM MICROCHIP
Programmers
Programmer ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔ ✔
KEELOQ
Programmer ✔
SEEVAL
Designers Kit ✔
PICDEM-1 ✔ ✔ ✔ ✔
PICDEM-2 ✔ ✔
PICDEM-3 ✔
Demo Boards
KEELOQ
✔
D041 with Schmitt Trigger buffer 0.85VDD - VDD V For entire VDD range
D042 MCLR 0.85VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 250 † 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current (Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-
impedance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS and
LP osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D080A - - 0.6 V IOL = 7.0 mA, VDD = 4.5V,
-40°C to +125°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
D083A - - 0.6 V IOL = 1.2 mA, VDD = 4.5V,
-40°C to +125°C
* The parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified
levels represent normal operating conditions. Higher leakage current may be measured at different input volt-
ages.
3: Negative current is defined as current sourced by the pin.
VDD/2
RL
CL CL
Pin Pin
VSS VSS
RL = 464Ω
CL = 50 pF for all pins except OSC2/CLKOUT
15 pF for OSC2 output
OSC1
1 3 3
4 4
2
CLKOUT
Q4 Q1 Q2 Q3
OSC1
10 11
CLKOUT
12
13 19 18
14
16
I/O Pin
(input)
17 15
20, 21
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
TABLE 16-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP
TIMER REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30* TmcL MCLR Pulse Width (low) 200 — — ns VDD = 5V, -40˚C to +125˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +125˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024TOSC — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period 28 72 132 ms VDD = 5V, -40˚C to +125˚C
34* TIOZ I/O Hi-impedance from MCLR Low — — 100 ns
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
TMR0
0.850
0 10 20 25 30 40 50 60 70
T (°C)
R = 3.3k
4.5
R = 4.7k 7.0
4.0
6.0 R = 4.7k
3.5
5.0
3.0
Fosc (MHz)
Fosc (MHz)
R = 10k
2.5 4.0
2.0 R = 10k
3.0
1.5
2.0
1.0
Cext = 300 pF, T = 25°C
Cext = 20 pF, T = 25°C
1.0
Data based on matrix samples. See first page of this section for details.
0.5
R = 100k
R = 100k
0.0 0.0
3.0 3.5 4.0 4.5 5.0 5.5 6.0 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD (Volts) VDD (Volts)
FIGURE 17-3: TYPICAL RC OSCILLATOR FIGURE 17-5: TYPICAL IPD VS. VDD
FREQUENCY VS. VDD WATCHDOG TIMER
DISABLED 25°C
2.0
0.6
1.8 R = 3.3k
1.6
0.5
1.4
R = 4.7k
1.2 0.4
Fosc (MHz)
1.0
IPD (µA)
0.3
0.8
R = 10k
0.6
0.2
0.4
Cext = 100 pF, T = 25°C
0.2
R = 100k 0.1
0.0
3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD (Volts) 0.0
3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD (Volts)
FIGURE 17-6: TYPICAL IPD VS. VDD FIGURE 17-7: MAXIMUM IPD VS. VDD
WATCHDOG TIMER ENABLED WATCHDOG DISABLED
25°C
14
25
125°C
12
20
10
15
8
IPD (µA)
IPD (µA)
6 10
85°C
4
70°C
Data based on matrix samples. See first page of this section for details.
5
2
0°C
-40°C
0 -55°C
0 3.0 3.5 4.0 4.5 5.0 5.5 6.0
3.0 3.5 4.0 4.5 5.0 5.5 6.0 VDD (Volts)
VDD (Volts)
-55°C
40 -40°C 2.00
1.80 Max (-40°C to 85°C)
35
1.60
VTH (Volts)
25°C, Typ
30 1.40
125°C
1.20
IPD (µA)
25
1.00 Min (-40°C to 85°C)
20 0.80
0°C 0.60
15 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
70°C
85°C VDD (Volts)
10
5
Data based on matrix samples. See first page of this section for details.
0
3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD (Volts)
3.0
VIH, VIL (Volts)
2.5
2.0
0.0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD (Volts)
These pins have Schmitt Trigger input buffers.
Data based on matrix samples. See first page of this section for details.
FIGURE 17-11: VTH (INPUT THRESHOLD VOLTAGE) OF OSC1 INPUT (IN XT, HS, AND LP MODES)
VS. VDD
3.2
Min (-40°C to 85°C)
3.0
2.8
2.6
VTH (Volts)
2.4
2.2
2.0
1.8
1.6
1.4
1.2
1.0
3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5
VDD (Volts)
10,000
6.0
5.5
5.0
4.5
4.0
3.5
3.0
1,000
IDD (µA)
100
10
Data based on matrix samples. See first page of this section for details.
1
10,000 100,000 1,000,000 10,000,000 100,000,000
Frequency (Hz)
FIGURE 17-13: MAXIMUM IDD VS. FREQUENCY (EXTERNAL CLOCK, -40° TO +85°C)
10,000
6.0
5.5
5.0
4.5
4.0
3.5
3.0
1,000
IDD (µA)
100
10
10,000 100,000 1,000,000 10,000,000 100,000,000
Frequency (Hz)
FIGURE 17-14: MAXIMUM IDD VS. FREQUENCY (EXTERNAL CLOCK, -55° TO +125°C)
10,000
6.0
5.5
5.0
4.5
4.0
3.5
3.0
1,000
IDD (µA)
100
Data based on matrix samples. See first page of this section for details.
10
10,000 100,000 1,000,000 10,000,000 100,000,000
Frequency (Hz)
45
8000
40
7000
Max. -40°C
35 6000
WDT period (ms)
gm (µA/V)
30 5000
Max. 85°C
25 4000
Typ. 25°C
Max. 70°C
3000
20
Typ. 25°C
MIn. 85°C
2000
15
Min. 0°C
1000
10
Min. -40°C 0
5 2 3 4 5 6 7
2 3 4 5 6 7 VDD (Volts)
VDD (Volts)
FIGURE 17-17: TRANSCONDUCTANCE (gm) FIGURE 17-19: IOH VS. VOH, VDD = 3V
OF LP OSCILLATOR VS. VDD
0
225
200 -5
MIn. 85°C
Max. -40°C
175
150 -10
Typ. 25°C
IOH (mA)
gm (µA/V)
125
Typ. 25°C
100 -15
MIn. 85°C
75
50
-20
Data based on matrix samples. See first page of this section for details.
25
Max. -40°C
0
3.0 3.5 4.0 4.5 5.0 5.5 6.0 -25
VDD (Volts) 0 0.5 1.0 1.5 2.0 2.5 3.0
VOH (Volts)
2500 0
-5
Max. -40°C
200 -10
-15
IOH (mA)
-20
1500 Min @ 85°C
gm (µA/V)
-35
MIn. 85°C
-40
500 Max @ -40°C
-45
-50
0 0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0
2 3 4 5 6 7
VDD (Volts) VOH (Volts)
FIGURE 17-21: IOL VS. VOL, VDD = 3V FIGURE 17-22: IOL VS. VOL, VDD = 5V
35 90
Min @ -40°C 80
Min @ -40°C
30
70
25
60
Typ @ 25°C
Typ @ 25°C
20
IOL (mA)
50
IOL (mA)
Min @ +85°C
40
15 Min @ +85°C
30
10
20
Data based on matrix samples. See first page of this section for details.
10
0 0
0.0 0.5 1.0 1.5 2.0 2.5 3.0 0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0
VOL (Volts)
VOL (Volts)
D041 with Schmitt Trigger buffer 0.8VDD - VDD For entire VDD range
D042 MCLR 0.8VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 200 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current (Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-
impedance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS and
LP osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
Output High Voltage
D090 I/O ports (Note 3) VOH VDD-0.7 - - V IOH = -3.0 mA, VDD = 4.5V,
-40°C to +85°C
D092 OSC2/CLKOUT (RC osc config) VDD-0.7 - - V IOH = -1.3 mA, VDD = 4.5V,
-40°C to +85°C
D150* Open-Drain High Voltage VOD - - 14 V RA4 pin
* These parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and
are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified lev-
els represent normal operating conditions. Higher leakage current may be measured at different input voltages.
3: Negative current is defined as current sourced by the pin.
RL
Pin CL
CL VSS
Pin
VSS
RL = 464Ω Note 1: PORTD and PORTE are not imple-
mented on the PIC16C62.
CL = 50 pF for all pins except OSC2/CLKOUT
but including D and E outputs as ports
15 pF for OSC2 output
OSC1
1 3 3
4 4
2
CLKOUT
Q4 Q1 Q2 Q3
OSC1
10 11
CLKOUT
13 12
19 18
14 16
I/O Pin
(input)
17 15
20, 21
Note: Refer to Figure 18-1 for load conditions.
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
TABLE 18-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP
TIMER REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30* TmcL MCLR Pulse Width (low) 100 — — ns VDD = 5V, -40˚C to +85˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +85˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024TOSC — — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period 28 72 132 ms VDD = 5V, -40˚C to +85˚C
34* TIOZ I/O Hi-impedance from MCLR Low — — 100 ns
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
RC0/T1OSI/T1CKI
45 46
47 48
TMR0 or
TMR1
RC2/CCP1
(Capture Mode)
50 51
52
RC2/CCP1
(Compare or
PWM Mode) 53 54
PIC16LC62/64 20 — — ns
PIC16LC62/64 20 — — ns
RE2/CS
RE0/RD
RE1/WR
65
RD7:RD0
62
64
63
Note: Refer to Figure 18-1 for load conditions
SS
70
SCK
(CKP = 0)
71 72
78 79
SCK
(CKP = 1)
80 79 78
SDO
75, 76 77
SDI
74
73
SCL
91 93
90 92
SDA
START STOP
Condition Condition
SDA
Out
Note: Refer to Figure 18-1 for load conditions
RC VDD: 4.0V to 6.0V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 2.5V to 6.0V VDD: 4.0V to 6.0V
IDD: 5 mA max. at 5.5V IDD: 2.0 mA typ. at 5.5V IDD: 2.0 mA typ. at 5.5V IDD: 3.8 mA max. at 3.0V IDD: 5 mA max. at 5.5V
IPD: 16 µA max. at 4V IPD: 1.5 µA typ. at 4V IPD: 1.5 µA typ. at 4V IPD: 5 µA max. at 3V IPD: 16 µA max. at 4V
Freq:4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq:4 MHz max.
XT VDD: 4.0V to 6.0V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 2.5V to 6.0V VDD: 4.0V to 6.0V
IDD: 5 mA max. at 5.5V IDD: 2.0 mA typ. at 5.5V IDD: 2.0 mA typ. at 5.5V IDD: 3.8 mA max. at 3.0V IDD: 5 mA max. at 5.5V
IPD: 16 µA max. at 4V IPD: 1.5 µA typ. at 4V IPD: 1.5 µA typ. at 4V IPD: 5 µA max. at 3.0V IPD: 16 µA max. at 4V
Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max.
HS VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V
IDD: 13.5 mA typ. at 5.5V IDD: 10 mA max. at 5.5V IDD: 20 mA max. at 5.5V Not recommended for use IDD: 20 mA max. at 5.5V
IPD: 1.5 µA typ. at 4.5V IPD: 1.5 µA typ. at 4.5V IPD: 1.5 µA typ. at 4.5V in HS mode IPD: 1.5 µA typ. at 4.5V
Freq: 4 MHz max. Freq: 10 MHz max. Freq: 20 MHz max. Freq: 20 MHz max.
LP VDD: 4.0V to 6.0V VDD: 2.5V to 6.0V VDD: 2.5V to 6.0V
IDD: 52.5 µA typ. IDD: 48 µA max. at 32 IDD: 48 µA max.
Not recommended for Not recommended for
at 32 kHz, 4.0V kHz, 3.0V at 32 kHz, 3.0V
use in LP mode use in LP mode
IPD: 0.9 µA typ. at 4.0V IPD: 5 µA max. at 3.0V IPD: 5 µA max. at 3.0V
Freq: 200 kHz max. Freq: 200 kHz max. Freq: 200 kHz max.
The shaded sections indicate oscillator selections which are tested for functionality, but not for MIN/MAX specifications. It is recommended
that the user select the device type that ensures the specifications required.
D015* Brown-out Reset Current ∆ IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 10.5 42 µA VDD = 4.0V, WDT enabled, -40°C to +85°C
D021 (Note 3, 5) - 1.5 16 µA VDD = 4.0V, WDT disabled, -0°C to +70°C
D021A - 1.5 19 µA VDD = 4.0V, WDT disabled, -40°C to +85°C
D021B - 2.5 19 µA VDD = 4.0V, WDT disabled, -40°C to +125°C
D023* Brown-out Reset Current ∆ IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and
are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD
MCLR = VDD; WDT enabled/disabled as specified.
3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 7.5 30 µA VDD = 3.0V, WDT enabled, -40°C to +85°C
D021 (Note 3, 5) - 0.9 5 µA VDD = 3.0V, WDT disabled, 0°C to +70°C
D021A - 0.9 5 µA VDD = 3.0V, WDT disabled, -40°C to +85°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and
are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD
MCLR = VDD; WDT enabled/disabled as specified.
3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be added
to the base IDD or IPD measurement.
D041 with Schmitt Trigger buffer 0.8VDD - VDD V For entire VDD range
D042 MCLR 0.8VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 250 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current (Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-imped-
ance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS and LP
osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D080A - - 0.6 V IOL = 7.0 mA, VDD = 4.5V,
-40°C to +125°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
D083A - - 0.6 V IOL = 1.2 mA, VDD = 4.5V,
-40°C to +125°C
* These parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and
are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified lev-
els represent normal operating conditions. Higher leakage current may be measured at different input voltages.
3: Negative current is defined as current sourced by the pin.
VDD/2
RL Pin CL
VSS
CL
Pin
VSS
RL = 464Ω
CL = 50 pF for all pins except OSC2/CLKOUT
but including D and E outputs as ports
Note 1: PORTD and PORTE are not
implemented on the 15 pF for OSC2 output
PIC16C62A/R62.
OSC1
1 3 3
4 4
2
CLKOUT
Q4 Q1 Q2 Q3
OSC1
10 11
CLKOUT
13 12
19 18
14
16
I/O Pin
(input)
17 15
20, 21
Note: Refer to Figure 19-1 for load conditions.
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
BVDD
VDD
35
TABLE 19-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER,
AND BROWN-OUT RESET REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30 TmcL MCLR Pulse Width (low) 2 — — µs VDD = 5V, -40˚C to +125˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +125˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024TOSC — — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period 28 72 132 ms VDD = 5V, -40˚C to +125˚C
34 TIOZ I/O Hi-impedance from MCLR Low — — 2.1 µs
or WDT Reset
35 TBOR Brown-out Reset Pulse Width 100 — — µs VDD ≤ BVDD (param. D005)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
RC0/T1OSO/T1CKI
45 46
47 48
TMR0 or
TMR1
RC2/CCP1
(Capture Mode)
50 51
52
RC2/CCP1
(Compare or
PWM Mode) 53 54
RE2/CS
RE0/RD
RE1/WR
65
RD7:RD0
62
64
63
Note: Refer to Figure 19-1 for load conditions
25 — — ns Extended
Range Only
63* TwrH2dtI WR↑ or CS↑ to data–in invalid (hold PIC16C64A/R64 20 — — ns
time) PIC16LC64A/R64 35 — — ns
64 TrdL2dtV RD↓ and CS↓ to data–out valid — — 80 ns
— — 90 ns Extended
Range Only
65* TrdH2dtI RD↑ or CS↑ to data–out invalid 10 — 30 ns
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
SS
70
SCK
(CKP = 0)
71 72
78 79
SCK
(CKP = 1)
79 78
80
SDO
75, 76 77
SDI
74
73
SCL
91 93
90 92
SDA
START STOP
Condition Condition
SDA
Out
Note: Refer to Figure 19-1 for load conditions
NOTES:
RC VDD: 4.0V to 6.0V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 3.0V to 6.0V VDD: 4.0V to 6.0V
IDD: 5 mA max. at 5.5V IDD: 2.7 mA typ. at 5.5V IDD: 2.7 mA typ. at 5.5V IDD: 3.8 mA max. at 3V IDD: 5 mA max. at 5.5V
IPD: 21 µA max. at 4V IPD: 1.5 µA typ. at 4V IPD: 1.5 µA typ. at 4V IPD: 800 µA max. at 3V IPD: 21 µA max. at 4V
Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max.
XT VDD: 4.0V to 6.0V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 3.0V to 6.0V VDD: 4.0V to 6.0V
IDD: 5 mA max. at 5.5V IDD: 2.7 mA typ. at 5.5V IDD: 2.7 mA typ. at 5.5V IDD: 3.8 mA max. at 3V IDD: 5 mA max. at 5.5V
IPD: 21 µA max. at 4V IPD: 1.5 µA typ. at 4V IPD: 1.5 µA typ. at 4V IPD: 800 µA max. at 3V IPD: 21 µA max. at 4V
Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max. Freq: 4 MHz max.
HS VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V VDD: 4.5V to 5.5V
IDD: 13.5 mA typ. at IDD: 15 mA max. at 5.5V IDD: 30 mA max. at IDD: 30 mA max. at 5.5V
Not recommended for
5.5V 5.5V
use in HS mode
IPD: 1.5 µA typ. at 4.5V IPD 1.0 µA typ. at 4.5V IPD: 1.5 µA typ. at 4.5V IPD: 1.5 µA typ. at 4.5V
Freq: 4 MHz max. Freq: 10 MHz max. Freq: 20 MHz max. Freq: 20 MHz max.
LP VDD: 4.0V to 6.0V VDD: 3.0V to 6.0V VDD: 3.0V to 6.0V
IDD: 52.5 µA typ. IDD: 105 µA max. IDD: 105 µA max.
at 32 kHz, 4.0V Not recommended for Not recommended for at 32 kHz, 3.0V at 32 kHz, 3.0V
IPD: 0.9 µA typ. at 4.0V use in LP mode use in LP mode IPD: 800 µA max. at IPD: 800 µA max. at
Freq: 200 kHz max. 3.0V 3.0V
Freq: 200 kHz max. Freq: 200 kHz max.
The shaded sections indicate oscillator selections which are tested for functionality, but not for MIN/MAX specifications. It is recom-
mended that the user select the device type that ensures the specifications required.
D041 with Schmitt Trigger buffer 0.8VDD - VDD For entire VDD range
D042 MCLR 0.8VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7 VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 250 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current
(Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-
impedance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS, and
LP osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
Output High Voltage
D090 I/O ports (Note 3) VOH VDD-0.7 - - V IOH = -3.0 mA, VDD = 4.5V,
-40°C to +85°C
D092 OSC2/CLKOUT (RC osc config) VDD-0.7 - - V IOH = -1.3 mA, VDD = 4.5V,
-40°C to +85°C
D150* Open-Drain High Voltage VOD - - 14 V RA4 pin
* These parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified
levels represent normal operating conditions. Higher leakage current may be measured at different input volt-
ages.
3: Negative current is defined as current sourced by the pin.
VDD/2
RL Pin CL
VSS
CL
Pin
RL = 464Ω
VSS CL = 50 pF for all pins except OSC2/CLKOUT
but including D and E outputs as ports
15 pF for OSC2 output
OSC1
1 3 3
4 4
2
CLKOUT
OSC1
10 11
CLKOUT
13 12
14 19 18
16
I/O Pin
(input)
17 15
20, 21
Note: Refer to Figure 20-1 for load conditions.
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
TABLE 20-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP
TIMER REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30* TmcL MCLR Pulse Width (low) 100 — — ns VDD = 5V, -40˚C to +85˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +85˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024TOSC — — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period or WDT 28 72 132 ms VDD = 5V, -40˚C to +85˚C
reset
34 TIOZ I/O Hi-impedance from MCLR Low — — 100 ns
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
RC0/T1OSO/T1CKI
45 46
47 48
TMR0 or
TMR1
Note: Refer to Figure 20-1 for load conditions.
RC1/T1OSI/CCP2
and RC2/CCP1
(Capture Mode)
50 51
52
RC1/T1OSI/CCP2
and RC2/CCP1
(Compare or
PWM Mode) 53 54
RE2/CS
RE0/RD
RE1/WR
65
RD7:RD0
62
64
63
Note: Refer to Figure 20-1 for load conditions
SS
70
SCK
(CKP = 0)
71 72
78 79
SCK
(CKP = 1)
79 78
80
SDO
75, 76 77
SDI
74
73
SCL
91 93
90 92
SDA
START STOP
Condition Condition
91 92
SDA
In
110
109 109
SDA
Out
RC6/TX/CK
pin 121
121
RC7/RX/DT
pin
120
122
Note: Refer to Figure 20-1 for load conditions
RC6/TX/CK
pin 125
RC7/RX/DT
pin
126
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 10.5 42 µA VDD = 4.0V, WDT enabled,-40°C to +85°C
D021 (Note 3, 5) - 1.5 16 µA VDD = 4.0V, WDT disabled,-0°C to +70°C
D021A - 1.5 19 µA VDD = 4.0V, WDT disabled,-40°C to +85°C
D021B - 2.5 19 µA VDD = 4.0V, WDT disabled,-40°C to +125°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and
are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,
MCLR = VDD; WDT enabled/disabled as specified.
3: The power down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 7.5 30 µA VDD = 3.0V, WDT enabled, -40°C to +85°C
D021 (Note 3, 5) - 0.9 5 µA VDD = 3.0V, WDT disabled, 0°C to +70°C
D021A - 0.9 5 µA VDD = 3.0V, WDT disabled, -40°C to +85°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,
MCLR = VDD; WDT enabled/disabled as specified.
3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D041 with Schmitt Trigger buffer 0.8VDD - VDD V For entire VDD range
D042 MCLR 0.8VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 250 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current (Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-
impedance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS and
LP osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D080A - - 0.6 V IOL = 7.0 mA, VDD = 4.5V,
-40°C to +125°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
D083A - - 0.6 V IOL = 1.2 mA, VDD = 4.5V,
-40°C to +125°C
* These parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified
levels represent normal operating conditions. Higher leakage current may be measured at different input volt-
ages.
3: Negative current is defined as current sourced by the pin.
VDD/2
RL Pin CL
VSS
CL
Pin
RL = 464Ω
VSS CL = 50 pF for all pins except OSC2/CLKOUT
but including D and E outputs as ports
Note 1: PORTD and PORTE are not imple-
mented on the PIC16C63. 15 pF for OSC2 output
OSC1
1 3 3
4 4
2
CLKOUT
OSC1
10 11
CLKOUT
13 12
14 19 18
16
I/O Pin
(input)
17 15
20, 21
Note: Refer to Figure 21-1 for load conditions.
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
BVDD
VDD
35
TABLE 21-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER,
AND BROWN-OUT RESET REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30 TmcL MCLR Pulse Width (low) 2 — — µs VDD = 5V, -40˚C to +125˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +125˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024 TOSC — — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period 28 72 132 ms VDD = 5V, -40˚C to +125˚C
34 TIOZ I/O Hi-impedance from MCLR Low — — 2.1 µs
or WDT reset
35 TBOR Brown-out Reset Pulse Width 100 — — µs VDD ≤ BVDD (D005)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
RC0/T1OSO/T1CKI
45 46
47 48
TMR0 or
TMR1
Note: Refer to Figure 21-1 for load conditions.
RC1/T1OSI/CCP2
and RC2/CCP1
(Capture Mode)
50 51
52
RC1/T1OSI/CCP2
and RC2/CCP1
(Compare or
PWM Mode) 53 54
RE2/CS
RE0/RD
RE1/WR
65
RD7:RD0
62
64
63
Note: Refer to Figure 21-1 for load conditions
25 — — ns Extended
Range Only
63* TwrH2dtI WR↑ or CS↑ to data–in invalid (hold PIC16C65A 20 — — ns
time) PIC16LC65A 35 — — ns
64 TrdL2dtV RD↓ and CS↓ to data–out valid — — 80 ns
— — 90 ns Extended
Range Only
65* TrdH2dtI RD↑ or CS↑ to data–out invalid 10 — 30 ns
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
SS
70
SCK
(CKP = 0)
71 72
78 79
SCK
(CKP = 1)
79 78
80
SDO
75, 76 77
SDI
74
73
SCL
91 93
90 92
SDA
START STOP
Condition Condition
91 92
SDA
In
110
109 109
SDA
Out
Note: Refer to Figure 21-1 for load conditions
RC6/TX/CK
pin 121 121
RC7/RX/DT
pin
120
122
Note: Refer to Figure 21-1 for load conditions
RC6/TX/CK
pin 125
RC7/RX/DT
pin
126
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 10.5 42 µA VDD = 4.0V, WDT enabled,-40°C to +85°C
D021 (Note 3, 5) - 1.5 16 µA VDD = 4.0V, WDT disabled,-0°C to +70°C
D021A - 1.5 19 µA VDD = 4.0V, WDT disabled,-40°C to +85°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,
MCLR = VDD; WDT enabled/disabled as specified.
3: The power down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 7.5 30 µA VDD = 3.0V, WDT enabled, -40°C to +85°C
D021 (Note 3, 5) - 0.9 5 µA VDD = 3.0V, WDT disabled, 0°C to +70°C
D021A - 0.9 5 µA VDD = 3.0V, WDT disabled, -40°C to +85°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,
MCLR = VDD; WDT enabled/disabled as specified.
3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D041 with Schmitt Trigger buffer 0.8VDD - VDD V For entire VDD range
D042 MCLR 0.8VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 250 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current (Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-
impedance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS and
LP osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
Output High Voltage
D090 I/O ports (Note 3) VOH VDD-0.7 - - V IOH = -3.0 mA, VDD = 4.5V,
-40°C to +85°C
D092 OSC2/CLKOUT (RC osc config) VDD-0.7 - - V IOH = -1.3 mA, VDD = 4.5V,
-40°C to +85°C
D150* Open-Drain High Voltage VOD - - 14 V RA4 pin
* These parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified
levels represent normal operating conditions. Higher leakage current may be measured at different input volt-
ages.
3: Negative current is defined as current sourced by the pin.
VDD/2
RL Pin CL
VSS
CL
Pin
RL = 464Ω
VSS CL = 50 pF for all pins except OSC2/CLKOUT
but including D and E outputs as ports
Note 1: PORTD and PORTE are not imple-
mented on the PIC16CR63. 15 pF for OSC2 output
OSC1
1 3 3
4 4
2
CLKOUT
OSC1
10 11
CLKOUT
13 12
14 19 18
16
I/O Pin
(input)
17 15
20, 21
Note: Refer to Figure 22-1 for load conditions.
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
BVDD
VDD
35
TABLE 22-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER,
AND BROWN-OUT RESET REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30 TmcL MCLR Pulse Width (low) 2 — — µs VDD = 5V, -40˚C to +125˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +125˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024 TOSC — — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period 28 72 132 ms VDD = 5V, -40˚C to +125˚C
34 TIOZ I/O Hi-impedance from MCLR Low — — 2.1 µs
or WDT reset
35 TBOR Brown-out Reset Pulse Width 100 — — µs VDD ≤ BVDD (D005)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
RC0/T1OSO/T1CKI
45 46
47 48
TMR0 or
TMR1
Note: Refer to Figure 22-1 for load conditions.
RC1/T1OSI/CCP2
and RC2/CCP1
(Capture Mode)
50 51
52
RC1/T1OSI/CCP2
and RC2/CCP1
(Compare or
PWM Mode) 53 54
RE2/CS
RE0/RD
RE1/WR
65
RD7:RD0
62
64
63
Note: Refer to Figure 22-1 for load conditions
SS
70
SCK
(CKP = 0)
71 72
78 79
SCK
(CKP = 1)
79 78
80
SDO
75, 76 77
SDI
74
73
SCL
91 93
90 92
SDA
START STOP
Condition Condition
91 92
SDA
In
110
109 109
SDA
Out
Note: Refer to Figure 22-1 for load conditions
RC6/TX/CK
pin 121 121
RC7/RX/DT
pin
120
122
Note: Refer to Figure 22-1 for load conditions
RC6/TX/CK
pin 125
RC7/RX/DT
pin
126
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 10.5 42 µA VDD = 4.0V, WDT enabled,-40°C to +85°C
D021 (Note 3, 5) - 1.5 16 µA VDD = 4.0V, WDT disabled,-0°C to +70°C
D021A - 1.5 19 µA VDD = 4.0V, WDT disabled,-40°C to +85°C
D021B - 2.5 19 µA VDD = 4.0V, WDT disabled,-40°C to +125°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,
MCLR = VDD; WDT enabled/disabled as specified.
3: The power down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D015* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
D020 Power-down Current IPD - 7.5 30 µA VDD = 3.0V, WDT enabled, -40°C to +85°C
D021 (Note 3, 5) - 0.9 5 µA VDD = 3.0V, WDT disabled, 0°C to +70°C
D021A - 0.9 5 µA VDD = 3.0V, WDT disabled, -40°C to +85°C
D023* Brown-out Reset Current ∆IBOR - 350 425 µA BOR enabled, VDD = 5.0V
(Note 6)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: This is the limit to which VDD can be lowered without losing RAM data.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin
loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an
impact on the current consumption.
The test conditions for all IDD measurements in active operation mode are:
OSC1 = external square wave, from rail to rail; all I/O pins tristated, pulled to VDD,
MCLR = VDD; WDT enabled/disabled as specified.
3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is mea-
sured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
4: For RC osc configuration, current through Rext is not included. The current through the resistor can be esti-
mated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
5: Timer1 oscillator (when enabled) adds approximately 20 µA to the specification. This value is from character-
ization and is for design guidance only. This is not tested.
6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be
added to the base IDD or IPD measurement.
D041 with Schmitt Trigger buffer 0.8VDD - VDD V For entire VDD range
D042 MCLR 0.8VDD - VDD V
D042A OSC1 (XT, HS and LP) 0.7VDD - VDD V Note1
D043 OSC1 (in RC mode) 0.9VDD - VDD V
D070 PORTB weak pull-up current IPURB 50 250 400 µA VDD = 5V, VPIN = VSS
Input Leakage Current (Notes 2, 3)
D060 I/O ports IIL - - ±1 µA Vss ≤ VPIN ≤ VDD, Pin at hi-
impedance
D061 MCLR, RA4/T0CKI - - ±5 µA Vss ≤ VPIN ≤ VDD
D063 OSC1 - - ±5 µA Vss ≤ VPIN ≤ VDD, XT, HS and
LP osc configuration
Output Low Voltage
D080 I/O ports VOL - - 0.6 V IOL = 8.5 mA, VDD = 4.5V,
-40°C to +85°C
D080A - - 0.6 V IOL = 7.0 mA, VDD = 4.5V,
-40°C to +125°C
D083 OSC2/CLKOUT (RC osc config) - - 0.6 V IOL = 1.6 mA, VDD = 4.5V,
-40°C to +85°C
D083A - - 0.6 V IOL = 1.2 mA, VDD = 4.5V,
-40°C to +125°C
* These parameters are characterized but not tested.
† Data in “Typ” column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only
and are not tested.
Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the
PIC16C6X be driven with external clock in RC mode.
2: The leakage current on the MCLR/VPP pin is strongly dependent on the applied voltage level. The specified
levels represent normal operating conditions. Higher leakage current may be measured at different input volt-
ages.
3: Negative current is defined as current sourced by the pin.
VDD/2
RL Pin CL
VSS
CL
Pin
RL = 464Ω
VSS CL = 50 pF for all pins except OSC2/CLKOUT
but including D and E outputs as ports
Note 1: PORTD and PORTE are not imple-
mented on the PIC16C66. 15 pF for OSC2 output
OSC1
1 3 3
4 4
2
CLKOUT
OSC1
10 11
CLKOUT
13 12
14 19 18
16
I/O Pin
(input)
17 15
20, 21
Note: Refer to Figure 23-1 for load conditions.
VDD
MCLR
30
Internal
POR
33
PWRT
Time-out 32
OSC
Time-out
Internal
RESET
Watchdog
Timer
RESET
31
34 34
I/O Pins
BVDD
VDD
35
TABLE 23-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER,
AND BROWN-OUT RESET REQUIREMENTS
Parameter Sym Characteristic Min Typ† Max Units Conditions
No.
30 TmcL MCLR Pulse Width (low) 2 — — µs VDD = 5V, -40˚C to +125˚C
31* Twdt Watchdog Timer Time-out Period 7 18 33 ms VDD = 5V, -40˚C to +125˚C
(No Prescaler)
32 Tost Oscillation Start-up Timer Period — 1024 TOSC — — TOSC = OSC1 period
33* Tpwrt Power-up Timer Period 28 72 132 ms VDD = 5V, -40˚C to +125˚C
34 TIOZ I/O Hi-impedance from MCLR Low — — 2.1 µs
or WDT reset
35 TBOR Brown-out Reset Pulse Width 100 — — µs VDD ≤ BVDD (D005)
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
RA4/T0CKI
40 41
42
RC0/T1OSO/T1CKI
45 46
47 48
TMR0 or
TMR1
Note: Refer to Figure 23-1 for load conditions.
RC1/T1OSI/CCP2
and RC2/CCP1
(Capture Mode)
50 51
52
RC1/T1OSI/CCP2
and RC2/CCP1
(Compare or
PWM Mode) 53 54
RE2/CS
RE0/RD
RE1/WR
65
RD7:RD0
62
64
63
Note: Refer to Figure 23-1 for load conditions
25 — — ns Extended
Range Only
63* TwrH2dtI WR↑ or CS↑ to data–in invalid (hold PIC16C67 20 — — ns
time) PIC16LC67 35 — — ns
64 TrdL2dtV RD↓ and CS↓ to data–out valid — — 80 ns
— — 90 ns Extended
Range Only
65* TrdH2dtI RD↑ or CS↑ to data–out invalid 10 — 30 ns
* These parameters are characterized but not tested.
† Data in "Typ" column is at 5V, 25˚C unless otherwise stated. These parameters are for design guidance only and are not
tested.
SS
70
SCK
(CKP = 0)
71 72
78 79
SCK
(CKP = 1)
79 78
80
75, 76
SS
81
SCK
(CKP = 0)
71 72
79
73
SCK
(CKP = 1)
80
78
75, 76
74
SS
70
SCK
(CKP = 0) 83
71 72
78 79
SCK
(CKP = 1)
79 78
80
75, 76 77
74
73
Refer to Figure 23-1 for load conditions.
82
SS
70
SCK 83
(CKP = 0)
71 72
SCK
(CKP = 1)
80
75, 76 77
SDI
MSB IN BIT6 - - - -1 LSB IN
74
SCL
91 93
90 92
SDA
START STOP
Condition Condition
91 92
SDA
In
110
109 109
SDA
Out
Note: Refer to Figure 23-1 for load conditions
RC6/TX/CK
pin 121 121
RC7/RX/DT
pin
120
122
Note: Refer to Figure 23-1 for load conditions
RC6/TX/CK
pin 125
RC7/RX/DT
pin
126
30
25
20
IPD(nA)
15
10
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD(Volts)
85°C
70°C
1.000
IPD(µA)
0.100 25°C
0°C
-40°C
0.010
0.001
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD(Volts)
Fosc(MHz)
IPD(µA)
15
3.5
3.0
10 R = 10k
2.5
2.0
5
1.5
1.0
0 R = 100k
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 0.5
VDD(Volts) 0.0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD(Volts)
25 2.2
R = 3.3k
2.0
IPD(µA)
20 1.8
70°C 1.6
Fosc(MHz)
15 R = 5k
1.4
85°C 1.2
10
1.0
R = 10k
Data based on matrix samples. See first page of this section for details.
5 0.8
0.6
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 0.4
R = 100k
VDD(Volts) 0.2
0.0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD(Volts)
600
R = 5k
500
400
R = 10k
300
200
100 R = 100k
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD(Volts)
1200 30
1000
25
IPD(µA)
IPD(µA)
400 Device in 15
Brown-out
200 Reset 10
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 5
VDD(Volts)
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
The shaded region represents the built-in hysteresis of the VDD(Volts)
brown-out reset circuitry.
1400
1200 45
1000 40
Device NOT in
IPD(µA)
35
800 Brown-out Reset
30
600 Device in
25
IPD(µA)
Brown-out
400 Reset 20
Data based on matrix samples. See first page of this section for details.
200 15
4.3 10
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 5
VDD(Volts)
0
The shaded region represents the built-in hysteresis of the 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
brown-out reset circuitry. VDD(Volts)
2000
6.0V
1800 5.5V
5.0V
1600
4.5V
1400
4.0V
1200
IDD(µA)
3.5V
1000 3.0V
800
2.5V
600
400
200
0
0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5
Frequency(MHz)
Shaded area is
beyond recommended range
FIGURE 24-13: MAXIMUM IDD vs. FREQUENCY (RC MODE @ 22 pF, -40°C TO 85°C)
2000 6.0V
1800 5.5V
5.0V
1600
4.5V
1400
4.0V
Data based on matrix samples. See first page of this section for details.
1200
IDD(µA)
3.5V
1000 3.0V
800
2.5V
600
400
200
0
0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5
Frequency(MHz)
Shaded area is
beyond recommended range
1600
6.0V
1400 5.5V
5.0V
1200 4.5V
4.0V
1000
3.5V
IDD(µA)
3.0V
800
2.5V
600
400
200
0
0 200 400 600 800 1000 1200 1400 1600 1800
Shaded area is Frequency(kHz)
beyond recommended range
FIGURE 24-15: MAXIMUM IDD vs. FREQUENCY (RC MODE @ 100 pF, -40°C TO 85°C)
1600
6.0V
1400 5.5V
Data based on matrix samples. See first page of this section for details.
5.0V
1200 4.5V
4.0V
1000
3.5V
IDD(µA)
3.0V
800
2.5V
600
400
200
0
0 200 400 600 800 1000 1200 1400 1600 1800
Shaded area is Frequency(kHz)
beyond recommended range
1200
6.0V
5.5V
1000 5.0V
4.5V
4.0V
800
3.5V
3.0V
IDD(µA)
600
2.5V
400
200
0
0 100 200 300 400 500 600 700
Frequency(kHz)
FIGURE 24-17: MAXIMUM IDD vs. FREQUENCY (RC MODE @ 300 pF, -40°C TO 85°C)
1200
6.0V
5.5V
1000 5.0V
Data based on matrix samples. See first page of this section for details.
4.5V
4.0V
800
3.5V
3.0V
IDD(µA)
600
2.5V
400
200
0
0 100 200 300 400 500 600 700
Frequency(kHz)
gm(mA/V)
IDD(µA)
3.0V
300 2.0
0 0.0
20 pF 100 pF 300 pF 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0
Capacitance(pF) Shaded area is VDD(Volts)
beyond recommended range
TABLE 24-1: RC OSCILLATOR
FREQUENCIES FIGURE 24-20: TRANSCONDUCTANCE(gm)
OF LP OSCILLATOR vs. VDD
Average 110
Cext Rext
Fosc @ 5V, 25°C 100 Max -40°C
90
22 pF 5k 4.12 MHz ± 1.4% 80
10k 2.35 MHz ± 1.4% 70
gm(µA/V)
Data based on matrix samples. See first page of this section for details.
Shaded areas are VDD(Volts)
5k 501 kHz ± 1.2%
beyond recommended range
10k 269 kHz ± 1.6%
100k 28.3 kHz ± 1.1% FIGURE 24-21: TRANSCONDUCTANCE(gm)
OF XT OSCILLATOR vs. VDD
The percentage variation indicated here is part to
part variation due to normal process distribution. The
1000
variation indicated is ±3 standard deviation from
900 Max -40°C
average value for VDD = 5V.
800
700
gm(µA/V)
70
3.0
60
2.5
Startup Time(Seconds)
50
Startup Time(ms)
2.0
40
32 kHz, 33 pF/33 pF 200 kHz, 68 pF/68 pF
1.5 30
200 kHz, 47 pF/47 pF
20
1.0 1 MHz, 15 pF/15 pF
10 4 MHz, 15 pF/15 pF
0.5 200 kHz, 15 pF/15 pF
0
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
0.0 VDD(Volts)
2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0
VDD(Volts)
1600 6.0V
120
1400 5.5V
100
5.0V
1200
80 4.5V
1000
IDD(µA)
4.0V
60
6.0V 3.5V
800
5.5V
IDD(µA)
40 5.0V 3.0V
4.5V 600
4.0V 2.5V
20 3.5V
3.0V 400
2.5V
0
0 50 100 150 200 200
Frequency(kHz)
0
0.0 0.4 0.8 1.2 1.6 2.0 2.4 2.8 3.2 3.6 4.0
Frequency(MHz)
FIGURE 24-26: MAXIMUM IDD vs. FIGURE 24-28: MAXIMUM IDD vs.
FREQUENCY FREQUENCY
(LP MODE, 85°C TO -40°C) (XT MODE, -40°C TO 85°C)
1800
6.0V
140 1600
5.5V
120 1400
5.0V
80 1000 4.0V
IDD(µA)
5.5V 3.0V
5.0V
Data based on matrix samples. See first page of this section for details.
40 4.5V 600 2.5V
4.0V
3.5V
20 3.0V
400
2.5V
0 200
0 50 100 150 200
Frequency(kHz) 0
0.0 0.4 0.8 1.2 1.6 2.0 2.4 2.8 3.2 3.6 4.0
Frequency(MHz)
4.0
IDD(mA)
3.0
3.0
2.0 6.0V
5.5V
5.0V 2.0 6.0V
1.0 4.5V 5.5V
4.0V 5.0V
1.0 4.5V
0.0 4.0V
1 2 4 6 8 10 12 14 16 18 20
0.0
Frequency(MHz) 1 2 4 6 8 10 12 14 16 18 20
Frequency(MHz)
Data based on matrix samples. See first page of this section for details.
N
α
C
E1 E
eA
Pin No. 1 eB
Indicator
Area
D
S S1
Base
Plane
Seating
Plane L
B1 e1 A1 A2 A
B
D1
E1 E α
C
Pin No. 1 eA
Indicator eB
Area
B2 B1
D
S
Base
Plane
Seating
Plane L
Detail A B3 B
e1 A1 A2 A
D1 Detail A
α
E1 E C
Pin No. 1 eA
Indicator eB
Area
D
S S1
Base
Plane
Seating
Plane L
B1 e1 A1 A2 A
B
D1
e
B
h x 45°
Index
Area
E H α C
Chamfer L
h x 45°
1 2 3
CP Base
Seating Plane
Plane
A1 A
e
B
h x 45°
Index
Area
E H α C
Chamfer L
h x 45°
1 2 3
CP Base
Seating Plane
Plane
A1 A
α C
E1 E
eA
Pin No. 1 eB
Indicator
Area
D
S S1
Base
Plane
Seating
Plane L
B1 e1 A1 A3 A A2
B
D1
E1 E
α C
Pin No. 1
Indicator eA
Area eB
D
D1
Base
Plane
Seating
Plane L
B1 e1 A1 A2 A
B
D2
E1 E
α C
Pin No. 1
Indicator eA
Area eB
D
S S1
Base
Plane
Seating
Plane L
B1 e1 A1 A3 A A2
B
D1
C
E1 E
eA
Pin #1 α eB
Indicator Area
D
S1
S
Base
Plane
Seating A3 A2
Plane L
A1 A
B1 e1
B
D1
N
Index
area
E H
α
C
L
1 2 3
e B
A Base plane
CP
Seating plane
D A1
D 0.812/0.661 N Pics
0.177 1.27 .032/.026
.007 S B D-E S .050
2 Sides -H- 0.177
-A- .007 S B A S
D1 A
A1 2 Sides
-D- 3 9
D3/E3
0.101 Seating
D2 D
.004 Plane
0.38 -C-
3 .015 F-G S 4
3 -G-
8 E2
-F-
E1 E
0.38
.015 F-G S 4
-B-
3 -E- 0.177
.007 S A F-G S
10
0.812/0.661
0.254 0.254 3
.032/.026
.010 Max 11 .010 Max 11
1.524
0.508 0.508
2 -H- .060 Min
.020 .020 -H- 2
6
6
-C-
5
1.651 1.651 0.64 Min 0.533/0.331
.065 .065 .025 .021/.013
R 1.14/0.64 R 1.14/0.64
.045/.025 .045/.025 0.177
, D-E S
.007 M A F-G S
0.20 M C A-B S D S
4 D
0.20 M H A-B S D S
D1 5 7
0.05 mm/mm A-B 0.20 min.
D3
0.13 R min.
Index
area 6 PARTING
LINE
0.13/0.30 R
9
b α
L
C
E3 E1 E
1.60 Ref.
0.20 M C A-B S D S
4
TYP 4x
10
0.20 M H A-B S D S
e B 5 7
0.05 mm/mm D
A2 A
Base
Plane Seating
Plane
A1
11°/13°(4x)
Pin#1 Pin#1
2 2 0° Min
E E1
Θ
11°/13°(4x)
Detail B
e
3.0ø (0.118ø) Ref. R1 0.08 Min
Option 1 (TOP side) R 0.08/0.20
Option 2 (TOP side)
Gage Plane
A1 0.250
Base Metal Lead Finish
A2 A b S
L 0.20
L Min
Detail A c c1 L1
Detail B
1.00 Ref. 1.00 Ref
b1
Detail A Detail B
MMMMMMMMMMMMM PIC16C61-04/P
XXXXXXXXXXXXXXXX
AABBCDE 9450CBA
MMMMMMMMMM PIC16C61
XXXXXXXXXXXX -20/SO
XXXXXXXXXXXX
AABBCDE 9449CBA
MMMMMM PIC16C61
XXXXXXXX /JW
AABBCDE 9440CBT
XXXXXXXXXXXXXXXXX PIC16C63-04I/SP
XXXXXXXXXXXXXXXXX
AABBCAE 9452CAN
Note: In the event the full Microchip part number cannot be marked on one
line, it will be carried over to the next line thus limiting the number of
available characters for customer specific information.
* Standard OTP marking consists of Microchip part number, year code, week code,
facility code, mask revision number, and assembly code. For OTP marking beyond
this, certain price adders apply. Please check with your Microchip Sales Office.
For QTP devices, any special marking adders are included in QTP price.
MMMMMMMMMMMMMMMMMMXX PIC16C62-20/S0111
XXXXXXXXXXXXXXXXXXXX
AABBCAE 9515SBA
XXXXXXXXXXXXXX PIC16C62/JW
XXXXXXXXXXXXXX
AABBCDE 9517SBT
XXXXXXXXXXX PIC16C66/JW
XXXXXXXXXXX
AABBCDE 9517CAT
XXXXXXXXXXXX PIC16C62
XXXXXXXXXXXX 20I/SS025
AABBCAE 9517SBP
MMMMMMMMMMMMMM PIC16C65-04/P
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXX
AABBCDE 9510CAA
Note: In the event the full Microchip part number cannot be marked on one
line, it will be carried over to the next line thus limiting the number of
available characters for customer specific information.
* Standard OTP marking consists of Microchip part number, year code, week code,
facility code, mask revision number, and assembly code. For OTP marking beyond
this, certain price adders apply. Please check with your Microchip Sales Office.
For QTP devices, any special marking adders are included in QTP price.
MMMMMMMMM PIC16C67/JW
XXXXXXXXXXX
XXXXXXXXXXX
AABBCDE 9450CAT
MMMMMMMM PIC16C64
XXXXXXXXXX -20/L
XXXXXXXXXX
AABBCDE 9442CAN
MMMMMMMM PIC16C64
XXXXXXXXXX -04/PQ
XXXXXXXXXX
AABBCDE 9444CAP
MMMMMMMM PIC16C64A
XXXXXXXXXX -10/TQ
XXXXXXXXXX
AABBCDE AABBCDE
Note: In the event the full Microchip part number cannot be marked on one
line, it will be carried over to the next line thus limiting the number of
available characters for customer specific information.
* Standard OTP marking consists of Microchip part number, year code, week code,
facility code, mask revision number, and assembly code. For OTP marking beyond
this, certain price adders apply. Please check with your Microchip Sales Office.
For QTP devices, any special marking adders are included in QTP price.
All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high
I/O current capability. All PIC16C5XX Family devices use serial programming with clock pin RB6 and data pin RB7.
Note 1: Please contact your local Microchip sales office for availability of these devices.
All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high
I/O current capability. All PIC16C62X and PIC16C64X Family devices use serial programming with clock pin RB6 and data pin RB7.
Features In-Circuit Serial Programming Yes Yes Yes Yes Yes Yes
Brown-out Reset Yes — Yes Yes Yes Yes
Packages 18-pin DIP, 18-pin DIP, 18-pin DIP, 18-pin DIP, 28-pin SDIP, 28-pin SDIP,
SOIC; SOIC SOIC; SOIC; SOIC, SSOP SOIC, SSOP
20-pin SSOP 20-pin SSOP 20-pin SSOP
Serial Port(s) (SPI/I2C, US- SPI/I2C, USART SPI/I2C, USART SPI/I2C, USART SPI/I2C, USART
ART)
Parallel Slave Port — Yes — Yes
A/D Converter (8-bit) Channels 5 8 5 8
Interrupt Sources 11 12 11 12
I/O Pins 22 33 22 33
Voltage Range (Volts) 2.5-6.0 2.5-6.0 2.5-6.0 2.5-6.0
All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capabil-
ity. All PIC16C8X Family devices use serial programming with clock pin RB6 and data pin RB7.
All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capa-
bility. All PIC16C9XX Family devices use serial programming with clock pin RB6 and data pin RB7.
PIC17C752 PIC17C756
Maximum Frequency 33 33
Clock
of Operation (MHz)
EPROM Program Memory 8K 16K
(words)
Memory ROM Program Memory — —
(words)
RAM Data Memory (bytes) 454 902
Timer Module(s) TMR0, TMR0,
TMR1, TMR1,
TMR2, TMR2,
Peripherals TMR3 TMR3
Captures/PWM Module(s) 4/3 4/3
Serial Port(s) (USART) 2 2
Hardware Multiply Yes Yes
External Interrupts Yes Yes
Interrupt Sources 18 18
I/O Pins 50 50
Features Voltage Range (Volts) 3.0-6.0 3.0-6.0
Number of Instructions 58 58
Packages 64-pin DIP; 64-pin DIP;
68-pin LCC, 68-pin LCC,
68-pin TQFP 68-pin TQFP
All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high
I/O current capability.
U
UA ................................................................................. 84, 89
Universal Synchronous Asynchronous Receiver Transmitter
(USART)
Asynchronous Mode
Setting Up Transmission................................... 113
Timing Diagram, Master Transmission ............. 113
Transmitter........................................................ 112
Asynchronous Receiver
Setting Up Reception........................................ 115
Timing Diagram ................................................ 114
Asynchronous Receiver Mode
Block Diagram .................................................. 114
Section.............................................................. 114
Section ...................................................................... 105
Synchronous Master Mode
Reception.......................................................... 118
Section.............................................................. 116
Setting Up Reception........................................ 118
Setting Up Transmission................................... 116
Timing Diagram, Reception .............................. 119
Timing Diagram, Transmission ......................... 117
Transmission .................................................... 116
Connecting to the Microchip BBS Trademarks: The Microchip name, logo, PIC, PICSTART,
PICMASTER and PRO MATE are registered trademarks
Connect worldwide to the Microchip BBS using either of Microchip Technology Incorporated in the U.S.A. and
the Internet or the CompuServe communications net- other countries. FlexROM, MPLAB and fuzzyLAB, are
work. trademarks and SQTP is a service mark of Microchip in
Internet: the U.S.A.
You can telnet or ftp to the Microchip BBS at the fuzzyTECH is a registered trademark of Inform Software
Corporation. IBM, IBM PC-AT are registered trademarks
address: mchipbbs.microchip.com of International Business Machines Corp. Pentium is a
trademark of Intel Corporation. Windows is a trademark
CompuServe Communications Network: and MS-DOS, Microsoft Windows are registered trade-
When using the BBS via the Compuserve Network, marks of Microsoft Corporation. CompuServe is a regis-
in most cases, a local call is your only expense. The tered trademark of CompuServe Incorporated.
Microchip BBS connection does not use CompuServe All other trademarks mentioned herein are the property of
membership services, therefore you do not need their respective companies.
CompuServe membership to join Microchip's BBS.
There is no charge for connecting to the Microchip BBS.
From: Name
Company
Address
City / State / ZIP / Country
Telephone: (_______) _________ - _________ FAX: (______) _________ - _________
Application (optional):
Would you like a reply? Y N
Questions:
2. How does this document meet your hardware and software development needs?
3. Do you find the organization of this data sheet easy to follow? If not, why?
4. What additions to the data sheet do you think would enhance the structure and subject?
5. What deletions from the data sheet could be made without affecting the overall usefulness?
8. How would you improve our software, systems, and silicon products?
Package: L = PLCC
SP = Skinny DIP
P = PDIP
SO = SOIC (Gull Wing, 300 mil body)
PQ = MQFP (Metric PQFP)
TQ = TQFP
JW* = Windowed CERDIP
SS = Shrink SOIC (Gull Wing, 300 mil body)
Examples:
a)PIC16C62A - 04/P 301 = Commercial temp., PDIP package, 4 MHz, normal VDD limits, QTP pattern #301
b)PIC16LC65A - 04I/PQ = Industrial temp., MQFP package, 4 MHz, extended VDD limits
c)PIC16C67 - 10E/P = Extended temp., PDIP package, 10 MHz, normal VDD limits
* JW Devices are UV erasable and can be programmed to any device configuration. JW Devices meet the electrical requirement of
each oscillator type (including LC devices).
Information contained in this publication regarding device applications and the like is intended for suggestion only and may be superseded by updates. No representation or warranty is
given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property
rights arising from such use, or otherwise. Use of Microchip’s products as critical components in medical devices is not authorized except with express written approval by Microchip. No
licenses are conveyed, implicitly or otherwise, under any intellectual property rights. The Microchip logo and name are registered trademarks of Microchip Technology Inc. All rights
reserved. All other trademarks mentioned herein are the property of their respective companies.