PIC17C7XX
High-Performance 8-bit CMOS EPROM Microcontrollers with 10-bit A/D
• Only 58 single word instructions to learn
• All single cycle instructions (121 ns), except for
program branches and table reads/writes which
are two-cycle
• Operating speed:
- DC - 33 MHz clock input
- DC - 121 ns instruction cycle
• 8 x 8 Single-Cycle Hardware Multiplier
• Interrupt capability
• 16 level deep hardware stack
• Direct, indirect, and relative addressing modes
• Internal/external program memory execution,
capable of addressing 64 K x 16 program memory
space
Memory
Device
PIC17C752
PIC17C756A
PIC17C762
PIC17C766
Program (x16)
Data (x8)
8K
16 K
8K
16 K
678
902
678
902
Peripheral Features:
•
•
•
•
•
•
•
•
•
•
•
Up to 66 I/O pins with individual direction control
10-bit, multi-channel Analog-to-Digital converter
High current sink/source for direct LED drive
Four capture input pins
- Captures are 16-bit, max resolution 121 ns
Three PWM outputs (resolution is 1 to 10-bits)
TMR0: 16-bit timer/counter with
8-bit programmable prescaler
TMR1: 8-bit timer/counter
TMR2: 8-bit timer/counter
TMR3: 16-bit timer/counter
Two Universal Synchronous Asynchronous
Receiver Transmitters (USART/SCI) with
independent baud rate generators
Synchronous Serial Port (SSP) with SPI™ and
I2C™ modes (including I2C Master mode)
1998-2013 Microchip Technology Inc.
84 PLCC
RH2
RH3
RD1/AD9
RD0/AD8
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
MCLR/VPP
TEST
NC
VSS
VDD
RF7/AN11
RF6/AN10
RF5/AN9
RF4/AN8
RF3/AN7
RF2/AN6
RH4/AN12
RH5/AN13
RH1
RH0
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
RC0/AD0
VDD
NC
VSS
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
RJ7
RJ6
Pin Diagrams
1110 9 8 7 6 5 4 3 2 1 84 838281 807978777675
12
74
13
73
14
72
15
71
70
16
69
17
68
18
67
19
66
20
65
21
64
22
63
23
62
24
61
25
60
26
59
27
58
28
57
29
56
30
31
55
32
54
33343536373839404142434445 464748 49 50 51 52 53
PIC17C76X
RJ5
RJ4
RA0/INT
RB0/CAP1
RB1/CAP2
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB2/PWM1
VSS
NC
OSC2/CLKOUT
OSC1/CLKIN
VDD
RB7/SDO
RB6/SCK
RA3/SDI/SDA
RA2/SS/SCL
RA1/T0CKI
RJ3
RJ2
RH6/AN14
RH7/AN15
RF1/AN5
RF0/AN4
AVDD
AVSS
RG3/AN0/VREF+
RG2/AN1/VREFRG1/AN2
RG0/AN3
NC
VSS
VDD
RG4/CAP3
RG5/PWM3
RG7/TX2/CK2
RG6/RX2/DT2
RA5/TX1/CK1
RA4/RX1/DT1
RJ0
RJ1
Microcontroller Core Features:
Special Microcontroller Features:
• Power-on Reset (POR), Power-up Timer (PWRT)
and Oscillator Start-up Timer (OST)
• Watchdog Timer (WDT) with its own on-chip RC
oscillator for reliable operation
• Brown-out Reset
• Code protection
• Power saving SLEEP mode
• Selectable oscillator options
CMOS Technology:
• Low power, high speed CMOS EPROM
technology
• Fully static design
• Wide operating voltage range (3.0V to 5.5V)
• Commercial and Industrial temperature ranges
• Low power consumption
- < 5 mA @ 5V, 4 MHz
- 100 µA typical @ 4.5V, 32 kHz
- < 1 µA typical standby current @ 5V
DS30289C-page 1
PIC17C7XX
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
RC0/AD0
VDD
NC
VSS
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
Pin Diagrams cont.’d
9
8
7
6
5
4
3
2
1
68
67
66
65
64
63
62
61
68-Pin PLCC
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
PIC17C75X
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
RA0/INT
RB0/CAP1
RB1/CAP2
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB2/PWM1
VSS
NC
OSC2/CLKOUT
OSC1/CLKIN
VDD
RB7/SDO
RB6/SCK
RA3/SDI/SDA
RA2/SS/SCL
RA1/T0CKI
64
63
62
61
60
59
64-Pin TQFP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
PIC17C75X
48
47
46
45
44
43
42
41
40
39
38
37
36
35
34
33
RA0/INT
RB0/CAP1
RB1/CAP2
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB2/PWM1
VSS
OSC2/CLKOUT
OSC1/CLKIN
VDD
RB7/SDO
RB6/SCK
RA3/SDI/SDA
RA2/SS/SCL
RA1/T0CKI
RF1/AN5
RF0/AN4
AVDD
AVSS
RG3/AN0/VREF+
RG2/AN1/VREFRG1/AN2
RG0/AN3
VSS
VDD
RG4/CAP3
RG5/PWM3
RG7/TX2/CK2
RG6/RX2/DT2
RA5/TX1/CK1
RA4/RX1/DT1
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
RD1/AD9
RD0/AD8
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
MCLR/VPP
TEST
VSS
VDD
RF7/AN11
RF6/AN10
RF5/AN9
RF4/AN8
RF3/AN7
RF2/AN6
58
57
56
55
54
53
52
51
50
49
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
RC0/AD0
VDD
VSS
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
RF1/AN5
RF0/AN4
AVDD
AVSS
RG3/AN0/VREF+
RG2/AN1/VREFRG1/AN2
RG0/AN3
NC
VSS
VDD
RG4/CAP3
RG5/PWM3
RG7/TX2/CK2
RG6/RX2/DT2
RA5/TX1/CK1
RA4/RX1/DT1
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
RD1/AD9
RD0/AD8
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
MCLR/VPP
TEST
NC
VSS
VDD
RF7/AN11
RF6/AN10
RF5/AN9
RF4/AN8
RF3/AN7
RF2/AN6
DS30289C-page 2
1998-2013 Microchip Technology Inc.
PIC17C7XX
Pin Diagrams cont.’d
RH1
RH0
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
RC0/AD0
VDD
NC
VSS
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
RJ7
RJ6
84-pin PLCC
RH2
RH3
RD1/AD9
RD0/AD8
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
MCLR/VPP
TEST
NC
VSS
VDD
RF7/AN11
RF6/AN10
RF5/AN9
RF4/AN8
RF3/AN7
RF2/AN6
RH4/AN12
RH5/AN13
11 10 9 8 7 6 5 4 3 2 1 84 83828180 79787776 75
12
74
13
73
14
72
15
71
16
70
69
17
68
18
67
19
66
20
65
21
64
22
63
23
62
24
61
25
60
26
59
27
58
28
57
29
56
30
31
55
32
54
333435363738394041424344 4546 4748 49 50 51 52 53
RH2
RH3
RD1/AD9
RD0/AD8
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
MCLR/VPP
TEST
VSS
VDD
RF7/AN11
RF6/AN10
RF5/AN9
RF4/AN8
RF3/AN7
RF2/AN6
RH4/AN12
RH5/AN13
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
RH6/AN14
RH7/AN15
RF1/AN5
RF0/AN4
AVDD
AVSS
RG3/AN0/VREF+
RG2/AN1/VREFRG1/AN2
RG0/AN3
NC
VSS
VDD
RG4/CAP3
RG5/PWM3
RG7/TX2/CK2
RG6/RX2/DT2
RA5/TX1/CK1
RA4/RX1/DT1
RJ0
RJ1
PIC17C76X
RJ5
RJ4
RA0/INT
RB0/CAP1
RB1/CAP2
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB2/PWM1
VSS
NC
OSC2/CLKOUT
OSC1/CLKIN
VDD
RB7/SDO
RB6/SCK
RA3/SDI/SDA
RA2/SS/SCL
RA1/T0CKI
RJ3
RJ2
RH1
RH0
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
RC0/AD0
VDD
VSS
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
RJ7
RJ6
80-Pin TQFP
80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61
PIC17C76X
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
43
42
41
RJ5
RJ4
RA0/INT
RB0/CAP1
RB1/CAP2
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB2/PWM1
VSS
OSC2/CLKOUT
OSC1/CLKIN
VDD
RB7/SDO
RB6/SCK
RA3/SDI/SDA
RA2/SS/SCL
RA1/T0CKI
RJ3
RJ2
RH6/AN14
RH7/AN15
RF1/AN5
RF0/AN4
AVDD
AVSS
RG3/AN0/VREF+
RG2/AN1/VREFRG1/AN2
RG0/AN3
VSS
VDD
RG4/CAP3
RG5/PWM3
RG7/TX2/CK2
RG6/RX2/DT2
RA5/TX1/CK1
RA4/RX1/DT1
RJ0
RJ1
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 3637 38 39 40
1998-2013 Microchip Technology Inc.
DS30289C-page 3
PIC17C7XX
Table of Contents
1.0
Overview ........................................................................................................................................................ 7
2.0
Device Varieties ............................................................................................................................................. 9
3.0
Architectural Overview ................................................................................................................................. 11
4.0
On-chip Oscillator Circuit ............................................................................................................................. 17
5.0
Reset............................................................................................................................................................ 23
6.0
Interrupts...................................................................................................................................................... 33
7.0
Memory Organization................................................................................................................................... 43
8.0
Table Reads and Table Writes .................................................................................................................... 59
9.0
Hardware Multiplier ...................................................................................................................................... 67
10.0
I/O Ports....................................................................................................................................................... 71
11.0
Overview of Timer Resources...................................................................................................................... 95
12.0
Timer0.......................................................................................................................................................... 97
13.0
Timer1, Timer2, Timer3, PWMs and Captures .......................................................................................... 101
14.0
Universal Synchronous Asynchronous Receiver Transmitter (USART) Modules...................................... 117
15.0
Master Synchronous Serial Port (MSSP) Module...................................................................................... 133
16.0
Analog-to-Digital Converter (A/D) Module ................................................................................................. 179
17.0
Special Features of the CPU ..................................................................................................................... 191
18.0
Instruction Set Summary............................................................................................................................ 197
19.0
Development Support ................................................................................................................................ 233
20.0
PIC17C7XX Electrical Characteristics ....................................................................................................... 239
21.0
PIC17C7XX DC and AC Characteristics.................................................................................................... 267
22.0
Packaging Information ............................................................................................................................... 281
Appendix A: Modifications ....................................................................................................................................... 287
Appendix B: Compatibility........................................................................................................................................ 287
Appendix C: What’s New ......................................................................................................................................... 288
Appendix D: What’s Changed.................................................................................................................................. 288
Index .......................................................................................................................................................................... 289
On-Line Support .......................................................................................................................................................... 299
Reader Response ....................................................................................................................................................... 300
Product Identification System...................................................................................................................................... 301
DS30289C-page 4
1998-2013 Microchip Technology Inc.
PIC17C7XX
TO OUR VALUED CUSTOMERS
It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined
and enhanced as new volumes and updates are introduced.
If you have any questions or comments regarding this publication, please contact the Marketing Communications Department
via E-mail at docerrors@mail.microchip.com or fax the Reader Response Form in the back of this data sheet to (480) 7924150. We welcome your feedback.
Most Current Data Sheet
To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:
http://www.microchip.com
You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page.
The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).
Errata
An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current
devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision
of silicon and revision of document to which it applies.
To determine if an errata sheet exists for a particular device, please check with one of the following:
• Microchip’s Worldwide Web site; http://www.microchip.com
• Your local Microchip sales office (see last page)
• The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277
When contacting a sales office or the literature center, please specify which device, revision of silicon and data sheet (include literature number) you are using.
Customer Notification System
Register on our web site at www.microchip.com/cn to receive the most current information on all of our products.
1998-2013 Microchip Technology Inc.
DS30289C-page 5
PIC17C7XX
NOTES:
DS30289C-page 6
1998-2013 Microchip Technology Inc.
PIC17C7XX
1.0
OVERVIEW
This data sheet covers the PIC17C7XX group of the
PIC17CXXX family of microcontrollers. The following
devices are discussed in this data sheet:
•
•
•
•
PIC17C752
PIC17C756A
PIC17C762
PIC17C766
The PIC17C7XX devices are 68/84-pin, EPROM
based members of the versatile PIC17CXXX family of
low cost, high performance, CMOS, fully static, 8-bit
microcontrollers.
All PIC® microcontrollers employ an advanced RISC
architecture. The PIC17CXXX has enhanced core features, 16-level deep stack, and multiple internal and
external interrupt sources. The separate instruction
and data buses of the Harvard architecture allow a 16bit wide instruction word with a separate 8-bit wide data
path. The two stage instruction pipeline allows all
instructions to execute in a single cycle, except for program branches (which require two cycles). A total of 58
instructions (reduced instruction set) are available.
Additionally, a large register set gives some of the
architectural innovations used to achieve a very high
performance. For mathematical intensive applications,
all devices have a single cycle 8 x 8 Hardware
Multiplier.
PIC17CXXX microcontrollers typically achieve a 2:1
code compression and a 4:1 speed improvement over
other 8-bit microcontrollers in their class.
PIC17C7XX devices have up to 902 bytes of RAM and
66 I/O pins. In addition, the PIC17C7XX adds several
peripheral features, useful in many high performance
applications, including:
•
•
•
•
Four timer/counters
Four capture inputs
Three PWM outputs
Two independent Universal Synchronous Asynchronous Receiver Transmitters (USARTs)
• An A/D converter (multi-channel, 10-bit resolution)
• A Synchronous Serial Port
(SPI and I2C w/ Master mode)
These special features reduce external components,
thus reducing cost, enhancing system reliability and
reducing power consumption.
There are four oscillator options, of which the single pin
RC oscillator provides a low cost solution, the LF oscillator is for low frequency crystals and minimizes power
consumption, XT is a standard crystal and the EC is for
external clock input.
The SLEEP (power-down) mode offers additional
power saving. Wake-up from SLEEP can occur through
several external and internal interrupts and device
RESETS.
1998-2013 Microchip Technology Inc.
A highly reliable Watchdog Timer with its own on-chip
RC oscillator provides protection against software malfunction.
There are four configuration options for the device
operational mode:
•
•
•
•
Microprocessor
Microcontroller
Extended microcontroller
Protected microcontroller
The microprocessor and extended microcontroller
modes allow up to 64K-words of external program
memory.
The device also has Brown-out Reset circuitry. This
allows a device RESET to occur if the device VDD falls
below the Brown-out voltage trip point (BVDD). The chip
will remain in Brown-out Reset until VDD rises above
BVDD.
A UV erasable, CERQUAD packaged version (compatible with PLCC), is ideal for code development, while
the cost-effective One-Time-Programmable (OTP) version is suitable for production in any volume.
The PIC17C7XX fits perfectly in applications that
require extremely fast execution of complex software
programs. These include applications ranging from
precise motor control and industrial process control to
automotive, instrumentation, and telecom applications.
The EPROM technology makes customization of application programs (with unique security codes, combinations, model numbers, parameter storage, etc.) fast
and convenient. Small footprint package options
(including die sales) make the PIC17C7XX ideal for
applications with space limitations that require high
performance.
High speed execution, powerful peripheral features,
flexible I/O, and low power consumption all at low cost
make the PIC17C7XX ideal for a wide range of embedded control applications.
1.1
Family and Upward Compatibility
The PIC17CXXX family of microcontrollers have architectural enhancements over the PIC16C5X and
PIC16CXX families. These enhancements allow the
device to be more efficient in software and hardware
requirements. Refer to Appendix A for a detailed list of
enhancements and modifications. Code written for
PIC16C5X or PIC16CXX can be easily ported to
PIC17CXXX devices (Appendix B).
1.2
Development Support
The PIC17CXXX family is supported by a full featured
macro assembler, a software simulator, an in-circuit
emulator, a universal programmer, a “C” compiler and
fuzzy logic support tools. For additional information,
see Section 19.0.
DS30289C-page 7
PIC17C7XX
TABLE 1-1:
PIC17CXXX FAMILY OF DEVICES
Features
Maximum Frequency
of Operation
PIC17C42A
PIC17C43
PIC17C44
PIC17C752
PIC17C756A
PIC17C762
PIC17C766
33 MHz
33 MHz
33 MHz
33 MHz
33 MHz
33 MHz
33 MHz
2.5 - 6.0V
2.5 - 6.0V
2.5 - 6.0V
3.0 - 5.5V
3.0 - 5.5V
3.0 - 5.5V
3.0 - 5.5V
(EPROM)
2K
4K
8K
8K
16 K
8K
16 K
(ROM)
—
—
—
—
—
—
—
Data Memory (bytes)
232
454
454
678
902
678
902
Hardware Multiplier (8 x 8)
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Timer0
(16-bit + 8-bit postscaler)
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Timer1 (8-bit)
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Timer2 (8-bit)
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Timer3 (16-bit)
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Capture inputs (16-bit)
2
2
2
4
4
4
4
PWM outputs (up to 10-bit)
2
2
2
3
3
3
3
USART/SCI
1
1
1
2
2
2
2
A/D channels (10-bit)
—
—
—
12
12
16
16
SSP (SPI/I2C w/Master
mode)
—
—
—
Yes
Yes
Yes
Yes
Power-on Reset
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Watchdog Timer
Yes
Yes
Yes
Yes
Yes
Yes
Yes
External Interrupts
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Interrupt Sources
11
11
11
18
18
18
18
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Brown-out Reset
—
—
—
Yes
Yes
Yes
Yes
In-Circuit Serial
Programming
—
—
—
Yes
Yes
Yes
Yes
Operating Voltage Range
Program
Memory ( x16)
Code Protect
I/O Pins
I/O High
Source
Current Capability Sink
Package Types
33
33
33
50
50
66
66
25 mA
25 mA
25 mA
25 mA
25 mA
25 mA
25 mA
25 mA(1)
25 mA(1)
25 mA(1)
25 mA(1)
25 mA(1)
25 mA(1)
25 mA(1)
40-pin DIP
44-pin PLCC
44-pin MQFP
44-pin TQFP
40-pin DIP
40-pin DIP 64-pin TQFP
44-pin PLCC 44-pin PLCC 68-pin PLCC
44-pin
44-pin
MQFP
MQFP
44-pin TQFP 44-pin TQFP
64-pin TQFP
68-pin PLCC
80-pin TQFP 80-pin TQFP
84-pin PLCC 84-pin PLCC
Note 1: Pins RA2 and RA3 can sink up to 60 mA.
DS30289C-page 8
1998-2013 Microchip Technology Inc.
PIC17C7XX
2.0
DEVICE VARIETIES
2.3
Each device has a variety of frequency ranges and
packaging options. Depending on application and production requirements, the proper device option can be
selected using the information in the PIC17C7XX Product Selection System section at the end of this data
sheet. When placing orders, please use the
“PIC17C7XX Product Identification System” at the
back of this data sheet to specify the correct part number. When discussing the functionality of the device,
memory technology and voltage range does not matter.
There are two memory type options. These are specified in the middle characters of the part number.
1.
C, as in PIC17C756A. These devices have
EPROM type memory.
CR, as in PIC17CR756A. These devices have
ROM type memory.
2.
All these devices operate over the standard voltage
range. Devices are also offered which operate over an
extended voltage range (and reduced frequency
range). Table 2-1 shows all possible memory types and
voltage range designators for a particular device.
These designators are in bold typeface.
TABLE 2-1:
DEVICE MEMORY VARIETIES
Voltage Range
Memory Type
Standard
Extended
EPROM
PIC17CXXX
PIC17LCXXX
ROM
PIC17CRXXX
PIC17LCRXXX
Note:
2.1
Not all memory technologies are available
for a particular device.
Quick-Turnaround-Production
(QTP) Devices
Microchip offers a QTP Programming Service for factory production orders. This service is made available
for users who choose not to program a medium to high
quantity of units and whose code patterns have stabilized. The devices are identical to the OTP devices but
with all EPROM locations and configuration options
already programmed by the factory. Certain code and
prototype verification procedures apply before production shipments are available. Please contact your local
Microchip Technology sales office for more details.
2.4
Serialized Quick-Turnaround
Production (SQTPsm) Devices
Microchip offers a unique programming service, where
a few user defined locations in each device are programmed with different serial numbers. The serial numbers may be random, pseudo-random or sequential.
Serial programming allows each device to have a
unique number which can serve as an entry code,
password or ID number.
2.5
Read Only Memory (ROM) Devices
Microchip offers masked ROM versions of several of
the highest volume parts, thus giving customers a low
cost option for high volume, mature products.
ROM devices do not allow serialization information in
the program memory space.
For information on submitting ROM code, please contact your regional sales office.
Note:
Presently, NO ROM versions of the
PIC17C7XX devices are available.
UV Erasable Devices
The UV erasable version, offered in CERQUAD package, is optimal for prototype development and pilot
programs.
The UV erasable version can be erased and reprogrammed to any of the configuration modes. Third
party programmers also are available; refer to the Third
Party Guide for a list of sources.
2.2
One-Time-Programmable (OTP)
Devices
The availability of OTP devices is especially useful for
customers expecting frequent code changes and
updates.
The OTP devices, packaged in plastic packages, permit
the user to program them once. In addition to the program
memory, the configuration bits must be programmed.
1998-2013 Microchip Technology Inc.
DS30289C-page 9
PIC17C7XX
NOTES:
DS30289C-page 10
1998-2013 Microchip Technology Inc.
PIC17C7XX
3.0
ARCHITECTURAL OVERVIEW
The high performance of the PIC17CXXX can be attributed to a number of architectural features, commonly
found in RISC microprocessors. To begin with, the
PIC17CXXX uses a modified Harvard architecture.
This architecture has the program and data accessed
from separate memories. So, the device has a program
memory bus and a data memory bus. This improves
bandwidth over traditional von Neumann architecture,
where program and data are fetched from the same
memory (accesses over the same bus). Separating
program and data memory further allows instructions to
be sized differently than the 8-bit wide data word.
PIC17CXXX opcodes are 16-bits wide, enabling single
word instructions. The full 16-bit wide program memory
bus fetches a 16-bit instruction in a single cycle. A twostage pipeline overlaps fetch and execution of instructions. Consequently, all instructions execute in a single
cycle (121 ns @ 33 MHz), except for program branches
and two special instructions that transfer data between
program and data memory.
The PIC17CXXX can address up to 64K x 16 of program memory space.
The PIC17C752 and PIC17C762 integrate 8K x 16 of
EPROM program memory on-chip.
The PIC17C756A and PIC17C766 integrate 16K x 16
EPROM program memory on-chip.
A simplified block diagram is shown in Figure 3-1. The
descriptions of the device pins are listed in Table 3-1.
Program execution can be internal only (Microcontroller or Protected Microcontroller mode), external only
(Microprocessor mode), or both (Extended Microcontroller mode). Extended Microcontroller mode does not
allow code protection.
The PIC17CXXX can directly or indirectly address its
register files or data memory. All special function registers, including the Program Counter (PC) and Working
Register (WREG), are mapped in data memory. The
PIC17CXXX has an orthogonal (symmetrical) instruction
set that makes it possible to carry out any operation on
any register using any addressing mode. This symmetrical nature and lack of ‘special optimal situations’ make
programming with the PIC17CXXX simple, yet efficient.
In addition, the learning curve is reduced significantly.
One of the PIC17CXXX family architectural enhancements from the PIC16CXX family, allows two file registers to be used in some two operand instructions. This
allows data to be moved directly between two registers
without going through the WREG register, thus increasing performance and decreasing program memory
usage.
The PIC17CXXX devices contain an 8-bit ALU and
working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions
between data in the working register and any register
file.
1998-2013 Microchip Technology Inc.
The WREG register is an 8-bit working register used for
ALU operations.
All PIC17CXXX devices have an 8 x 8 hardware multiplier. This multiplier generates a 16-bit result in a single
cycle.
The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise
mentioned, arithmetic operations are two's complement in nature.
Depending on the instruction executed, the ALU may
affect the values of the Carry (C), Digit Carry (DC), Zero
(Z) and Overflow (OV) bits in the ALUSTA register. The
C and DC bits operate as a borrow and digit borrow out
bit, respectively, in subtraction. See the SUBLW and
SUBWF instructions for examples.
Signed arithmetic is comprised of a magnitude and a
sign bit. The overflow bit indicates if the magnitude
overflows and causes the sign bit to change state. That
is, if the result of 8-bit signed operations is greater than
127 (7Fh), or less than -128 (80h).
Signed math can have greater than 7-bit values (magnitude), if more than one byte is used. The overflow bit
only operates on bit6 (MSb of magnitude) and bit7 (sign
bit) of each byte value in the ALU. That is, the overflow
bit is not useful if trying to implement signed math
where the magnitude, for example, is 11-bits.
If the signed math values are greater than 7-bits (such
as 15-, 24-, or 31-bit), the algorithm must ensure that
the low order bytes of the signed value ignore the overflow status bit.
Example 3-1 shows two cases of doing signed arithmetic. The Carry (C) bit and the Overflow (OV) bit are the
most important status bits for signed math operations.
EXAMPLE 3-1:
Hex Value
+
=
FFh
01h
00h
8-BIT MATH ADDITION
Signed Values
+
=
-1
1
0 (FEh)
Unsigned Values
255
+
1
= 256 00h
C bit = 1
OV bit = 0
C bit = 1
OV bit = 0
C bit = 1
OV bit = 0
DC bit = 1
Z bit = 1
DC bit = 1
Z bit = 1
DC bit = 1
Z bit = 1
Hex Value
Signed Values
Unsigned Values
+
=
7Fh
01h
80h
+
=
127
1
128 00h
127
+
1
= 128
C bit = 0
OV bit = 1
C bit = 0
OV bit = 1
C bit = 0
OV bit = 1
DC bit = 1
Z bit = 0
DC bit = 1
Z bit = 0
DC bit = 1
Z bit = 0
DS30289C-page 11
PIC17C7XX
FIGURE 3-1:
PIC17C752/756A BLOCK DIAGRAM
PORTA
RA0/INT
RA1/T0CKI
RA2/SS/SCL
RA3/SDI/SDA
RA4/RX1/DT1
RA5/TX1/CK1
WREG
IR
BITOP
Clock
Generator
Q1, Q2,
Q3, Q4
OSC1,
OSC2
Power-on
Reset
Brown-out VDD, VSS
Reset
PORTB
8 x 8 mult
RB0/CAP1
RB1/CAP2
RB2/PWM1
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB6/SCK
RB7/SDO
Chip_reset
& Other
Control
Signals
ALU
PRODH PRODL
Shifter
Watchdog
Timer
MCLR, VPP
Test Mode
Select
Test
IR Latch
8
8
8
BSR
IR
PORTC
RC0/AD0
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
16
F1
F9
12
RAM
Address
Buffer
Data RAM
17C756A
902 x 8
17C752
678 x 8
PORTD
RD0/AD8
RD1/AD9
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
Read/Write
Decode
for
Registers
Mapped
in Data
Space
Instruction
Decode
Control Outputs
ROM Latch
Decode
8
AD
PORTC,
PORTD
BSR
Literal
Table
Latch
Data Latch
Program
Memory
(EPROM)
17C756A
16K x 16
17C752
8K x 16
PORTE
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
Address
Latch
Table Pointer
PCLATH
System Bus Interface
Data Latch
ALE,
WR,
OE,
PORTE
16
16
PORTF
RF0/AN4
RF1/AN5
RF2/AN6
RF3/AN7
RF4/AN8
RF5/AN9
RF6/AN10
RF7/AN11
PCH
PCL
16
Stack
16 x 16
16
Data Bus
Timer0
Timer2
USART1
PWM1
PWM3
Capture2
10-bit
A/D
SSP
Timer1
Timer3
USART2
PWM2
Capture1
Capture3
Capture4
Interrupt
Module
PORTG
RG0/AN3
RG1/AN2
RG2/AN1/VREFRG3/AN0/VREF+
RG4/CAP3
RG5/PWM3
RG6/RX2/DT2
RG7/TX2/CK2
DS30289C-page 12
1998-2013 Microchip Technology Inc.
PIC17C7XX
PIC17C762/766 BLOCK DIAGRAM
PORTA
Clock
Generator
RA0/INT
RA1/T0CKI
RA2/SS/SCL
RA3/SDI/SDA
RA4/RX1/DT1
RA5/TX1/CK1
WREG
Q1, Q2,
Q3, Q4
IR
BITOP
Chip_reset
& Other
Control
Signals
PORTB
RB0/CAP1
RB1/CAP2
RB2/PWM1
RB3/PWM2
RB4/TCLK12
RB5/TCLK3
RB6/SCK
RB7/SDO
8 x 8 mult
ALU
OSC1,
OSC2
Power-on
Reset
Watchdog
Timer
VDD, VSS
Test Mode
Select
MCLR, VPP
Brown-out
Reset
Test
AVDD, AVSS
PRODH PRODL
Shifter
IR Latch
PORTC
8
8
RC0/AD0
RC1/AD1
RC2/AD2
RC3/AD3
RC4/AD4
RC5/AD5
RC6/AD6
RC7/AD7
8 BSR
IR
16
FSR0
FSR1
12
RAM
Address
Buffer
Data RAM
17C766
902 x 8
and
17C762
678 x 8
Data Latch
PORTD
RD0/AD8
RD1/AD9
RD2/AD10
RD3/AD11
RD4/AD12
RD5/AD13
RD6/AD14
RD7/AD15
PORTE
RE0/ALE
RE1/OE
RE2/WR
RE3/CAP4
BSR
Read/Write
Decode
for
Registers
Mapped
in Data
Space
Instruction
Decode
Control Outputs
Literal
ROM Latch
8
AD
PORTC,
PORTD
Table
Latch
Data Latch
Program
Memory
(EPROM)
17C766
16K x 16,
and
17C762
8K x 16
PORTF
RF0/AN4
RF1/AN5
RF2/AN6
RF3/AN7
RF4/AN8
RF5/AN9
RF6/AN10
RF7/AN11
Decode
System Bus Interface
FIGURE 3-2:
Table Pointer
PCLATH
ALE,
WR,
OE,
PORTE
Address
Latch
16
PORTG
RG0/AN3
RG1/AN2
RG2/AN1/VREFRG3/AN0/VREF+
RG4/CAP3
RG5/PWM3
RG6/RX2/DT2
RG7/TX2/CK2
16
PCH
PCL
16
Stack
16 x 16
16
Data Bus
PORTJ
RJ0
RJ1
RJ2
RJ3
RJ4
RJ5
RJ6
RJ7
PORTH
RH0
RH1
RH2
RH3
RH4/AN12
RH5/AN13
RH6/AN14
RH7/AN15
1998-2013 Microchip Technology Inc.
Timer0
Timer2
USART1
PWM1
PWM3
Timer1
Timer3
USART2
PWM2
Capture1
Interrupt
Module
SSP
10-bit
A/D
Capture2
Capture3
Capture4
DS30289C-page 13
PIC17C7XX
TABLE 3-1:
PINOUT DESCRIPTIONS
PIC17C75X
Name
PIC17C76X
DIP
No.
PLCC
No.
TQFP
No.
PLCC
No.
QFP
No.
I/O/P
Type
Buffer
Type
Description
OSC1/CLKIN
47
50
39
62
49
I
ST
Oscillator input in Crystal/Resonator or RC Oscillator
mode. External clock input in External Clock mode.
OSC2/CLKOUT
48
51
40
63
50
O
—
Oscillator output. Connects to crystal or resonator in
Crystal Oscillator mode. In RC Oscillator or External
Clock modes, OSC2 pin outputs CLKOUT which has
one fourth the frequency (FOSC/4) of OSC1 and
denotes the instruction cycle rate.
MCLR/VPP
15
16
7
20
9
I/P
ST
Master clear (RESET) input or Programming Voltage
(VPP) input. This is the active low RESET input to the
device.
PORTA pins have individual differentiations that are
listed in the following descriptions:
RA0/INT
56
60
48
72
58
I
ST
RA0 can also be selected as an external interrupt input. Interrupt can be configured to be on
positive or negative edge. Input only pin.
RA1/T0CKI
41
44
33
56
43
I
ST
RA1 can also be selected as an external interrupt input and the interrupt can be configured to
be on positive or negative edge. RA1 can also
be selected to be the clock input to the Timer0
timer/counter. Input only pin.
RA2/SS/SCL
42
45
34
57
44
I/O(2)
ST
RA2 can also be used as the slave select input
for the SPI or the clock input for the I2C bus.
High voltage, high current, open drain port pin.
RA3/SDI/SDA
43
46
35
58
45
I/O(2)
ST
RA3 can also be used as the data input for the
SPI or the data for the I2C bus.
High voltage, high current, open drain port pin.
RA4/RX1/DT1
40
43
32
51
38
I/O(1)
ST
RA4 can also be selected as the USART1 (SCI)
Asynchronous Receive or USART1 (SCI)
Synchronous Data.
Output available from USART only.
RA5/TX1/CK1
39
42
31
50
37
I/O(1)
ST
RA5 can also be selected as the USART1 (SCI)
Asynchronous Transmit or USART1 (SCI)
Synchronous Clock.
Output available from USART only.
PORTB is a bi-directional I/O Port with software
configurable weak pull-ups.
RB0/CAP1
55
59
47
71
57
I/O
ST
RB1/CAP2
54
58
46
70
56
I/O
ST
RB0 can also be the Capture1 input pin.
RB1 can also be the Capture2 input pin.
RB2/PWM1
50
54
42
66
52
I/O
ST
RB2 can also be the PWM1 output pin.
RB3/PWM2
53
57
45
69
55
I/O
ST
RB3 can also be the PWM2 output pin.
RB4/TCLK12
52
56
44
68
54
I/O
ST
RB4 can also be the external clock input to
Timer1 and Timer2.
RB5/TCLK3
51
55
43
67
53
I/O
ST
RB5 can also be the external clock input to
Timer3.
RB6/SCK
44
47
36
59
46
I/O
ST
RB6 can also be used as the master/slave clock
for the SPI.
RB7/SDO
45
48
37
60
47
I/O
ST
RB7 can also be used as the data output for the
SPI.
Legend: I = Input only; O = Output only;
I/O = Input/Output;
P = Power;
— = Not Used;
TTL = TTL input;
ST = Schmitt Trigger input
Note 1: The output is only available by the peripheral operation.
2: Open drain input/output pin. Pin forced to input upon any device RESET.
DS30289C-page 14
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 3-1:
PINOUT DESCRIPTIONS (CONTINUED)
PIC17C75X
Name
PIC17C76X
DIP
No.
PLCC
No.
TQFP
No.
PLCC
No.
QFP
No.
I/O/P
Type
Buffer
Type
RC0/AD0
2
3
58
3
72
I/O
TTL
RC1/AD1
63
67
55
83
69
I/O
TTL
RC2/AD2
62
66
54
82
68
I/O
TTL
RC3/AD3
61
65
53
81
67
I/O
TTL
RC4/AD4
60
64
52
80
66
I/O
TTL
RC5/AD5
58
63
51
79
65
I/O
TTL
RC6/AD6
58
62
50
78
64
I/O
TTL
RC7/AD7
57
61
49
77
63
I/O
TTL
RD0/AD8
10
11
2
15
4
I/O
TTL
RD1/AD9
9
10
1
14
3
I/O
TTL
Description
PORTC is a bi-directional I/O Port.
This is also the least significant byte (LSB) of
the 16-bit wide system bus in Microprocessor
mode or Extended Microcontroller mode. In
multiplexed system bus configuration, these
pins are address output as well as data input or
output.
PORTD is a bi-directional I/O Port.
This is also the most significant byte (MSB) of
the 16-bit system bus in Microprocessor mode
or Extended Microcontroller mode. In multiplexed system bus configuration, these pins are
address output as well as data input or output.
RD2/AD10
8
9
64
9
78
I/O
TTL
RD3/AD11
7
8
63
8
77
I/O
TTL
RD4/AD12
6
7
62
7
76
I/O
TTL
RD5/AD13
5
6
61
6
75
I/O
TTL
RD6/AD14
4
5
60
5
74
I/O
TTL
RD7/AD15
3
4
59
4
73
I/O
TTL
RE0/ALE
11
12
3
16
5
I/O
TTL
In Microprocessor mode or Extended Microcontroller mode, RE0 is the Address Latch Enable
(ALE) output. Address should be latched on the
falling edge of ALE output.
RE1/OE
12
13
4
17
6
I/O
TTL
In Microprocessor or Extended Microcontroller
mode, RE1 is the Output Enable (OE) control
output (active low).
RE2/WR
13
14
5
18
7
I/O
TTL
In Microprocessor or Extended Microcontroller
mode, RE2 is the Write Enable (WR) control
output (active low).
RE3/CAP4
14
15
6
19
8
I/O
ST
PORTE is a bi-directional I/O Port.
RE3 can also be the Capture4 input pin.
PORTF is a bi-directional I/O Port.
RF0/AN4
26
28
18
36
24
I/O
ST
RF0 can also be analog input 4.
RF1/AN5
25
27
17
35
23
I/O
ST
RF1 can also be analog input 5.
RF2/AN6
24
26
16
30
18
I/O
ST
RF2 can also be analog input 6.
RF3/AN7
23
25
15
29
17
I/O
ST
RF3 can also be analog input 7.
RF4/AN8
22
24
14
28
16
I/O
ST
RF4 can also be analog input 8.
RF5/AN9
21
23
13
27
15
I/O
ST
RF5 can also be analog input 9.
RF6/AN10
20
22
12
26
14
I/O
ST
RF6 can also be analog input 10.
RF7/AN11
19
21
11
25
13
I/O
ST
RF7 can also be analog input 11.
Legend: I = Input only; O = Output only;
I/O = Input/Output;
P = Power;
— = Not Used;
TTL = TTL input;
ST = Schmitt Trigger input
Note 1: The output is only available by the peripheral operation.
2: Open drain input/output pin. Pin forced to input upon any device RESET.
1998-2013 Microchip Technology Inc.
DS30289C-page 15
PIC17C7XX
TABLE 3-1:
PINOUT DESCRIPTIONS (CONTINUED)
PIC17C75X
Name
PIC17C76X
Description
DIP
No.
PLCC
No.
TQFP
No.
PLCC
No.
QFP
No.
I/O/P
Type
Buffer
Type
RG0/AN3
32
34
24
42
30
I/O
ST
RG0 can also be analog input 3.
RG1/AN2
31
33
23
41
29
I/O
ST
RG1 can also be analog input 2.
RG2/AN1/VREF-
30
32
22
40
28
I/O
ST
RG2 can also be analog input 1, or
the ground reference voltage.
RG3/AN0/VREF+
29
31
21
39
27
I/O
ST
RG3 can also be analog input 0, or
the positive reference voltage.
RG4/CAP3
35
38
27
46
33
I/O
ST
RG4 can also be the Capture3 input pin.
RG5/PWM3
36
39
28
47
34
I/O
ST
RG5 can also be the PWM3 output pin.
RG6/RX2/DT2
38
41
30
49
36
I/O
ST
RG6 can also be selected as the USART2 (SCI)
Asynchronous Receive or USART2 (SCI)
Synchronous Data.
RG7/TX2/CK2
37
40
29
48
35
I/O
ST
RG7 can also be selected as the USART2 (SCI)
Asynchronous Transmit or USART2 (SCI)
Synchronous Clock.
RH0
—
—
—
10
79
I/O
ST
PORTG is a bi-directional I/O Port.
RH1
—
—
—
11
80
I/O
ST
RH2
—
—
—
12
1
I/O
ST
PORTH is a bi-directional I/O Port. PORTH is only
available on the PIC17C76X devices.
RH3
—
—
—
13
2
I/O
ST
RH4/AN12
—
—
—
31
19
I/O
ST
RH4 can also be analog input 12.
RH5/AN13
—
—
—
32
20
I/O
ST
RH5 can also be analog input 13.
RH6/AN14
—
—
—
33
21
I/O
ST
RH6 can also be analog input 14.
RH7/AN15
—
—
—
34
22
I/O
ST
RH7 can also be analog input 15.
PORTJ is a bi-directional I/O Port. PORTJ is only
available on the PIC17C76X devices.
RJ0
—
—
—
52
39
I/O
ST
RJ1
—
—
—
53
40
I/O
ST
RJ2
—
—
—
54
41
I/O
ST
RJ3
—
—
—
55
42
I/O
ST
RJ4
—
—
—
73
59
I/O
ST
RJ5
—
—
—
74
60
I/O
ST
RJ6
—
—
—
75
61
I/O
ST
RJ7
—
—
—
76
62
I/O
ST
TEST
16
17
8
21
10
I
ST
Test mode selection control input. Always tie to VSS
for normal operation.
VSS
17, 33, 19, 36, 9, 25, 23, 44, 11, 31,
49, 64 53, 68 41, 56 65, 84 51, 70
P
Ground reference for logic and I/O pins.
VDD
1, 18, 2, 20, 10, 26, 24, 45, 12, 32,
34, 46 37, 49, 38, 57 61, 2 48, 71
P
Positive supply for logic and I/O pins.
AVSS
28
30
20
38
26
P
Ground reference for A/D converter.
This pin MUST be at the same potential as VSS.
AVDD
27
29
19
37
25
P
Positive supply for A/D converter.
This pin MUST be at the same potential as VDD.
NC
—
1, 18,
35, 52
—
1, 22,
43, 64
—
No Connect. Leave these pins unconnected.
Legend: I = Input only; O = Output only;
I/O = Input/Output;
P = Power;
— = Not Used;
TTL = TTL input;
ST = Schmitt Trigger input
Note 1: The output is only available by the peripheral operation.
2: Open drain input/output pin. Pin forced to input upon any device RESET.
DS30289C-page 16
1998-2013 Microchip Technology Inc.
PIC17C7XX
4.0
ON-CHIP OSCILLATOR
CIRCUIT
The internal oscillator circuit is used to generate the
device clock. Four device clock periods generate an
internal instruction clock (TCY).
There are four modes that the oscillator can operate in.
They are selected by the device configuration bits during device programming. These modes are:
• LF
• XT
• EC
• RC
Low Frequency (FOSC 2 MHz)
Standard Crystal/Resonator Frequency
(2 MHz FOSC 33 MHz)
External Clock Input
(Default oscillator configuration)
External Resistor/Capacitor
(FOSC 4 MHz)
There are two timers that offer necessary delays on
power-up. One is the Oscillator Start-up Timer (OST),
intended to keep the chip in RESET until the crystal
oscillator is stable. The other is the Power-up Timer
(PWRT), which provides a fixed delay of 96 ms (nominal) on POR and BOR. The PWRT is designed to keep
the part in RESET while the power supply stabilizes.
With these two timers on-chip, most applications need
no external RESET circuitry.
SLEEP mode is designed to offer a very low current
power-down mode. The user can wake from SLEEP
through external RESET, Watchdog Timer Reset, or
through an interrupt.
4.1.2
CRYSTAL OSCILLATOR/CERAMIC
RESONATORS
In XT or LF modes, a crystal or ceramic resonator is connected to the OSC1/CLKIN and OSC2/CLKOUT pins to
establish oscillation (Figure 4-2). The PIC17CXXX oscillator design requires the use of a parallel cut crystal. Use
of a series cut crystal may give a frequency out of the
crystal manufacturers specifications.
For frequencies above 24 MHz, it is common for the
crystal to be an overtone mode crystal. Use of overtone
mode crystals require a tank circuit to attenuate the
gain at the fundamental frequency. Figure 4-3 shows
an example circuit.
4.1.3
OSCILLATOR/RESONATOR
START-UP
As the device voltage increases from Vss, the oscillator
will start its oscillations. The time required for the oscillator to start oscillating depends on many factors.
These include:
•
•
•
•
•
•
Crystal/resonator frequency
Capacitor values used (C1 and C2)
Device VDD rise time
System temperature
Series resistor value (and type) if used
Oscillator mode selection of device (which selects
the gain of the internal oscillator inverter)
Several oscillator options are made available to allow
the part to better fit the application. The RC oscillator
option saves system cost while the LF crystal option
saves power. Configuration bits are used to select various options.
Figure 4-1 shows an example of a typical oscillator/
resonator start-up. The peak-to-peak voltage of the
oscillator waveform can be quite low (less than 50% of
device VDD) when the waveform is centered at VDD/2
(refer to parameter #D033 and parameter #D043 in the
electrical specification section).
4.1
FIGURE 4-1:
4.1.1
Oscillator Configurations
OSCILLATOR TYPES
OSCILLATOR/
RESONATOR START-UP
CHARACTERISTICS
•
•
•
•
LF
XT
EC
RC
Low Power Crystal
Crystal/Resonator
External Clock Input
Resistor/Capacitor
VDD
The PIC17CXXX can be operated in four different oscillator modes. The user can program two configuration
bits (FOSC1:FOSC0) to select one of these four
modes:
The main difference between the LF and XT modes is
the gain of the internal inverter of the oscillator circuit,
which allows the different frequency ranges.
For more details on the device configuration bits, see
Section 17.0.
Crystal Start-up Time
Time
1998-2013 Microchip Technology Inc.
DS30289C-page 17
PIC17C7XX
FIGURE 4-2:
CRYSTAL OR CERAMIC
RESONATOR OPERATION
(XT OR LF OSC
CONFIGURATION)
FIGURE 4-3:
CRYSTAL OPERATION,
OVERTONE CRYSTALS
(XT OSC
CONFIGURATION)
C1
OSC1
OSC1
C1
XTAL
SLEEP
SLEEP
RF
C2
OSC2
OSC2
(Note 1)
To internal
logic
C2
See Table 4-1 and Table 4-2 for recommended values of C1
and C2.
A series resistor (Rs) may be required for AT strip
cut crystals.
TABLE 4-1:
L1
PIC17CXXX
0.1 F
PIC17CXXX
Note 1:
C3
CAPACITOR SELECTION FOR
CERAMIC RESONATORS
Oscillator
Type
Resonator
Frequency
Capacitor Range
C1 = C2(1)
LF
455 kHz
2.0 MHz
15 - 68 pF
10 - 33 pF
XT
4.0 MHz
8.0 MHz
16.0 MHz
22 - 68 pF
33 - 100 pF
33 - 100 pF
Higher capacitance increases the stability of the oscillator,
but also increases the start-up time. These values are for
design guidance only. Since each resonator has its own
characteristics, the user should consult the resonator manufacturer for appropriate values of external components.
Note 1: These values include all board capacitances on
this pin. Actual capacitor value depends on
board capacitance.
Resonators Used:
455 kHz
Panasonic EFO-A455K04B
0.3%
2.0 MHz
Murata Erie CSA2.00MG
0.5%
4.0 MHz
Murata Erie CSA4.00MG
0.5%
8.0 MHz
Murata Erie CSA8.00MT
0.5%
16.0 MHz
Murata Erie CSA16.00MX
0.5%
Resonators used did not have built-in capacitors.
To filter the fundamental frequency:
1 =
2
L1*C2 (2f)
Where f = tank circuit resonant frequency. This should be
midway between the fundamental and the 3rd overtone
frequencies of the crystal.
C3 blocks DC current to ground.
TABLE 4-2:
Osc
Type
CAPACITOR SELECTION FOR
CRYSTAL OSCILLATOR
Freq
C1(2)
C2(2)
LF
32 kHz
1 MHz
2 MHz
100-150 pF
10-68 pF
10-68 pF
100-150 pF
10-68 pF
10-68 pF
XT
2 MHz
4 MHz
8 MHz
16 MHz
24 MHz(1)
32 MHz(1)
47-100 pF
15-68 pF
15-47 pF
15-47 pF
15-47 pF
10-47 pF
47-100 pF
15-68 pF
15-47 pF
15-47 pF
15-47 pF
10-47 pF
Higher capacitance increases the stability of the oscillator,
but also increases the start-up time and the oscillator current. These values are for design guidance only. RS may be
required in XT mode to avoid overdriving the crystals with
low drive level specification. Since each crystal has its own
characteristics, the user should consult the crystal manufacturer for appropriate values for external components.
Note 1: Overtone crystals are used at 24 MHz and
higher. The circuit in Figure 4-3 should be used
to select the desired harmonic frequency.
2: These values include all board capacitances on
this pin. Actual capacitor value depends on
board capacitance.
Crystals Used:
DS30289C-page 18
32.768 kHz
Epson C-001R32.768K-A
20 PPM
1.0 MHz
ECS-10-13-1
50 PPM
2.0 MHz
ECS-20-20-1
50 PPM
4.0 MHz
ECS-40-20-1
50 PPM
8.0 MHz
ECS ECS-80-S-4
ECS-80-18-1
50 PPM
16.0 MHz
ECS-160-20-1
50 PPM
25 MHz
CTS CTS25M
50 PPM
32 MHz
CRYSTEK HF-2
50 PPM
1998-2013 Microchip Technology Inc.
PIC17C7XX
4.1.4
EXTERNAL CLOCK OSCILLATOR
FIGURE 4-5:
In the EC oscillator mode, the OSC1 input can be
driven by CMOS drivers. In this mode, the OSC1/
CLKIN pin is hi-impedance and the OSC2/CLKOUT pin
is the CLKOUT output (4 TOSC).
FIGURE 4-4:
EXTERNAL PARALLEL
RESONANT CRYSTAL
OSCILLATOR CIRCUIT
+5V
To Other
Devices
10 k
4.7 k
EXTERNAL CLOCK INPUT
OPERATION (EC OSC
CONFIGURATION)
PIC17CXXX
OSC1
74AS04
10 k
Clock from
OSC1
ext. system
CLKOUT
(FOSC/4)
XTAL
PIC17CXXX
OSC2
10k
20 pF
4.1.5
74AS04
EXTERNAL CRYSTAL OSCILLATOR
CIRCUIT
Either a prepackaged oscillator can be used, or a simple oscillator circuit with TTL gates can be built. Prepackaged oscillators provide a wide operating range
and better stability. A well designed crystal oscillator
will provide good performance with TTL gates. Two
types of crystal oscillator circuits can be used: one with
series resonance, or one with parallel resonance.
Figure 4-5 shows implementation of a parallel resonant
oscillator circuit. The circuit is designed to use the fundamental frequency of the crystal. The 74AS04 inverter
performs the 180-degree phase shift that a parallel
oscillator requires. The 4.7 k resistor provides the
negative feedback for stability. The 10 k potentiometer biases the 74AS04 in the linear region. This could
be used for external oscillator designs.
20 pF
Figure 4-6 shows a series resonant oscillator circuit.
This circuit is also designed to use the fundamental frequency of the crystal. The inverter performs a 180degree phase shift in a series resonant oscillator circuit. The 330 resistors provide the negative feedback
to bias the inverters in their linear region.
FIGURE 4-6:
EXTERNAL SERIES
RESONANT CRYSTAL
OSCILLATOR CIRCUIT
330
330
74AS04
74AS04
To Other
Devices
74AS04
PIC17CXXX
OSC1
0.1 F
XTAL
1998-2013 Microchip Technology Inc.
DS30289C-page 19
PIC17C7XX
4.1.6
RC OSCILLATOR
For timing insensitive applications, the RC device
option offers additional cost savings. RC oscillator frequency is a function of the supply voltage, the resistor
(REXT) and capacitor (CEXT) values, and the operating
temperature. In addition to this, oscillator frequency will
vary from unit to unit due to normal process parameter
variation. Furthermore, the difference in lead frame
capacitance between package types will also affect
oscillation frequency, especially for low CEXT values.
The user also needs to take into account variation due
to tolerance of external R and C components used.
Figure 4-7 shows how the R/C combination is connected to the PIC17CXXX. For REXT values below
2.2 k, the oscillator operation may become unstable,
or stop completely. For very high REXT values (e.g.
1 M), the oscillator becomes sensitive to noise,
humidity and leakage. Thus, we recommend to keep
REXT between 3 k and 100 k.
Although the oscillator will operate with no external
capacitor (CEXT = 0 pF), we recommend using values
above 20 pF for noise and stability reasons. With little
or no external capacitance, oscillation frequency can
vary dramatically due to changes in external capacitances, such as PCB trace capacitance or package
lead frame capacitance.
FIGURE 4-7:
RC OSCILLATOR MODE
VDD
PIC17CXXX
REXT
OSC1
Internal
Clock
CEXT
VSS
OSC2/CLKOUT
FOSC/4
4.1.6.1
RC Start-up
As the device voltage increases, the RC will immediately start its oscillations once the pin voltage levels
meet the input threshold specifications (parameter
#D032 and parameter #D042 in the electrical specification section). The time required for the RC to start oscillating depends on many factors. These include:
•
•
•
•
Resistor value used
Capacitor value used
Device VDD rise time
System temperature
See Section 21.0 for RC frequency variation from part
to part due to normal process variation. The variation is
larger for larger R (since leakage current variation will
affect RC frequency more for large R) and for smaller
C (since variation of input capacitance will affect RC
frequency more).
See Section 21.0 for variation of oscillator frequency
due to VDD for given REXT/CEXT values, as well as frequency variation due to operating temperature for
given R, C, and VDD values.
The oscillator frequency, divided by 4, is available on
the OSC2/CLKOUT pin and can be used for test purposes or to synchronize other logic (see Figure 4-8 for
waveform).
DS30289C-page 20
1998-2013 Microchip Technology Inc.
PIC17C7XX
4.2
Clocking Scheme/Instruction
Cycle
4.3
Instruction Flow/Pipelining
An “Instruction Cycle” consists of four Q cycles (Q1,
Q2, Q3 and Q4). The instruction fetch and execute are
pipelined such that fetch takes one instruction cycle,
while decode and execute takes another instruction
cycle. However, due to the pipelining, each instruction
effectively executes in one cycle. If an instruction
causes the program counter to change (e.g. GOTO),
then two cycles are required to complete the instruction
(Example 4-1).
The clock input (from OSC1) is internally divided by
four to generate four non-overlapping quadrature
clocks, namely Q1, Q2, Q3 and Q4. Internally, the program counter (PC) is incremented every Q1 and the
instruction is fetched from the program memory and
latched into the instruction register in Q4. The instruction is decoded and executed during the following Q1
through Q4. The clocks and instruction execution flow
are shown in Figure 4-8.
A fetch cycle begins with the program counter incrementing in Q1.
In the execution cycle, the fetched instruction is latched
into the “Instruction Register (IR)” in cycle Q1. This
instruction is then decoded and executed during the Q2,
Q3 and Q4 cycles. Data memory is read during Q2
(operand read) and written during Q4 (destination write).
FIGURE 4-8:
CLOCK/INSTRUCTION CYCLE
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
OSC1
Q1
Q2
Internal
Phase
Clock
Q3
Q4
PC
OSC2/CLKOUT
(RC mode)
EXAMPLE 4-1:
1. MOVLW 55h
PC
Fetch INST (PC)
Execute INST (PC-1)
PC+2
Fetch INST (PC+1)
Execute INST (PC)
Fetch INST (PC+2)
Execute INST (PC+1)
INSTRUCTION PIPELINE FLOW
TCY0
TCY1
Fetch 1
Execute 1
2. MOVWF PORTB
3. CALL SUB_1
4. BSF
PC+1
PORTA, BIT3 (Forced NOP)
5. Instruction @ address SUB_1
Fetch 2
TCY2
TCY3
TCY4
TCY5
Execute 2
Fetch 3
Execute 3
Fetch 4
Flush
Fetch SUB_1 Execute SUB_1
All instructions are single cycle, except for any program branches. These take two cycles since the fetched instruction is “flushed” from the pipeline, while the new instruction is being fetched and then executed.
1998-2013 Microchip Technology Inc.
DS30289C-page 21
PIC17C7XX
NOTES:
DS30289C-page 22
1998-2013 Microchip Technology Inc.
PIC17C7XX
5.0
RESET
The PIC17CXXX differentiates between various kinds
of RESET:
•
•
•
•
Power-on Reset (POR)
Brown-out Reset
MCLR Reset
WDT Reset
Note:
Some registers are not affected in any RESET condition, their status is unknown on POR and unchanged in
any other RESET. Most other registers are forced to a
“RESET state”. The TO and PD bits are set or cleared
differently in different RESET situations, as indicated in
Table 5-3. These bits, in conjunction with the POR and
BOR bits, are used in software to determine the nature
of the RESET. See Table 5-4 for a full description of the
RESET states of all registers.
FIGURE 5-1:
When the device enters the “RESET state”, the Data
Direction registers (DDR) are forced set, which will
make the I/O hi-impedance inputs. The RESET state of
some peripheral modules may force the I/O to other
operations, such as analog inputs or the system bus.
While the device is in a RESET state, the
internal phase clock is held in the Q1 state.
Any processor mode that allows external
execution will force the RE0/ALE pin as a
low output and the RE1/OE and RE2/WR
pins as high outputs.
A simplified block diagram of the On-Chip Reset Circuit
is shown in Figure 5-1.
SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT
External
Reset
MCLR
BOR
Module
Brown-out
Reset
WDT
Module
WDT
Time_Out
Reset
VDD Rise
Detect
S
Power_On_Reset
VDD
OST/PWRT
Chip_Reset
R
OST
Q
10-bit Ripple Counter
OSC1
PWRT
Enable PWRT
10-bit Ripple Counter
Enable OST
On-chip
RC OSC†
(Enable the PWRT timer
only during POR or BOR)
(If PWRT is invoked, or a Wake-up from
SLEEP and OSC type is XT or LF)
† This RC oscillator is shared with the WDT when not in a power-up sequence.
1998-2013 Microchip Technology Inc.
DS30289C-page 23
PIC17C7XX
5.1
Power-on Reset (POR), Power-up
Timer (PWRT), Oscillator Start-up
Timer (OST) and Brown-out Reset
(BOR)
5.1.1
POWER-ON RESET (POR)
The Power-on Reset circuit holds the device in RESET
until VDD is above the trip point (in the range of 1.4V 2.3V). The devices produce an internal RESET for both
rising and falling VDD. To take advantage of the POR,
just tie the MCLR/VPP pin directly (or through a resistor)
to VDD. This will eliminate external RC components
usually needed to create Power-on Reset. A minimum
rise time for VDD is required. See Electrical Specifications for details.
Figure 5-2 and Figure 5-3 show two possible POR
circuits.
FIGURE 5-2:
USING ON-CHIP POR
VDD
VDD
MCLR
PIC17CXXX
5.1.2
POWER-UP TIMER (PWRT)
The Power-up Timer provides a fixed 96 ms time-out
(nominal) on power-up. This occurs from the rising
edge of the internal POR signal if VDD and MCLR are
tied, or after the first rising edge of MCLR (detected
high). The Power-up Timer operates on an internal RC
oscillator. The chip is kept in RESET as long as the
PWRT is active. In most cases, the PWRT delay allows
VDD to rise to an acceptable level.
The power-up time delay will vary from chip to chip and
with VDD and temperature. See DC parameters for
details.
5.1.3
OSCILLATOR START-UP TIMER
(OST)
The Oscillator Start-up Timer (OST) provides a 1024
oscillator cycle (1024TOSC) delay whenever the PWRT
is invoked, or a wake-up from SLEEP event occurs in XT
or LF mode. The PWRT and OST operate in parallel.
The OST counts the oscillator pulses on the OSC1/
CLKIN pin. The counter only starts incrementing after
the amplitude of the signal reaches the oscillator input
thresholds. This delay allows the crystal oscillator or
resonator to stabilize before the device exits RESET.
The length of the time-out is a function of the crystal/
resonator frequency.
Figure 5-4 shows the operation of the OST circuit. In
this figure, the oscillator is of such a low frequency that
although enabled simultaneously, the OST does not
time-out until after the Power-up Timer time-out.
FIGURE 5-3:
EXTERNAL POWER-ON
RESET CIRCUIT (FOR
SLOW VDD POWER-UP)
FIGURE 5-4:
OSCILLATOR START-UP
TIME (LOW FREQUENCY)
POR or BOR Trip Point
VDD
VDD
VDD
D
R
R1
MCLR
C
PIC17CXXX
MCLR
OSC2
TOSC1
TOST
Note 1: An external Power-on Reset circuit is
required only if VDD power-up time is too
slow. The diode D helps discharge the capacitor quickly when VDD powers down.
2: R < 40 k is recommended to ensure that the
voltage drop across R does not exceed 0.2V
(max. leakage current spec. on the MCLR/
VPP pin is 5 A). A larger voltage drop will
degrade VIH level on the MCLR/VPP pin.
3: R1 = 100 to 1 k will limit any current flowing into MCLR from external capacitor C in
the event of MCLR/VPP pin breakdown due to
Electrostatic Discharge (ESD) or Electrical
Overstress (EOS).
OST TIME_OUT
PWRT TIME_OUT
TPWRT
INTERNAL RESET
This figure shows in greater detail the timings involved
with the oscillator start-up timer. In this example, the low
frequency crystal start-up time is larger than power-up
time (TPWRT).
TOSC1 = time for the crystal oscillator to react to an oscillation level detectable by the Oscillator Start-up Timer
(OST).
TOST = 1024TOSC.
DS30289C-page 24
1998-2013 Microchip Technology Inc.
PIC17C7XX
5.1.4
TIME-OUT SEQUENCE
If the device voltage is not within electrical specification
at the end of a time-out, the MCLR/VPP pin must be
held low until the voltage is within the device specification. The use of an external RC delay is sufficient for
many of these applications.
On power-up, the time-out sequence is as follows: First,
the internal POR signal goes high when the POR trip
point is reached. If MCLR is high, then both the OST and
PWRT timers start. In general, the PWRT time-out is
longer, except with low frequency crystals/resonators.
The total time-out also varies based on oscillator configuration. Table 5-1 shows the times that are associated
with the oscillator configuration. Figure 5-5 and Figure 56 display these time-out sequences.
TABLE 5-1:
The time-out sequence begins from the first rising edge
of MCLR.
Table 5-3 shows the RESET conditions for some special registers, while Table 5-4 shows the initialization
conditions for all the registers.
TIME-OUT IN VARIOUS SITUATIONS
Oscillator
Configuration
POR, BOR
Wake-up from
SLEEP
MCLR Reset
XT, LF
Greater of: 96 ms or 1024TOSC
1024TOSC
—
EC, RC
Greater of: 96 ms or 1024TOSC
—
—
TABLE 5-2:
STATUS BITS AND THEIR SIGNIFICANCE
POR
BOR(1)
TO
PD
0
0
1
1
Power-on Reset
1
1
1
0
MCLR Reset during SLEEP or interrupt wake-up from SLEEP
1
1
0
1
WDT Reset during normal operation
1
1
0
0
WDT Wake-up during SLEEP
1
1
1
1
MCLR Reset during normal operation
1
0
1
1
Brown-out Reset
0
0
0
x
Illegal, TO is set on POR
0
0
x
0
Illegal, PD is set on POR
x
x
1
1
CLRWDT instruction executed
Event
Note 1: When BODEN is enabled, else the BOR status bit is unknown.
TABLE 5-3:
RESET CONDITION FOR THE PROGRAM COUNTER AND THE CPUSTA REGISTER
PCH:PCL
CPUSTA(4)
OST Active
Power-on Reset
0000h
--11 1100
Yes
Brown-out Reset
0000h
--11 1110
Yes
MCLR Reset during normal operation
0000h
--11 1111
No
MCLR Reset during SLEEP
0000h
--11 1011
Yes(2)
WDT Reset during normal operation
Event
0000h
--11 0111
No
SLEEP(3)
0000h
--11 0011
Yes(2)
Interrupt Wake-up from SLEEP GLINTD is set
PC + 1
--11 1011
Yes(2)
PC + 1(1)
--10 1011
Yes(2)
WDT Reset during
GLINTD is clear
Legend: u = unchanged, x = unknown, - = unimplemented, read as '0'
Note 1: On wake-up, this instruction is executed. The instruction at the appropriate interrupt vector is fetched and
then executed.
2: The OST is only active (on wake-up) when the oscillator is configured for XT or LF modes.
3: The Program Counter = 0; that is, the device branches to the RESET vector and places SFRs in WDT
Reset states. This is different from the mid-range devices.
4: When BODEN is enabled, else the BOR status bit is unknown.
1998-2013 Microchip Technology Inc.
DS30289C-page 25
PIC17C7XX
In Figure 5-5, Figure 5-6 and Figure 5-7, the TPWRT
timer time-out is greater then the TOST timer time-out,
as would be the case in higher frequency crystals. For
lower frequency crystals (i.e., 32 kHz), TOST may be
greater.
FIGURE 5-5:
TIME-OUT SEQUENCE ON POWER-UP (MCLR TIED TO VDD)
VDD
MCLR
INTERNAL POR
TPWRT
PWRT TIME-OUT
TOST
OST TIME-OUT
INTERNAL RESET
TIME-OUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD)
FIGURE 5-6:
VDD
MCLR
INTERNAL POR
TPWRT
PWRT TIME-OUT
TOST
OST TIME-OUT
INTERNAL RESET
FIGURE 5-7:
SLOW RISE TIME (MCLR TIED TO VDD)
Minimum VDD Operating Voltage
5V
VDD
1V
0V
MCLR
INTERNAL POR
TPWRT
PWRT TIME-OUT
TOST
OST TIME-OUT
INTERNAL RESET
DS30289C-page 26
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 5-4:
Register
INITIALIZATION CONDITIONS FOR SPECIAL FUNCTION REGISTERS
Address
Power-on Reset
Brown-out Reset
MCLR Reset
WDT Reset
Wake-up from SLEEP
through Interrupt
Unbanked
INDF0
00h
N/A
N/A
N/A
FSR0
01h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PCL
02h
0000h
0000h
PCLATH
03h
0000 0000
uuuu uuuu
uuuu uuuu
ALUSTA
04h
1111 xxxx
1111 uuuu
1111 uuuu
T0STA
05h
0000 000-
0000 000-
0000 000-
06h
--11 11qq
--11 qquu
--uu qquu
07h
0000 0000
0000 0000
uuuu uuuu(1)
CPUSTA
(3)
INTSTA
PC + 1(2)
INDF1
08h
N/A
N/A
N/A
FSR1
09h
xxxx xxxx
uuuu uuuu
uuuu uuuu
WREG
0Ah
xxxx xxxx
uuuu uuuu
uuuu uuuu
TMR0L
0Bh
xxxx xxxx
uuuu uuuu
uuuu uuuu
TMR0H
0Ch
xxxx xxxx
uuuu uuuu
uuuu uuuu
TBLPTRL
0Dh
0000 0000
0000 0000
uuuu uuuu
TBLPTRH
0Eh
0000 0000
0000 0000
uuuu uuuu
BSR
0Fh
0000 0000
0000 0000
uuuu uuuu
10h
0-xx 11xx
0-uu 11uu
u-uu uuuu
DDRB
11h
1111 1111
1111 1111
uuuu uuuu
PORTB(4)
12h
xxxx xxxx
uuuu uuuu
uuuu uuuu
RCSTA1
13h
0000 -00x
0000 -00u
uuuu -uuu
RCREG1
14h
xxxx xxxx
uuuu uuuu
uuuu uuuu
TXSTA1
15h
0000 --1x
0000 --1u
uuuu --uu
TXREG1
16h
xxxx xxxx
uuuu uuuu
uuuu uuuu
SPBRG1
17h
0000 0000
0000 0000
uuuu uuuu
Bank 0
PORTA(4,6)
Legend: u = unchanged, x = unknown, - = unimplemented, read as '0', q = value depends on condition
Note 1: One or more bits in INTSTA, PIR1, PIR2 will be affected (to cause wake-up).
2: When the wake-up is due to an interrupt and the GLINTD bit is cleared, the PC is loaded with the interrupt
vector.
3: See Table 5-3 for RESET value of specific condition.
4: This is the value that will be in the port output latch.
5: When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this
port does not rely on these registers.
6: On any device RESET, these pins are configured as inputs.
1998-2013 Microchip Technology Inc.
DS30289C-page 27
PIC17C7XX
TABLE 5-4:
INITIALIZATION CONDITIONS FOR SPECIAL FUNCTION REGISTERS (CONTINUED)
Address
Power-on Reset
Brown-out Reset
MCLR Reset
WDT Reset
Wake-up from SLEEP
through Interrupt
DDRC(5)
10h
1111 1111
1111 1111
uuuu uuuu
PORTC(4,5)
11h
xxxx xxxx
uuuu uuuu
uuuu uuuu
DDRD(5)
12h
1111 1111
1111 1111
uuuu uuuu
PORTD(4,5)
13h
xxxx xxxx
uuuu uuuu
uuuu uuuu
DDRE(5)
14h
---- 1111
---- 1111
---- uuuu
PORTE(4,5)
15h
---- xxxx
---- uuuu
---- uuuu
PIR1
16h
x000 0010
u000 0010
uuuu uuuu(1)
PIE1
17h
0000 0000
0000 0000
uuuu uuuu
TMR1
10h
xxxx xxxx
uuuu uuuu
uuuu uuuu
TMR2
11h
xxxx xxxx
uuuu uuuu
uuuu uuuu
TMR3L
12h
xxxx xxxx
uuuu uuuu
uuuu uuuu
TMR3H
13h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PR1
14h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PR2
15h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PR3/CA1L
16h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PR3/CA1H
17h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PW1DCL
10h
xx-- ----
uu-- ----
uu-- ----
PW2DCL
11h
xx0- ----
uu0- ----
uuu- ----
PW1DCH
12h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PW2DCH
13h
xxxx xxxx
uuuu uuuu
uuuu uuuu
CA2L
14h
xxxx xxxx
uuuu uuuu
uuuu uuuu
CA2H
15h
xxxx xxxx
uuuu uuuu
uuuu uuuu
TCON1
16h
0000 0000
0000 0000
uuuu uuuu
TCON2
17h
0000 0000
0000 0000
uuuu uuuu
Register
Bank 1
Bank 2
Bank 3
Legend: u = unchanged, x = unknown, - = unimplemented, read as '0', q = value depends on condition
Note 1: One or more bits in INTSTA, PIR1, PIR2 will be affected (to cause wake-up).
2: When the wake-up is due to an interrupt and the GLINTD bit is cleared, the PC is loaded with the interrupt
vector.
3: See Table 5-3 for RESET value of specific condition.
4: This is the value that will be in the port output latch.
5: When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this
port does not rely on these registers.
6: On any device RESET, these pins are configured as inputs.
DS30289C-page 28
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 5-4:
Register
INITIALIZATION CONDITIONS FOR SPECIAL FUNCTION REGISTERS (CONTINUED)
Address
Power-on Reset
Brown-out Reset
MCLR Reset
WDT Reset
10h
000- 0010
000- 0010
Wake-up from SLEEP
through Interrupt
Bank 4
PIR2
uuu- uuuu(1)
PIE2
11h
000- 0000
000- 0000
uuu- uuuu
Unimplemented
12h
---- ----
---- ----
---- ----
RCSTA2
13h
0000 -00x
0000 -00u
uuuu -uuu
RCREG2
14h
xxxx xxxx
uuuu uuuu
uuuu uuuu
TXSTA2
15h
0000 --1x
0000 --1u
uuuu --uu
TXREG2
16h
xxxx xxxx
uuuu uuuu
uuuu uuuu
SPBRG2
17h
0000 0000
0000 0000
uuuu uuuu
DDRF
10h
1111 1111
1111 1111
uuuu uuuu
PORTF(4)
11h
0000 0000
0000 0000
uuuu uuuu
DDRG
12h
1111 1111
1111 1111
uuuu uuuu
PORTG(4)
13h
xxxx 0000
uuuu 0000
uuuu uuuu
ADCON0
14h
0000 -0-0
0000 -0-0
uuuu uuuu
ADCON1
15h
000- 0000
000- 0000
uuuu uuuu
ADRESL
16h
xxxx xxxx
uuuu uuuu
uuuu uuuu
ADRESH
17h
xxxx xxxx
uuuu uuuu
uuuu uuuu
SSPADD
10h
0000 0000
0000 0000
uuuu uuuu
SSPCON1
11h
0000 0000
0000 0000
uuuu uuuu
SSPCON2
12h
0000 0000
0000 0000
uuuu uuuu
SSPSTAT
13h
0000 0000
0000 0000
uuuu uuuu
SSPBUF
14h
xxxx xxxx
uuuu uuuu
uuuu uuuu
Unimplemented
15h
---- ----
---- ----
---- ----
Unimplemented
16h
---- ----
---- ----
---- ----
Unimplemented
17h
---- ----
---- ----
---- ----
Bank 5
Bank 6
Legend: u = unchanged, x = unknown, - = unimplemented, read as '0', q = value depends on condition
Note 1: One or more bits in INTSTA, PIR1, PIR2 will be affected (to cause wake-up).
2: When the wake-up is due to an interrupt and the GLINTD bit is cleared, the PC is loaded with the interrupt
vector.
3: See Table 5-3 for RESET value of specific condition.
4: This is the value that will be in the port output latch.
5: When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this
port does not rely on these registers.
6: On any device RESET, these pins are configured as inputs.
1998-2013 Microchip Technology Inc.
DS30289C-page 29
PIC17C7XX
TABLE 5-4:
INITIALIZATION CONDITIONS FOR SPECIAL FUNCTION REGISTERS (CONTINUED)
Address
Power-on Reset
Brown-out Reset
MCLR Reset
WDT Reset
Wake-up from SLEEP
through Interrupt
PW3DCL
10h
xx0- ----
uu0- ----
uuu- ----
PW3DCH
11h
xxxx xxxx
uuuu uuuu
uuuu uuuu
CA3L
12h
xxxx xxxx
uuuu uuuu
uuuu uuuu
CA3H
13h
xxxx xxxx
uuuu uuuu
uuuu uuuu
CA4L
14h
xxxx xxxx
uuuu uuuu
uuuu uuuu
CA4H
15h
xxxx xxxx
uuuu uuuu
uuuu uuuu
Register
Bank 7
TCON3
16h
-000 0000
-000 0000
-uuu uuuu
Unimplemented
17h
---- ----
---- ----
---- ----
10h
1111 1111
1111 1111
uuuu uuuu
11h
xxxx xxxx
uuuu uuuu
uuuu uuuu
DDRJ
12h
1111 1111
1111 1111
uuuu uuuu
PORTJ(4)
13h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PRODL
18h
xxxx xxxx
uuuu uuuu
uuuu uuuu
PRODH
19h
xxxx xxxx
uuuu uuuu
uuuu uuuu
Bank 8
DDRH
PORTH
(4)
Unbanked
Legend: u = unchanged, x = unknown, - = unimplemented, read as '0', q = value depends on condition
Note 1: One or more bits in INTSTA, PIR1, PIR2 will be affected (to cause wake-up).
2: When the wake-up is due to an interrupt and the GLINTD bit is cleared, the PC is loaded with the interrupt
vector.
3: See Table 5-3 for RESET value of specific condition.
4: This is the value that will be in the port output latch.
5: When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this
port does not rely on these registers.
6: On any device RESET, these pins are configured as inputs.
DS30289C-page 30
1998-2013 Microchip Technology Inc.
PIC17C7XX
5.1.5
BROWN-OUT RESET (BOR)
that may be implemented. Each needs to be evaluated
to determine if they match the requirements of the
application.
PIC17C7XX devices have on-chip Brown-out Reset
circuitry. This circuitry places the device into a RESET
when the device voltage falls below a trip point (BVDD).
This ensures that the device does not continue program execution outside the valid operation range of the
device. Brown-out Resets are typically used in AC line
applications, or large battery applications, where large
loads may be switched in (such as automotive).
Note:
FIGURE 5-8:
EXTERNAL BROWN-OUT
PROTECTION CIRCUIT 1
VDD
VDD
33k
Before using the on-chip Brown-out for a
voltage supervisory function, please
review the electrical specifications to
ensure that they meet your requirements.
10k
40 k
The BODEN configuration bit can disable (if clear/
programmed), or enable (if set) the Brown-out Reset
circuitry. If VDD falls below BVDD (typically 4.0 V,
paramter #D005 in electrical specification section), for
greater than parameter #35, the Brown-out situation
will reset the chip. A RESET is not guaranteed to occur
if VDD falls below BVDD for less than paramter #35. The
chip will remain in Brown-out Reset until VDD rises
above BVDD. The Power-up Timer and Oscillator Startup Timer will then be invoked. This will keep the chip in
RESET the greater of 96 ms and 1024 TOSC. If VDD
drops below BVDD while the Power-up Timer/Oscillator
Start-up Timer is running, the chip will go back into a
Brown-out Reset. The Power-up Timer/Oscillator Startup Timer will be initialized. Once VDD rises above
BVDD, the Power-up Timer/Oscillator Start-up Timer
will start their time delays. Figure 5-10 shows typical
Brown-out situations.
PIC17CXXX
This circuit will activate RESET when VDD goes below
(Vz + 0.7V) where Vz = Zener voltage.
FIGURE 5-9:
EXTERNAL BROWN-OUT
PROTECTION CIRCUIT 2
VDD
VDD
R1
Q1
MCLR
R2
In some applications, the Brown-out Reset trip point of
the device may not be at the desired level. Figure 5-8
and Figure 5-9 are two examples of external circuitry
40 k
PIC17CXXX
This brown-out circuit is less expensive, albeit less
accurate. Transistor Q1 turns off when VDD is below a
certain level such that:
VDD •
FIGURE 5-10:
MCLR
R1
R1 + R2
= 0.7V
BROWN-OUT SITUATIONS
VDD
Internal
RESET
BVDD Max.
BVDD Min.
Greater of 96 ms
and 1024 TOSC
VDD
Internal
RESET
BVDD Max.
BVDD Min.
< 96 ms
Greater of 96 ms
and 1024 TOSC
VDD
Internal
RESET
1998-2013 Microchip Technology Inc.
BVDD Max.
BVDD Min.
Greater of 96 ms
and 1024 TOSC
DS30289C-page 31
PIC17C7XX
NOTES:
DS30289C-page 32
1998-2013 Microchip Technology Inc.
PIC17C7XX
6.0
INTERRUPTS
PIC17C7XX devices have 18 sources of interrupt:
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
External interrupt from the RA0/INT pin
Change on RB7:RB0 pins
TMR0 Overflow
TMR1 Overflow
TMR2 Overflow
TMR3 Overflow
USART1 Transmit buffer empty
USART1 Receive buffer full
USART2 Transmit buffer empty
USART2 Receive buffer full
SSP Interrupt
SSP I2C bus collision interrupt
A/D conversion complete
Capture1
Capture2
Capture3
Capture4
T0CKI edge occurred
There are six registers used in the control and status of
interrupts. These are:
•
•
•
•
•
•
CPUSTA
INTSTA
PIE1
PIR1
PIE2
PIR2
When an interrupt is responded to, the GLINTD bit is
automatically set to disable any further interrupts, the
return address is pushed onto the stack and the PC is
loaded with the interrupt vector address. There are four
interrupt vectors. Each vector address is for a specific
interrupt source (except the peripheral interrupts, which
all vector to the same address). These sources are:
•
•
•
•
External interrupt from the RA0/INT pin
TMR0 Overflow
T0CKI edge occurred
Any peripheral interrupt
When program execution vectors to one of these interrupt vector addresses (except for the peripheral interrupts), the interrupt flag bit is automatically cleared.
Vectoring to the peripheral interrupt vector address
does not automatically clear the source of the interrupt.
In the peripheral Interrupt Service Routine, the
source(s) of the interrupt can be determined by testing
the interrupt flag bits. The interrupt flag bit(s) must be
cleared in software before re-enabling interrupts to
avoid infinite interrupt requests.
When an interrupt condition is met, that individual interrupt flag bit will be set, regardless of the status of its
corresponding mask bit or the GLINTD bit.
For external interrupt events, there will be an interrupt
latency. For two-cycle instructions, the latency could be
one instruction cycle longer.
The CPUSTA register contains the GLINTD bit. This is
the Global Interrupt Disable bit. When this bit is set, all
interrupts are disabled. This bit is part of the controller
core functionality and is described in the Section 6.4.
FIGURE 6-1:
The “return from interrupt” instruction, RETFIE, can be
used to mark the end of the Interrupt Service Routine.
When this instruction is executed, the stack is “POPed”
and the GLINTD bit is cleared (to re-enable interrupts).
INTERRUPT LOGIC
RBIF
RBIE
PIR1/PIE1
TMR3IF
TMR3IE
TMR2IF
TMR2IE
TMR1IF
TMR1IE
T0IF
T0IE
CA2IF
CA2IE
CA1IF
CA1IE
INTF
INTE
TX1IF
TX1IE
RC1IF
RC1IE
SSPIF
SSPIE
Wake-up (If in SLEEP mode)
or terminate long write
Interrupt to CPU
T0CKIF
T0CKIE
PEIF
PEIE
BCLIF
BCLIE
PIR2/PIE2
INTSTA
GLINTD (CPUSTA)
ADIF
ADIE
CA4IF
CA4IE
CA3IF
CA3IE
TX2IF
TX2IE
RC2IF
RC2IE
1998-2013 Microchip Technology Inc.
DS30289C-page 33
PIC17C7XX
6.1
Interrupt Status Register (INTSTA)
Care should be taken when clearing any of the INTSTA
register enable bits when interrupts are enabled
(GLINTD is clear). If any of the INTSTA flag bits (T0IF,
INTF, T0CKIF, or PEIF) are set in the same instruction
cycle as the corresponding interrupt enable bit is cleared,
the device will vector to the RESET address (0x00).
The Interrupt Status/Control register (INTSTA) contains
the flag and enable bits for non-peripheral interrupts.
The PEIF bit is a read only, bit wise OR of all the peripheral flag bits in the PIR registers (Figure 6-4 and
Figure 6-5).
Note:
Prior to disabling any of the INTSTA enable bits, the
GLINTD bit should be set (disabled).
All interrupt flag bits get set by their specified condition, even if the corresponding
interrupt enable bit is clear (interrupt disabled), or the GLINTD bit is set (all interrupts disabled).
REGISTER 6-1: INTSTA REGISTER (ADDRESS: 07h, UNBANKED)
R-0
PEIF
R/W-0
T0CKIF
R/W-0
T0IF
R/W-0
INTF
R/W-0
PEIE
R/W-0
T0CKIE
R/W-0
T0IE
bit 7
R/W-0
INTE
bit 0
bit 7
PEIF: Peripheral Interrupt Flag bit
This bit is the OR of all peripheral interrupt flag bits AND’ed with their corresponding enable bits.
The interrupt logic forces program execution to address (20h) when a peripheral interrupt is
pending.
1 = A peripheral interrupt is pending
0 = No peripheral interrupt is pending
bit 6
T0CKIF: External Interrupt on T0CKI Pin Flag bit
This bit is cleared by hardware, when the interrupt logic forces program execution to address (18h).
1 = The software specified edge occurred on the RA1/T0CKI pin
0 = The software specified edge did not occur on the RA1/T0CKI pin
bit 5
T0IF: TMR0 Overflow Interrupt Flag bit
This bit is cleared by hardware, when the interrupt logic forces program execution to address (10h).
1 = TMR0 overflowed
0 = TMR0 did not overflow
bit 4
INTF: External Interrupt on INT Pin Flag bit
This bit is cleared by hardware, when the interrupt logic forces program execution to address (08h).
1 = The software specified edge occurred on the RA0/INT pin
0 = The software specified edge did not occur on the RA0/INT pin
bit 3
PEIE: Peripheral Interrupt Enable bit
This bit acts as a global enable bit for the peripheral interrupts that have their corresponding
enable bits set.
1 = Enable peripheral interrupts
0 = Disable peripheral interrupts
bit 2
T0CKIE: External Interrupt on T0CKI Pin Enable bit
1 = Enable software specified edge interrupt on the RA1/T0CKI pin
0 = Disable interrupt on the RA1/T0CKI pin
bit 1
T0IE: TMR0 Overflow Interrupt Enable bit
1 = Enable TMR0 overflow interrupt
0 = Disable TMR0 overflow interrupt
bit 0
INTE: External Interrupt on RA0/INT Pin Enable bit
1 = Enable software specified edge interrupt on the RA0/INT pin
0 = Disable software specified edge interrupt on the RA0/INT pin
Legend:
DS30289C-page 34
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
6.2
Peripheral Interrupt Enable
Register1 (PIE1) and Register2
(PIE2)
These registers contains the individual enable bits for
the peripheral interrupts.
REGISTER 6-2: PIE1 REGISTER (ADDRESS: 17h, BANK 1)
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
RBIE
TMR3IE
TMR2IE
TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
bit 7
bit 0
bit 7
RBIE: PORTB Interrupt-on-Change Enable bit
1 = Enable PORTB interrupt-on-change
0 = Disable PORTB interrupt-on-change
bit 6
TMR3IE: TMR3 Interrupt Enable bit
1 = Enable TMR3 interrupt
0 = Disable TMR3 interrupt
bit 5
TMR2IE: TMR2 Interrupt Enable bit
1 = Enable TMR2 interrupt
0 = Disable TMR2 interrupt
bit 4
TMR1IE: TMR1 Interrupt Enable bit
1 = Enable TMR1 interrupt
0 = Disable TMR1 interrupt
bit 3
CA2IE: Capture2 Interrupt Enable bit
1 = Enable Capture2 interrupt
0 = Disable Capture2 interrupt
bit 2
CA1IE: Capture1 Interrupt Enable bit
1 = Enable Capture1 interrupt
0 = Disable Capture1 interrupt
bit 1
TX1IE: USART1 Transmit Interrupt Enable bit
1 = Enable USART1 Transmit buffer empty interrupt
0 = Disable USART1 Transmit buffer empty interrupt
bit 0
RC1IE: USART1 Receive Interrupt Enable bit
1 = Enable USART1 Receive buffer full interrupt
0 = Disable USART1 Receive buffer full interrupt
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 35
PIC17C7XX
REGISTER 6-3: PIE2 REGISTER (ADDRESS: 11h, BANK 4)
R/W-0
SSPIE
R/W-0
BCLIE
R/W-0
ADIE
U-0
—
R/W-0
CA4IE
R/W-0
CA3IE
R/W-0
TX2IE
bit 7
R/W-0
RC2IE
bit 0
bit 7
SSPIE: Synchronous Serial Port Interrupt Enable bit
1 = Enable SSP interrupt
0 = Disable SSP interrupt
bit 6
BCLIE: Bus Collision Interrupt Enable bit
1 = Enable bus collision interrupt
0 = Disable bus collision interrupt
bit 5
ADIE: A/D Module Interrupt Enable bit
1 = Enable A/D module interrupt
0 = Disable A/D module interrupt
bit 4
Unimplemented: Read as ‘0’
bit 3
CA4IE: Capture4 Interrupt Enable bit
1 = Enable Capture4 interrupt
0 = Disable Capture4 interrupt
bit 2
CA3IE: Capture3 Interrupt Enable bit
1 = Enable Capture3 interrupt
0 = Disable Capture3 interrupt
bit 1
TX2IE: USART2 Transmit Interrupt Enable bit
1 = Enable USART2 Transmit buffer empty interrupt
0 = Disable USART2 Transmit buffer empty interrupt
bit 0
RC2IE: USART2 Receive Interrupt Enable bit
1 = Enable USART2 Receive buffer full interrupt
0 = Disable USART2 Receive buffer full interrupt
Legend:
DS30289C-page 36
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
6.3
Peripheral Interrupt Request
Register1 (PIR1) and Register2
(PIR2)
Note:
These registers contains the individual flag bits for the
peripheral interrupts.
These bits will be set by the specified condition, even if the corresponding interrupt
enable bit is cleared (interrupt disabled), or
the GLINTD bit is set (all interrupts disabled).
Before enabling an interrupt, the user may
wish to clear the interrupt flag to ensure that
the program does not immediately branch to
the peripheral Interrupt Service Routine.
REGISTER 6-4: PIR1 REGISTER (ADDRESS: 16h, BANK 1)
R/W-x
RBIF
R/W-0
TMR3IF
R/W-0
TMR2IF
R/W-0
TMR1IF
R/W-0
CA2IF
R/W-0
CA1IF
R-1
TX1IF
bit 7
R-0
RC1IF
bit 0
bit 7
RBIF: PORTB Interrupt-on-Change Flag bit
1 = One of the PORTB inputs changed (software must end the mismatch condition)
0 = None of the PORTB inputs have changed
bit 6
TMR3IF: TMR3 Interrupt Flag bit
If Capture1 is enabled (CA1/PR3 = 1):
1 = TMR3 overflowed
0 = TMR3 did not overflow
If Capture1 is disabled (CA1/PR3 = 0):
1 = TMR3 value has rolled over to 0000h from equalling the period register (PR3H:PR3L) value
0 = TMR3 value has not rolled over to 0000h from equalling the period register (PR3H:PR3L)
value
bit 5
TMR2IF: TMR2 Interrupt Flag bit
1 = TMR2 value has rolled over to 0000h from equalling the period register (PR2) value
0 = TMR2 value has not rolled over to 0000h from equalling the period register (PR2) value
bit 4
TMR1IF: TMR1 Interrupt Flag bit
If TMR1 is in 8-bit mode (T16 = 0):
1 = TMR1 value has rolled over to 0000h from equalling the period register (PR1) value
0 = TMR1 value has not rolled over to 0000h from equalling the period register (PR1) value
If Timer1 is in 16-bit mode (T16 = 1):
1 = TMR2:TMR1 value has rolled over to 0000h from equalling the period register (PR2:PR1)
value
0 = TMR2:TMR1 value has not rolled over to 0000h from equalling the period register (PR2:PR1)
value
bit 3
CA2IF: Capture2 Interrupt Flag bit
1 = Capture event occurred on RB1/CAP2 pin
0 = Capture event did not occur on RB1/CAP2 pin
bit 2
CA1IF: Capture1 Interrupt Flag bit
1 = Capture event occurred on RB0/CAP1 pin
0 = Capture event did not occur on RB0/CAP1 pin
bit 1
TX1IF: USART1 Transmit Interrupt Flag bit (state controlled by hardware)
1 = USART1 Transmit buffer is empty
0 = USART1 Transmit buffer is full
bit 0
RC1IF: USART1 Receive Interrupt Flag bit (state controlled by hardware)
1 = USART1 Receive buffer is full
0 = USART1 Receive buffer is empty
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 37
PIC17C7XX
REGISTER 6-5: PIR2 REGISTER (ADDRESS: 10h, BANK 4)
R/W-0
SSPIF
R/W-0
BCLIF
R/W-0
ADIF
U-0
—
R/W-0
CA4IF
R/W-0
CA3IF
R-1
TX2IF
bit 7
bit 7
R-0
RC2IF
bit 0
SSPIF: Synchronous Serial Port (SSP) Interrupt Flag bit
1 = The SSP interrupt condition has occurred and must be cleared in software before returning
from the Interrupt Service Routine. The conditions that will set this bit are:
SPI:
A transmission/reception has taken place.
I2 C Slave/Master:
A transmission/reception has taken place.
I2 C Master:
The initiated START condition was completed by the SSP module.
The initiated STOP condition was completed by the SSP module.
The initiated Restart condition was completed by the SSP module.
The initiated Acknowledge condition was completed by the SSP module.
A START condition occurred while the SSP module was idle (Multi-master system).
A STOP condition occurred while the SSP module was idle (Multi-master system).
0 = An SSP interrupt condition has NOT occurred
bit 6
BCLIF: Bus Collision Interrupt Flag bit
1 = A bus collision has occurred in the SSP, when configured for I2C Master mode
0 = No bus collision has occurred
bit 5
ADIF: A/D Module Interrupt Flag bit
1 = An A/D conversion is complete
0 = An A/D conversion is not complete
bit 4
Unimplemented: Read as '0'
bit 3
CA4IF: Capture4 Interrupt Flag bit
1 = Capture event occurred on RE3/CAP4 pin
0 = Capture event did not occur on RE3/CAP4 pin
bit 2
CA3IF: Capture3 Interrupt Flag bit
1 = Capture event occurred on RG4/CAP3 pin
0 = Capture event did not occur on RG4/CAP3 pin
bit 1
TX2IF:USART2 Transmit Interrupt Flag bit (state controlled by hardware)
1 = USART2 Transmit buffer is empty
0 = USART2 Transmit buffer is full
bit 0
RC2IF: USART2 Receive Interrupt Flag bit (state controlled by hardware)
1 = USART2 Receive buffer is full
0 = USART2 Receive buffer is empty
Legend:
DS30289C-page 38
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
6.4
Interrupt Operation
6.5
Global Interrupt Disable bit, GLINTD (CPUSTA),
enables all unmasked interrupts (if clear), or disables
all interrupts (if set). Individual interrupts can be disabled through their corresponding enable bits in the
INTSTA register. Peripheral interrupts need either the
global peripheral enable PEIE bit disabled, or the specific peripheral enable bit disabled. Disabling the
peripherals via the global peripheral enable bit, disables all peripheral interrupts. GLINTD is set on
RESET (interrupts disabled).
The RETFIE instruction clears the GLINTD bit while
forcing the Program Counter (PC) to the value loaded
at the Top-of-Stack.
When an interrupt is responded to, the GLINTD bit is
automatically set to disable any further interrupt, the
return address is pushed onto the stack and the PC is
loaded with the interrupt vector. There are four interrupt
vectors which help reduce interrupt latency.
The peripheral interrupt vector has multiple interrupt
sources. Once in the peripheral Interrupt Service Routine, the source(s) of the interrupt can be determined by
polling the interrupt flag bits. The peripheral interrupt
flag bit(s) must be cleared in software before reenabling interrupts to avoid continuous interrupts.
The PIC17C7XX devices have four interrupt vectors.
These vectors and their hardware priority are shown in
Table 6-1. If two enabled interrupts occur “at the same
time”, the interrupt of the highest priority will be serviced first. This means that the vector address of that
interrupt will be loaded into the program counter (PC).
TABLE 6-1:
Address
0008h
0010h
0018h
0020h
INTERRUPT VECTORS/
PRIORITIES
Vector
External Interrupt on RA0/
INT pin (INTF)
TMR0 Overflow Interrupt
(T0IF)
External Interrupt on T0CKI
(T0CKIF)
Peripherals (PEIF)
Priority
1 (Highest)
2
3
4 (Lowest)
Note 1: Individual interrupt flag bits are set, regardless of the status of their corresponding
mask bit or the GLINTD bit.
2: Before disabling any of the INTSTA enable
bits, the GLINTD bit should be set
(disabled).
1998-2013 Microchip Technology Inc.
RA0/INT Interrupt
The external interrupt on the RA0/INT pin is edge triggered. Either the rising edge if the INTEDG bit
(T0STA) is set, or the falling edge if the INTEDG bit
is clear. When a valid edge appears on the RA0/INT
pin, the INTF bit (INTSTA) is set. This interrupt can
be disabled by clearing the INTE control bit
(INTSTA). The INT interrupt can wake the processor from SLEEP. See Section 17.4 for details on
SLEEP operation.
6.6
T0CKI Interrupt
The external interrupt on the RA1/T0CKI pin is edge
triggered. Either the rising edge if the T0SE bit
(T0STA) is set, or the falling edge if the T0SE bit is
clear. When a valid edge appears on the RA1/T0CKI
pin, the T0CKIF bit (INTSTA) is set. This interrupt
can be disabled by clearing the T0CKIE control bit
(INTSTA). The T0CKI interrupt can wake up the
processor from SLEEP. See Section 17.4 for details on
SLEEP operation.
6.7
Peripheral Interrupt
The peripheral interrupt flag indicates that at least one
of the peripheral interrupts occurred (PEIF is set). The
PEIF bit is a read only bit and is a bit wise OR of all the
flag bits in the PIR registers AND’d with the corresponding enable bits in the PIE registers. Some of the peripheral interrupts can wake the processor from SLEEP.
See Section 17.4 for details on SLEEP operation.
6.8
Context Saving During Interrupts
During an interrupt, only the returned PC value is saved
on the stack. Typically, users may wish to save key registers during an interrupt; e.g. WREG, ALUSTA and the
BSR registers. This requires implementation in software.
Example 6-2 shows the saving and restoring of information for an Interrupt Service Routine. This is for a
simple interrupt scheme, where only one interrupt may
occur at a time (no interrupt nesting). The SFRs are
stored in the non-banked GPR area.
Example 6-2 shows the saving and restoring of information for a more complex Interrupt Service Routine.
This is useful where nesting of interrupts is required. A
maximum of 6 levels can be done by this example. The
BSR is stored in the non-banked GPR area, while the
other registers would be stored in a particular bank.
Therefore, 6 saves may be done with this routine (since
there are 6 non-banked GPR registers). These routines
require a dedicated indirect addressing register, FSR0,
to be selected for this.
The PUSH and POP code segments could either be in
each Interrupt Service Routine, or could be subroutines
that were called. Depending on the application, other
registers may also need to be saved.
DS30289C-page 39
DS30289C-page 40
Instruction
Executed
System Bus
Instruction
Fetched
PC
GLINTD
INTF or
T0CKIF
RA0/INT or
RA1/T0CKI
PC
Q2
PC
Q4
Inst (PC)
Q3
Q1
Q4
Inst (PC+1)
PC + 1
Q3
Inst (PC)
Addr
Q2
Q1
Q4
Inst (PC+1)
Q3
Dummy
Addr
Q2
Q1
Q3
Q4
Dummy
Addr Inst (Vector)
Addr (Vector)
Q2
Q1
Addr
Q2
YY
Q4
RETFIE
Q3
Q1
Q3
Q4
Inst (YY + 1)
RETFIE
Addr
YY + 1
Q2
Q1
Q3
Dummy
PC + 1
Q2
Q4
FIGURE 6-2:
OSC2
OSC1
Q1
PIC17C7XX
INT PIN/T0CKI PIN INTERRUPT TIMING
1998-2013 Microchip Technology Inc.
PIC17C7XX
EXAMPLE 6-1:
SAVING STATUS AND WREG IN RAM (SIMPLE)
; The addresses that are used to store the CPUSTA and WREG values must be in the data memory
; address range of 1Ah - 1Fh. Up to 6 locations can be saved and restored using the MOVFP
; instruction. This instruction neither affects the status bits, nor corrupts the WREG register.
;
UNBANK1
EQU
0x01A
; Address for 1st location to save
UNBANK2
EQU
0x01B
; Address for 2nd location to save
UNBANK3
EQU
0x01C
; Address for 3rd location to save
UNBANK4
EQU
0x01D
; Address for 4th location to save
UNBANK5
EQU
0x01E
; Address for 5th location to save
;
(Label Not used in program)
UNBANK6
EQU
0x01F
; Address for 6th location to save
;
(Label Not used in program)
;
:
; At Interrupt Vector Address
PUSH
MOVFP
ALUSTA, UNBANK1
; Push ALUSTA value
MOVFP
BSR, UNBANK2
; Push BSR value
MOVFP
WREG, UNBANK3
; Push WREG value
MOVFP
PCLATH, UNBANK4
; Push PCLATH value
;
:
; Interrupt Service Routine (ISR) code
;
POP
MOVFP
UNBANK4, PCLATH
; Restore PCLATH value
MOVFP
UNBANK3, WREG
; Restore WREG value
MOVFP
UNBANK2, BSR
; Restore BSR value
MOVFP
UNBANK1, ALUSTA
; Restore ALUSTA value
;
RETFIE
; Return from interrupt (enable interrupts)
1998-2013 Microchip Technology Inc.
DS30289C-page 41
PIC17C7XX
EXAMPLE 6-2:
SAVING STATUS AND WREG IN RAM (NESTED)
; The addresses that are used to store the CPUSTA and WREG values must be in the data memory
; address range of 1Ah - 1Fh. Up to 6 locations can be saved and restored using the MOVFP
; instruction. This instruction neither affects the status bits, nor corrupts the WREG register.
; This routine uses the FRS0, so it controls the FS1 and FS0 bits in the ALUSTA register.
;
Nobank_FSR
EQU
0x40
Bank_FSR
EQU
0x41
ALU_Temp
EQU
0x42
WREG_TEMP
EQU
0x43
BSR_S1
EQU
0x01A
; 1st location to save BSR
BSR_S2
EQU
0x01B
; 2nd location to save BSR (Label Not used in program)
BSR_S3
EQU
0x01C
; 3rd location to save BSR (Label Not used in program)
BSR_S4
EQU
0x01D
; 4th location to save BSR (Label Not used in program)
BSR_S5
EQU
0x01E
; 5th location to save BSR (Label Not used in program)
BSR_S6
EQU
0x01F
; 6th location to save BSR (Label Not used in program)
;
INITIALIZATION
;
CALL
CLEAR_RAM
; Must Clear all Data RAM
;
INIT_POINTERS
; Must Initialize the pointers for POP and PUSH
CLRF
BSR, F
; Set All banks to 0
CLRF
ALUSTA, F
; FSR0 post increment
BSF
ALUSTA, FS1
CLRF
WREG, F
; Clear WREG
MOVLW
BSR_S1
; Load FSR0 with 1st address to save BSR
MOVWF
FSR0
MOVWF
Nobank_FSR
MOVLW
0x20
MOVWF
Bank_FSR
:
:
; Your code
:
:
; At Interrupt Vector Address
PUSH
BSF
ALUSTA, FS0
; FSR0 has auto-increment, does not affect status bits
BCF
ALUSTA, FS1
; does not affect status bits
MOVFP
BSR, INDF0
; No Status bits are affected
CLRF
BSR, F
; Peripheral and Data RAM Bank 0 No Status bits are affected
MOVPF
ALUSTA, ALU_Temp
;
MOVPF
FSR0, Nobank_FSR
; Save the FSR for BSR values
MOVPF
WREG, WREG_TEMP
;
MOVFP
Bank_FSR, FSR0
; Restore FSR value for other values
MOVFP
ALU_Temp, INDF0
; Push ALUSTA value
MOVFP
WREG_TEMP, INDF0
; Push WREG value
MOVFP
PCLATH, INDF0
; Push PCLATH value
MOVPF
FSR0, Bank_FSR
; Restore FSR value for other values
MOVFP
Nobank_FSR, FSR0
;
;
:
; Interrupt Service Routine (ISR) code
;
POP
CLRF
ALUSTA, F
; FSR0 has auto-decrement, does not affect status bits
MOVFP
Bank_FSR, FSR0
; Restore FSR value for other values
DECF
FSR0, F
;
MOVFP
INDF0, PCLATH
; Pop PCLATH value
MOVFP
INDF0, WREG
; Pop WREG value
BSF
ALUSTA, FS1
; FSR0 does not change
MOVPF
INDF0, ALU_Temp
; Pop ALUSTA value
MOVPF
FSR0, Bank_FSR
; Restore FSR value for other values
DECF
Nobank_FSR, F
;
MOVFP
Nobank_FSR, FSR0
; Save the FSR for BSR values
MOVFP
ALU_Temp, ALUSTA
;
MOVFP
INDF0, BSR
; No Status bits are affected
;
RETFIE
; Return from interrupt (enable interrupts)
DS30289C-page 42
1998-2013 Microchip Technology Inc.
PIC17C7XX
7.0
MEMORY ORGANIZATION
There are two memory blocks in the PIC17C7XX; program memory and data memory. Each block has its
own bus, so that access to each block can occur during
the same oscillator cycle.
The data memory can further be broken down into
General Purpose RAM and the Special Function Registers (SFRs). The operation of the SFRs that control
the “core” are described here. The SFRs used to control the peripheral modules are described in the section
discussing each individual peripheral module.
7.1
FIGURE 7-1:
PC
16
CALL, RETURN
RETFIE, RETLW
Stack Level 1
Stack Level 16
Program Memory Organization
PROGRAM MEMORY OPERATION
The PIC17C7XX can operate in one of four possible
program memory configurations. The configuration is
selected by configuration bits. The possible modes are:
0000h
INT Pin Interrupt Vector
0008h
Timer0 Interrupt Vector
0010h
T0CKI Pin Interrupt Vector
0018h
Peripheral Interrupt Vector
0020h
0021h
1FFFh
(PIC17C752
PIC17C762)
Microprocessor
Microcontroller
Extended Microcontroller
Protected Microcontroller
The Microcontroller and Protected Microcontroller
modes only allow internal execution. Any access
beyond the program memory reads unknown data. The
Protected Microcontroller mode also enables the code
protection feature.
The Extended Microcontroller mode accesses both
the internal program memory, as well as external program memory. Execution automatically switches
between internal and external memory. The 16-bits of
address allow a program memory range of 64K-words.
The Microprocessor mode only accesses the external
program memory. The on-chip program memory is
ignored. The 16-bits of address allow a program memory range of 64K-words. Microprocessor mode is the
default mode of an unprogrammed device.
The different modes allow different access to the configuration bits, test memory and boot ROM. Table 7-1
lists which modes can access which areas in memory.
Test Memory and Boot Memory are not required for
normal operation of the device. Care should be taken
to ensure that no unintended branches occur to these
areas.
1998-2013 Microchip Technology Inc.
3FFFh
(PIC17C756A
PIC17C766)
Configuration Memory
Space
•
•
•
•
RESET Vector
User Memory
Space(1)
PIC17C7XX devices have a 16-bit program counter
capable of addressing a 64K x 16 program memory
space. The RESET vector is at 0000h and the interrupt
vectors are at 0008h, 0010h, 0018h, and 0020h
(Figure 7-1).
7.1.1
PROGRAM MEMORY MAP
AND STACK
FOSC0
FOSC1
WDTPS0
WDTPS1
PM0
Reserved
PM1
Reserved
Reserved
BODEN
PM2
Test EPROM
FDFFh
FE00h
FE01h
FE02h
FE03h
FE04h
FE05h
FE06h
FE07h
FE08h
FE0Dh
FE0Eh
FE0Fh
FE10h
FF5Fh
FF60h
Boot ROM
FFFFh
Note 1: User memory space may be internal, external,
or both. The memory configuration depends
on the processor mode.
DS30289C-page 43
PIC17C7XX
MODE MEMORY ACCESS
Internal
Program
Memory
Configuration Bits,
Test Memory,
Boot ROM
Microprocessor
No Access
No Access
Microcontroller
Access
Access
Extended
Microcontroller
Access
No Access
Protected
Microcontroller
Access
Access
MEMORY MAP IN DIFFERENT MODES
Extended
Microcontroller
Mode
Microcontroller
Modes
0000h
0000h
0000h
01FFFh
On-chip
Program
Memory
01FFFh
2000h
2000h
External
Program
Memory
External
Program
Memory
PIC17C752/762
FE00h Config. Bits
Test Memory
FFFFh Boot ROM
FFFFh
FFFFh
OFF-CHIP
ON-CHIP
OFF-CHIP
ON-CHIP
00h
FFh
OFF-CHIP
ON-CHIP
00h
120h
00h
120h
1FFh
FFh
ON-CHIP
120h
1FFh
FFh
ON-CHIP
0000h
On-chip
Program
Memory
3FFFh
4000h
3FFFh
External
Program
Memory
1FFh
ON-CHIP
0000h
0000h
On-chip
Program
Memory
4000h
External
Program
Memory
PIC17C756A/766
FE00h Config. Bits
Test Memory
FFFFh Boot ROM
FFFFh
FFFFh
OFF-CHIP
ON-CHIP
00h
OFF-CHIP
FFh
ON-CHIP
OFF-CHIP
1FFh 2FFh 3FFh
ON-CHIP
120h 220h 320h
120h 220h 320h
FFh
ON-CHIP
00h
00h
120h 220h 320h
DS30289C-page 44
On-chip
Program
Memory
PROGRAM SPACE
Microprocessor
Mode
DATA SPACE
FIGURE 7-2:
Regardless of the processor mode, data memory is
always on-chip.
PROGRAM SPACE
Operating
Mode
The PIC17C7XX can operate in modes where the program memory is off-chip. They are the Microprocessor
and Extended Microcontroller modes. The Microprocessor mode is the default for an unprogrammed
device.
1FFh 2FFh 3FFh
ON-CHIP
FFh
1FFh 2FFh 3FFh
ON-CHIP
DATA SPACE
TABLE 7-1:
1998-2013 Microchip Technology Inc.
PIC17C7XX
7.1.2
EXTERNAL MEMORY INTERFACE
When either Microprocessor or Extended Microcontroller mode is selected, PORTC, PORTD and PORTE are
configured as the system bus. PORTC and PORTD are
the multiplexed address/data bus and PORTE is
for the control signals. External components are
needed to demultiplex the address and data. This can
be done as shown in Figure 7-4. The waveforms of
address and data are shown in Figure 7-3. For complete timings, please refer to the electrical specification
section.
In Extended Microcontroller mode, when the device is
executing out of internal memory, the control signals
will continue to be active. That is, they indicate the
action that is occurring in the internal memory. The
external memory access is ignored.
The following selection is for use with Microchip
EPROMs. For interfacing to other manufacturers memory, please refer to the electrical specifications of the
desired PIC17C7XX device, as well as the desired
memory device to ensure compatibility.
TABLE 7-2:
FIGURE 7-3:
EXTERNAL PROGRAM
MEMORY ACCESS
WAVEFORMS
EPROM MEMORY ACCESS
TIME ORDERING SUFFIX
PIC17C7XX
Oscillator
Frequency
Instruction
Cycle Time
(TCY)
EPROM Suffix
8 MHz
500 ns
-25
ALE
16 MHz
250 ns
-15
OE
20 MHz
200 ns
-10
25 MHz
160 ns
-70
Q1
AD
Q2
Q4
Q3
Address out Data in
Q1
Q2
Q3
Address out
Q4
Q1
Data out
'1'
WR
Read Cycle
Write Cycle
The system bus requires that there is no bus conflict
(minimal leakage), so the output value (address) will be
capacitively held at the desired value.
As the speed of the processor increases, external
EPROM memory with faster access time must be used.
Table 7-2 lists external memory speed requirements for
a given PIC17C7XX device frequency.
FIGURE 7-4:
Note:
The access times for this requires the use
of fast SRAMs.
The electrical specifications now include timing specifications for the memory interface with PIC17LCXXX
devices. These specifications reflect the capability of
the device by characterization. Please validate your
design with these timings.
TYPICAL EXTERNAL PROGRAM MEMORY CONNECTION DIAGRAM
AD15-AD0
A15-A0
AD7-AD0
373(3)
PIC17CXXX
Memory(3)
(MSB)
Memory(3)
(LSB)
Ax-A0
Ax-A0
D7-D0
D7-D0
CE
OE
AD15-AD8
CE
WR(2)
OE WR(2)
373(3)
ALE
138(1)
I/O(1)
OE
WR
Note 1: Use of I/O pins is only required for paged memory.
2: This signal is unused for ROM and EPROM devices.
3: 16-bit wide devices are now common and could be used instead of 8-bit wide devices.
1998-2013 Microchip Technology Inc.
DS30289C-page 45
PIC17C7XX
7.2
Data Memory Organization
Data memory is partitioned into two areas. The first is
the General Purpose Registers (GPR) area, and the
second is the Special Function Registers (SFR) area.
The SFRs control and provide status of device operation.
Portions of data memory are banked, this occurs in
both areas. The GPR area is banked to allow greater
than 232 bytes of general purpose RAM.
Banking requires the use of control bits for bank selection. These control bits are located in the Bank Select
Register (BSR). If an access is made to the unbanked
region, the BSR bits are ignored. Figure 7-5 shows the
data memory map organization.
Instructions MOVPF and MOVFP provide the means to
move values from the peripheral area (“P”) to any location in the register file (“F”), and vice-versa. The definition of the “P” range is from 0h to 1Fh, while the “F”
range is 0h to FFh. The “P” range has six more locations than peripheral registers, which can be used as
General Purpose Registers. This can be useful in some
applications where variables need to be copied to other
locations in the general purpose RAM (such as saving
status information during an interrupt).
The entire data memory can be accessed either
directly, or indirectly (through file select registers FSR0
and FSR1) (see Section 7.4). Indirect addressing uses
the appropriate control bits of the BSR for access into
the banked areas of data memory. The BSR is
explained in greater detail in Section 7.8.
DS30289C-page 46
7.2.1
GENERAL PURPOSE REGISTER
(GPR)
All devices have some amount of GPR area. The GPRs
are 8-bits wide. When the GPR area is greater than
232, it must be banked to allow access to the additional
memory space.
All the PIC17C7XX devices have banked memory in
the GPR area. To facilitate switching between these
banks, the MOVLR bank instruction has been added to
the instruction set. GPRs are not initialized by a Poweron Reset and are unchanged on all other RESETS.
7.2.2
SPECIAL FUNCTION REGISTERS
(SFR)
The SFRs are used by the CPU and peripheral functions to control the operation of the device (Figure 7-5).
These registers are static RAM.
The SFRs can be classified into two sets, those associated with the “core” function and those related to the
peripheral functions. Those registers related to the
“core” are described here, while those related to a
peripheral feature are described in the section for each
peripheral feature.
The peripheral registers are in the banked portion of
memory, while the core registers are in the unbanked
region. To facilitate switching between the peripheral
banks, the MOVLB bank instruction has been provided.
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 7-5:
Addr
Unbanked
00h
01h
02h
03h
04h
05h
06h
07h
08h
09h
0Ah
0Bh
0Ch
0Dh
0Eh
0Fh
INDF0
10h
11h
12h
13h
14h
15h
16h
17h
PIC17C7XX REGISTER FILE MAP
FSR0
PCL
PCLATH
ALUSTA
T0STA
CPUSTA
INTSTA
INDF1
FSR1
WREG
TMR0L
TMR0H
TBLPTRL
TBLPTRH
BSR
Bank 0
Bank 1(1)
Bank 2(1)
Bank 3(1)
Bank 4(1)
Bank 5(1)
Bank 6(1)
Bank 7(1)
Bank 8(1,4)
PORTA
DDRC
TMR1
PW1DCL
PIR2
DDRF
SSPADD
PW3DCL
DDRH
PORTH
DDRB
PORTC
TMR2
PW2DCL
PIE2
PORTF
SSPCON1
PW3DCH
PORTB
DDRD
TMR3L
PW1DCH
—
DDRG
SSPCON2
CA3L
DDRJ
RCSTA1
PORTD
TMR3H
PW2DCH
RCSTA2
PORTG
SSPSTAT
CA3H
PORTJ
RCREG1
DDRE
PR1
CA2L
RCREG2
ADCON0
SSPBUF
CA4L
—
TXSTA1
PORTE
PR2
CA2H
TXSTA2
ADCON1
—
CA4H
—
TXREG1
PIR1
PR3L/CA1L
TCON1
TXREG2
ADRESL
—
TCON3
—
SPBRG1
PIE1
PR3H/CA1H
TCON2
SPBRG2
ADRESH
—
—
—
Bank 0(2)
Bank 1(2)
Bank 2(2)
Bank 3(2,3)
General
Purpose
RAM
General
Purpose
RAM
General
Purpose
RAM
General
Purpose
RAM
Unbanked
18h
19h
1Ah
1Fh
PRODL
PRODH
General
Purpose
RAM
20h
FFh
Note 1: SFR file locations 10h - 17h are banked. The lower nibble of the BSR specifies the bank. All unbanked
SFRs ignore the Bank Select Register (BSR) bits.
2: General Purpose Registers (GPR) locations 20h - FFh, 120h - 1FFh, 220h - 2FFh, and 320h - 3FFh are
banked. The upper nibble of the BSR specifies this bank. All other GPRs ignore the Bank Select Register
(BSR) bits.
3: RAM bank 3 is not implemented on the PIC17C752 and the PIC17C762. Reading any unimplemented register reads ‘0’s.
4: Bank 8 is only implemented on the PIC17C76X devices.
1998-2013 Microchip Technology Inc.
DS30289C-page 47
PIC17C7XX
TABLE 7-3:
Address
SPECIAL FUNCTION REGISTERS
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Unbanked
00h
INDF0
01h
FSR0
02h
PCL
Uses contents of FSR0 to address Data Memory (not a physical register)
Indirect Data Memory Address Pointer 0
Low order 8-bits of PC
03h(1)
04h
05h
PCLATH
ALUSTA
T0STA
Holding Register for upper 8-bits of PC
FS3
FS2
FS1
FS0
INTEDG
T0SE
T0CS
T0PS3
06h(2)
CPUSTA
INTSTA
INDF1
FSR1
WREG
TMR0L
TMR0H
TBLPTRL
TBLPTRH
BSR
—
—
STKAV
GLINTD
TO
PD
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
Uses contents of FSR1 to address Data Memory (not a physical register)
Indirect Data Memory Address Pointer 1
Working Register
TMR0 Register; Low Byte
TMR0 Register; High Byte
Low Byte of Program Memory Table Pointer
High Byte of Program Memory Table Pointer
Bank Select Register
07h
08h
09h
0Ah
0Bh
0Ch
0Dh
0Eh
0Fh
Bit 0
Value on
POR,
BOR
MCLR,
WDT
---- ---- ---- ---xxxx xxxx uuuu uuuu
0000 0000 0000 0000
0000 0000 uuuu uuuu
OV
T0PS2
Z
T0PS1
DC
T0PS0
C
—
1111 xxxx 1111 uuuu
POR
T0IE
BOR
INTE
--11 11qq --11 qquu
0000 000- 0000 000-
0000 0000 0000 0000
---- ---- ---- ---xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
0000 0000 0000 0000
0000 0000 0000 0000
0000 0000 0000 0000
Bank 0
10h
PORTA(4,6)
11h
DDRB
12h
PORTB(4)
13h
14h
15h
16h
17h
RCSTA1
RCREG1
TXSTA1
TXREG1
SPBRG1
RBPU
—
RA5/TX1/
CK1
RA4/RX1/
DT1
Data Direction Register for PORTB
RB7/
RB6/
RB5/
RB4/
SDO
SCK
TCLK3
TCLK12
SPEN
RX9
SREN
CREN
Serial Port Receive Register
CSRC
TX9
TXEN
SYNC
Serial Port Transmit Register (for USART1)
Baud Rate Generator Register (for USART1)
RA3/SDI/
SDA
RA2/SS/
SCL
RA1/T0CKI
RA0/INT
RB3/
PWM2
—
RB2/
PWM1
FERR
RB1/
CAP2
OERR
RB0/
CAP1
RX9D
—
—
TRMT
TX9D
0-xx 11xx 0-uu 11uu
1111 1111 1111 1111
xxxx xxxx uuuu uuuu
0000 -00x 0000 -00u
xxxx xxxx uuuu uuuu
0000 --1x 0000 --1u
xxxx xxxx uuuu uuuu
0000 0000 0000 0000
Bank 1
10h
11h
12h
DDRC(5)
PORTC(4,5)
DDRD(5)
13h
PORTD(4,5)
14h
DDRE(5)
1111 1111 1111 1111
RC3/AD3
RC2/AD2
RD3/
AD11
RD2/
AD10
RC1/AD1
RC0/AD0
xxxx xxxx uuuu uuuu
1111 1111 1111 1111
RD1/AD9
RD0/AD8
xxxx xxxx uuuu uuuu
---- 1111 ---- 1111
RE3/
—
—
—
—
RE2/WR
RE1/OE
RE0/ALE ---- xxxx ---- uuuu
CAP4
x000 0010 u000 0010
PIR1
RBIF
TMR3IF
TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
0000 0000 0000 0000
PIE1
RBIE
TMR3IE
TMR2IE
TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends on condition.
Shaded cells are unimplemented, read as '0'.
The upper byte of the program counter is not directly accessible. PCLATH is a holding register for PC whose
contents are updated from, or transferred to, the upper byte of the program counter.
The TO and PD status bits in CPUSTA are not affected by a MCLR Reset.
Bank 8 and associated registers are only implemented on the PIC17C76X devices.
This is the value that will be in the port output latch.
When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this port does not rely on these
registers.
On any device RESET, these pins are configured as inputs.
PORTE(4,5)
15h
16h
17h
Legend:
Note
Data Direction Register for PORTC
RC7/AD7 RC6/AD6 RC5/AD5 RC4/AD4
Data Direction Register for PORTD
RD7/
RD6/
RD5/
RD4/
AD15
AD14
AD13
AD12
Data Direction Register for PORTE
1:
2:
3:
4:
5:
6:
DS30289C-page 48
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 7-3:
Address
SPECIAL FUNCTION REGISTERS (CONTINUED)
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bank 2
10h
11h
12h
13h
14h
15h
16h
17h
TMR1
TMR2
TMR3L
TMR3H
PR1
PR2
PR3L/CA1L
PR3H/CA1H
Timer1’s Register
Timer2’s Register
Timer3’s Register; Low Byte
Timer3’s Register; High Byte
Timer1’s Period Register
Timer2’s Period Register
Timer3’s Period Register - Low Byte/Capture1 Register; Low Byte
Timer3’s Period Register - High Byte/Capture1 Register; High Byte
Bank 3
10h
11h
12h
13h
14h
15h
16h
PW1DCL
PW2DCL
PW1DCH
PW2DCH
CA2L
CA2H
TCON1
DC1
DC0
DC1
DC0
DC9
DC8
DC9
DC8
Capture2 Low Byte
Capture2 High Byte
CA2ED1 CA2ED0
TCON2
CA2OVF
17h
—
TM2PW2
DC7
DC7
—
—
DC6
DC6
—
—
DC5
DC5
—
—
DC4
DC4
Bit 1
Value on
POR,
BOR
Bit 0
MCLR,
WDT
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
—
—
DC3
DC3
—
—
DC2
DC2
xx-- ---- uu-- ---xx0- ---- uu0- ---xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
CA1ED1
CA1ED0
CA1OVF PWM2ON PWM1ON
T16
TMR3CS
TMR2CS
TMR1CS
CA1/PR3
TMR3ON
TMR2ON
TMR1ON 0000 0000 0000 0000
0000 0000 0000 0000
Bank 4
10h
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0010 000- 0010
11h
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000 000- 0000
12h
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
0000 -00x 0000 -00u
—
—
TRMT
TX9D
13h
RCSTA2
14h
RCREG2
15h
TXSTA2
16h
TXREG2
Serial Port Transmit Register for USART2
xxxx xxxx uuuu uuuu
17h
SPBRG2
Baud Rate Generator for USART2
0000 0000 0000 0000
DDRF
Data Direction Register for PORTF
Serial Port Receive Register for USART2
CSRC
TX9
TXEN
SYNC
xxxx xxxx uuuu uuuu
0000 --1x 0000 --1u
Bank 5:
10h
RF7/
AN11
RF6/
AN10
RF5/
AN9
RF3/
AN7
RF2/
AN6
RF1/
AN5
RF0/
AN4
RG5/
PWM3
RG4/
CAP3
RG3/
AN0
RG2/
AN1
RG1/
AN2
RG0/
AN3
xxxx 0000 uuuu 0000
11h
PORTF(4)
12h
DDRG
Data Direction Register for PORTG
PORTG(4)
RG7/
RG6/
TX2/CK2 RX2/DT2
13h
1111 1111 1111 1111
RF4/
AN8
0000 0000 0000 0000
1111 1111 1111 1111
14h
ADCON0
CHS3
CHS2
CHS1
CHS0
—
GO/DONE
—
ADON
0000 -0-0 0000 -0-0
15h
ADCON1
ADCS1
ADCS0
ADFM
—
PCFG3
PCFG2
PCFG1
PCFG0
000- 0000 000- 0000
16h
ADRESL
17h
Legend:
Note
1:
2:
3:
4:
5:
6:
A/D Result Register Low Byte
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
ADRESH
A/D Result Register High Byte
x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends on condition.
Shaded cells are unimplemented, read as '0'.
The upper byte of the program counter is not directly accessible. PCLATH is a holding register for PC whose
contents are updated from, or transferred to, the upper byte of the program counter.
The TO and PD status bits in CPUSTA are not affected by a MCLR Reset.
Bank 8 and associated registers are only implemented on the PIC17C76X devices.
This is the value that will be in the port output latch.
When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this port does not rely on these
registers.
On any device RESET, these pins are configured as inputs.
1998-2013 Microchip Technology Inc.
DS30289C-page 49
PIC17C7XX
TABLE 7-3:
Address
SPECIAL FUNCTION REGISTERS (CONTINUED)
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR,
WDT
Bank 6
SSP Address Register in I2C Slave mode. SSP Baud Rate Reload Register in I2C Master mode
10h
SSPADD
11h
SSPCON1
WCOL
SSPOV
SSPEN
CKP
SSPM3
SSPM2
SSPM1
SSPM0
0000 0000 0000 0000
12h
SSPCON2
GCEN
AKSTAT
AKDT
AKEN
RCEN
PEN
RSEN
SEN
0000 0000 0000 0000
SMP
CKE
D/A
P
S
R/W
UA
BF
0000 0000 0000 0000
0000 0000 0000 0000
13h
SSPSTAT
14h
SSPBUF
15h
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
16h
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
17h
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
Synchronous Serial Port Receive Buffer/Transmit Register
xxxx xxxx uuuu uuuu
Bank 7
10h
PW3DCL
DC1
DC0
TM2PW3
—
—
—
—
—
xx0- ---- uu0- ----
11h
PW3DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx uuuu uuuu
12h
CA3L
Capture3 Low Byte
xxxx xxxx uuuu uuuu
13h
CA3H
Capture3 High Byte
xxxx xxxx uuuu uuuu
14h
CA4L
Capture4 Low Byte
xxxx xxxx uuuu uuuu
15h
CA4H
Capture4 High Byte
xxxx xxxx uuuu uuuu
16h
TCON3
—
CA4OVF
CA3OVF
CA4ED1
CA4ED0
CA3ED1
CA3ED0
17h
Unimplemented
—
—
—
—
—
—
—
Bank
PWM3ON -000 0000 -000 0000
—
---- ---- ---- ----
8(3)
10h(3)
DDRH
11h(3)
PORTH(4)
12h(3)
DDRJ
13h(3)
PORTJ(4)
14h(3)
Data Direction Register for PORTH
RH7/
AN15
RH6/
AN14
RH5/
AN13
1111 1111 1111 1111
RH4/
AN12
RH3
RH2
RH1
RH0
Data Direction Register for PORTJ
xxxx xxxx uuuu uuuu
1111 1111 1111 1111
RJ7
RJ6
RJ5
RJ4
RJ3
RJ2
RJ1
RJ0
xxxx xxxx uuuu uuuu
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
15h(3)
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
16h(3)
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
17h(3)
Unimplemented
—
—
—
—
—
—
—
—
---- ---- ---- ----
Unbanked
xxxx xxxx uuuu uuuu
18h
PRODL
Low Byte of 16-bit Product (8 x 8 Hardware Multiply)
xxxx xxxx uuuu uuuu
19h
PRODH
High Byte of 16-bit Product (8 x 8 Hardware Multiply)
Legend: x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends on condition.
Shaded cells are unimplemented, read as '0'.
Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for PC whose
contents are updated from, or transferred to, the upper byte of the program counter.
2: The TO and PD status bits in CPUSTA are not affected by a MCLR Reset.
3: Bank 8 and associated registers are only implemented on the PIC17C76X devices.
4: This is the value that will be in the port output latch.
5: When the device is configured for Microprocessor or Extended Microcontroller mode, the operation of this port does not rely on these
registers.
6: On any device RESET, these pins are configured as inputs.
DS30289C-page 50
1998-2013 Microchip Technology Inc.
PIC17C7XX
7.2.2.1
ALU Status Register (ALUSTA)
The ALUSTA register contains the status bits of the
Arithmetic and Logic Unit and the mode control bits for
the indirect addressing register.
As with all the other registers, the ALUSTA register can
be the destination for any instruction. If the ALUSTA
register is the destination for an instruction that affects
the Z, DC, C, or OV bits, then the write to these three
bits is disabled. These bits are set or cleared according
to the device logic. Therefore, the result of an instruction with the ALUSTA register as destination may be
different than intended.
For example, the CLRF ALUSTA, F instruction will clear
the upper four bits and set the Z bit. This leaves the
ALUSTA register as 0000u1uu (where u = unchanged).
It is recommended, therefore, that only BCF, BSF, SWAPF
and MOVWF instructions be used to alter the ALUSTA
register, because these instructions do not affect any
status bits. To see how other instructions affect the status bits, see the “Instruction Set Summary.”
Note 1: The C and DC bits operate as a borrow and
digit borrow bit, respectively, in subtraction.
See the SUBLW and SUBWF instructions for
examples.
2: The overflow bit will be set if the 2’s complement result exceeds +127, or is less than -128.
The Arithmetic and Logic Unit (ALU) is capable of carrying out arithmetic or logical operations on two operands, or a single operand. All single operand
instructions operate either on the WREG register, or
the given file register. For two operand instructions, one
of the operands is the WREG register and the other is
either a file register, or an 8-bit immediate constant.
REGISTER 7-1: ALUSTA REGISTER (ADDRESS: 04h, UNBANKED)
R/W-1
FS3
R/W-1
FS2
R/W-1
FS1
R/W-1
FS0
R/W-x
OV
R/W-x
Z
R/W-x
DC
R/W-x
C
bit 7
bit 0
bit 7-6
FS3:FS2: FSR1 Mode Select bits
00 = Post auto-decrement FSR1 value
01 = Post auto-increment FSR1 value
1x = FSR1 value does not change
bit 5-4
FS1:FS0: FSR0 Mode Select bits
00 = Post auto-decrement FSR0 value
01 = Post auto-increment FSR0 value
1x = FSR0 value does not change
bit 3
OV: Overflow bit
This bit is used for signed arithmetic (2’s complement). It indicates an overflow of the 7-bit
magnitude, which causes the sign bit (bit7) to change state.
1 = Overflow occurred for signed arithmetic (in this arithmetic operation)
0 = No overflow occurred
bit 2
Z: Zero bit
1 = The result of an arithmetic or logic operation is zero
0 = The result of an arithmetic or logic operation is not zero
bit 1
DC: Digit carry/borrow bit
For ADDWF and ADDLW instructions.
1 = A carry-out from the 4th low order bit of the result occurred
0 = No carry-out from the 4th low order bit of the result
bit 0
C: Carry/borrow bit
Note:
For borrow, the polarity is reversed.
For ADDWF and ADDLW instructions. Note that a subtraction is executed by adding the two’s
complement of the second operand.
For rotate (RRCF, RLCF) instructions, this bit is loaded with either the high or low order bit of the
source register.
1 = A carry-out from the Most Significant bit of the result occurred
0 = No carry-out from the Most Significant bit of the result
Note:
For borrow, the polarity is reversed.
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 51
PIC17C7XX
7.2.2.2
CPU Status Register (CPUSTA)
The CPUSTA register contains the status and control
bits for the CPU. This register has a bit that is used to
globally enable/disable interrupts. If only a specific
interrupt is desired to be enabled/disabled, please refer
to the Interrupt Status (INTSTA) register and the
Peripheral Interrupt Enable (PIE) registers. The
CPUSTA register also indicates if the stack is available
and contains the Power-down (PD) and Time-out (TO)
bits. The TO, PD, and STKAV bits are not writable.
These bits are set and cleared according to device
logic. Therefore, the result of an instruction with the
CPUSTA register as destination may be different than
intended.
The POR bit allows the differentiation between a
Power-on Reset, external MCLR Reset, or a WDT
Reset. The BOR bit indicates if a Brown-out Reset
occurred.
Note 1: The BOR status bit is a don’t care and is
not necessarily predictable if the Brown-out
circuit is disabled (when the BODEN bit in
the Configuration word is programmed).
REGISTER 7-2: CPUSTA REGISTER (ADDRESS: 06h, UNBANKED)
U-0
—
U-0
—
R-1
STKAV
R/W-1
GLINTD
R-1
TO
R-1
PD
R/W-0
POR
bit 7
R/W-1
BOR
bit 0
bit 7-6
Unimplemented: Read as '0'
bit 5
STKAV: Stack Available bit
This bit indicates that the 4-bit stack pointer value is Fh, or has rolled over from Fh 0h
(stack overflow).
1 = Stack is available
0 = Stack is full, or a stack overflow may have occurred (once this bit has been cleared by a
stack overflow, only a device RESET will set this bit)
bit 4
GLINTD: Global Interrupt Disable bit
This bit disables all interrupts. When enabling interrupts, only the sources with their enable bits
set can cause an interrupt.
1 = Disable all interrupts
0 = Enables all unmasked interrupts
bit 3
TO: WDT Time-out Status bit
1 = After power-up, by a CLRWDT instruction, or by a SLEEP instruction
0 = A Watchdog Timer time-out occurred
bit 2
PD: Power-down Status bit
1 = After power-up or by the CLRWDT instruction
0 = By execution of the SLEEP instruction
bit 1
POR: Power-on Reset Status bit
1 = No Power-on Reset occurred
0 = A Power-on Reset occurred (must be set by software)
bit 0
BOR: Brown-out Reset Status bit
When BODEN Configuration bit is set (enabled):
1 = No Brown-out Reset occurred
0 = A Brown-out Reset occurred (must be set by software)
When BODEN Configuration bit is clear (disabled):
Don’t care
Legend:
DS30289C-page 52
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
7.2.2.3
TMR0 Status/Control Register
(T0STA)
This register contains various control bits. Bit7
(INTEDG) is used to control the edge upon which a signal on the RA0/INT pin will set the RA0/INT interrupt
flag. The other bits configure Timer0, it’s prescaler and
clock source.
REGISTER 7-3: T0STA REGISTER (ADDRESS: 05h, UNBANKED)
R/W-0
INTEDG
R/W-0
T0SE
R/W-0
T0CS
R/W-0
T0PS3
R/W-0
T0PS2
R/W-0
T0PS1
R/W-0
T0PS0
bit 7
U-0
—
bit 0
bit 7
INTEDG: RA0/INT Pin Interrupt Edge Select bit
This bit selects the edge upon which the interrupt is detected.
1 = Rising edge of RA0/INT pin generates interrupt
0 = Falling edge of RA0/INT pin generates interrupt
bit 6
T0SE: Timer0 External Clock Input Edge Select bit
This bit selects the edge upon which TMR0 will increment.
When T0CS = 0 (External Clock):
1 = Rising edge of RA1/T0CKI pin increments TMR0 and/or sets the T0CKIF bit
0 = Falling edge of RA1/T0CKI pin increments TMR0 and/or sets a T0CKIF bit
When T0CS = 1 (Internal Clock):
Don’t care
bit 5
T0CS: Timer0 Clock Source Select bit
This bit selects the clock source for Timer0.
1 = Internal instruction clock cycle (TCY)
0 = External clock input on the T0CKI pin
bit 4-1
T0PS3:T0PS0: Timer0 Prescale Selection bits
These bits select the prescale value for Timer0.
T0PS3:T0PS0
0000
0001
0010
0011
0100
0101
0110
0111
1xxx
bit 0
Prescale Value
1:1
1:2
1:4
1:8
1:16
1:32
1:64
1:128
1:256
Unimplemented: Read as '0'
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 53
PIC17C7XX
7.3
Stack Operation
PIC17C7XX devices have a 16 x 16-bit hardware stack
(Figure 7-1). The stack is not part of either the program
or data memory space, and the stack pointer is neither
readable nor writable. The PC (Program Counter) is
“PUSH’d” onto the stack when a CALL or LCALL
instruction is executed, or an interrupt is acknowledged. The stack is “POP’d” in the event of a RETURN,
RETLW, or a RETFIE instruction execution. PCLATH is
not affected by a “PUSH” or a “POP” operation.
The stack operates as a circular buffer, with the stack
pointer initialized to '0' after all RESETS. There is a
stack available bit (STKAV) to allow software to ensure
that the stack will not overflow. The STKAV bit is set
after a device RESET. When the stack pointer equals
Fh, STKAV is cleared. When the stack pointer rolls over
from Fh to 0h, the STKAV bit will be held clear until a
device RESET.
7.4
Indirect Addressing
Indirect addressing is a mode of addressing data memory where the data memory address in the instruction
is not fixed. That is, the register that is to be read or
written can be modified by the program. This can be
useful for data tables in the data memory. Figure 7-6
shows the operation of indirect addressing. This
depicts the moving of the value to the data memory
address specified by the value of the FSR register.
Example 7-1 shows the use of indirect addressing to
clear RAM in a minimum number of instructions. A similar concept could be used to move a defined number
of bytes (block) of data to the USART transmit register
(TXREG). The starting address of the block of data to
be transmitted could easily be modified by the program.
FIGURE 7-6:
INDIRECT ADDRESSING
RAM
Note 1: There is not a status bit for stack underflow. The STKAV bit can be used to detect
the underflow which results in the stack
pointer being at the Top-of-Stack.
Instruction
Executed
Opcode
Address
2: There are no instruction mnemonics
called PUSH or POP. These are actions
that occur from the execution of the CALL,
RETURN, RETLW and RETFIE instructions, or the vectoring to an interrupt
vector.
3: After a RESET, if a “POP” operation
occurs before a “PUSH” operation, the
STKAV bit will be cleared. This will
appear as if the stack is full (underflow
has occurred). If a “PUSH” operation
occurs next (before another “POP”), the
STKAV bit will be locked clear. Only a
device RESET will cause this bit to set.
After the device is “PUSH’d” sixteen times (without a
“POP”), the seventeenth push overwrites the value
from the first push. The eighteenth push overwrites the
second push (and so on).
8
File = INDFx
Opcode
7.4.1
8
8
Instruction
Fetched
File
FSR
INDIRECT ADDRESSING
REGISTERS
The PIC17C7XX has four registers for indirect addressing. These registers are:
• INDF0 and FSR0
• INDF1 and FSR1
Registers INDF0 and INDF1 are not physically implemented. Reading or writing to these registers activates
indirect addressing, with the value in the corresponding
FSR register being the address of the data. The FSR is
an 8-bit register and allows addressing anywhere in the
256-byte data memory address range. For banked
memory, the bank of memory accessed is specified by
the value in the BSR.
If file INDF0 (or INDF1) itself is read indirectly via an
FSR, all '0's are read (Zero bit is set). Similarly, if INDF0
(or INDF1) is written to indirectly, the operation will be
equivalent to a NOP, and the status bits are not affected.
DS30289C-page 54
1998-2013 Microchip Technology Inc.
PIC17C7XX
7.4.2
INDIRECT ADDRESSING
OPERATION
7.5
Table Pointer (TBLPTRL and
TBLPTRH)
The indirect addressing capability has been enhanced
over that of the PIC16CXX family. There are two control
bits associated with each FSR register. These two bits
configure the FSR register to:
File registers TBLPTRL and TBLPTRH form a 16-bit
pointer to address the 64K program memory space.
The table pointer is used by instructions TABLWT and
TABLRD.
• Auto-decrement the value (address) in the FSR
after an indirect access
• Auto-increment the value (address) in the FSR
after an indirect access
• No change to the value (address) in the FSR after
an indirect access
The TABLRD and the TABLWT instructions allow transfer of data between program and data space. The table
pointer serves as the 16-bit address of the data word
within the program memory. For a more complete
description of these registers and the operation of
Table Reads and Table Writes, see Section 8.0.
These control bits are located in the ALUSTA register.
The FSR1 register is controlled by the FS3:FS2 bits
and FSR0 is controlled by the FS1:FS0 bits.
7.6
When using the auto-increment or auto-decrement features, the effect on the FSR is not reflected in the
ALUSTA register. For example, if the indirect address
causes the FSR to equal '0', the Z bit will not be set.
If the FSR register contains a value of 0h, an indirect
read will read 0h (Zero bit is set) while an indirect write
will be equivalent to a NOP (status bits are not affected).
Table Latch (TBLATH, TBLATL)
The table latch (TBLAT) is a 16-bit register, with
TBLATH and TBLATL referring to the high and low
bytes of the register. It is not mapped into data or program memory. The table latch is used as a temporary
holding latch during data transfer between program
and data memory (see TABLRD, TABLWT, TLRD and
TLWT instruction descriptions). For a more complete
description of these registers and the operation of
Table Reads and Table Writes, see Section 8.0.
Indirect addressing allows single cycle data transfers
within the entire data space. This is possible with the
use of the MOVPF and MOVFP instructions, where either
'p' or 'f' is specified as INDF0 (or INDF1).
If the source or destination of the indirect address is in
banked memory, the location accessed will be determined by the value in the BSR.
A simple program to clear RAM from 20h - FFh is
shown in Example 7-1.
EXAMPLE 7-1:
LP
MOVLW
MOVWF
BCF
BSF
BCF
MOVLW
CLRF
CPFSEQ
GOTO
:
:
INDIRECT ADDRESSING
0x20
FSR0
ALUSTA, FS1
ALUSTA, FS0
ALUSTA, C
END_RAM + 1
INDF0, F
FSR0
LP
;
;
;
;
;
;
;
;
;
;
;
FSR0 = 20h
Increment FSR
after access
C = 0
Addr(FSR) = 0
FSR0 = END_RAM+1?
NO, clear next
YES, All RAM is
cleared
1998-2013 Microchip Technology Inc.
DS30289C-page 55
PIC17C7XX
7.7
Program Counter Module
The Program Counter (PC) is a 16-bit register. PCL, the
low byte of the PC, is mapped in the data memory. PCL
is readable and writable just as is any other register.
PCH is the high byte of the PC and is not directly
addressable. Since PCH is not mapped in data or program memory, an 8-bit register PCLATH (PC high
latch) is used as a holding latch for the high byte of the
PC. PCLATH is mapped into data memory. The user
can read or write PCH through PCLATH.
The 16-bit wide PC is incremented after each instruction fetch during Q1 unless:
• Modified by a GOTO, CALL, LCALL, RETURN,
RETLW, or RETFIE instruction
• Modified by an interrupt response
• Due to destination write to PCL by an instruction
“Skips” are equivalent to a forced NOP cycle at the
skipped address.
Using Figure 7-7, the operations of the PC and
PCLATH for different instructions are as follows:
a)
b)
c)
d)
Figure 7-7 and Figure 7-8 show the operation of the
program counter for various situations.
FIGURE 7-7:
PROGRAM COUNTER
OPERATION
Internal Data Bus
e)
Using Figure 7-8, the operation of the PC and PCLATH
for GOTO and CALL instructions is as follows:
8
PCLATH
CALL, GOTO instructions:
A 13-bit destination address is provided in the
instruction (opcode).
Opcode PC
PC PCLATH
Opcode PCLATH
8
8
PCH
FIGURE 7-8:
15
PCL
PROGRAM COUNTER
USING THE CALL AND
GOTO INSTRUCTIONS
13 12
8 7
From Instruction
0
5
PC
3
7
54
0
PCLATH
0
8 7
PCH
DS30289C-page 56
The read-modify-write only affects the PCL with the
result. PCH is loaded with the value in the PCLATH. For
example, ADDWF PCL will result in a jump within the
current page. If PC = 03F0h, WREG = 30h and
PCLATH = 03h before instruction, PC = 0320h after the
instruction. To accomplish a true 16-bit computed jump,
the user needs to compute the 16-bit destination
address, write the high byte to PCLATH and then write
the low value to PCL.
The following PC related operations do not change
PCLATH:
8
8
15
LCALL instructions:
An 8-bit destination address is provided in the
instruction (opcode). PCLATH is unchanged.
PCLATH PCH
Opcode PCL
Read instructions on PCL:
Any instruction that reads PCL.
PCL data bus ALU or destination
PCH PCLATH
Write instructions on PCL:
Any instruction that writes to PCL.
8-bit data data bus PCL
PCLATH PCH
Read-Modify-Write instructions on PCL:
Any instruction that does a read-write-modify
operation on PCL, such as ADDWF PCL.
Read:
PCL data bus ALU
Write:
8-bit result data bus PCL
PCLATH PCH
RETURN instruction:
Stack PC
a)
b)
c)
LCALL, RETLW, and RETFIE instructions.
Interrupt vector is forced onto the PC.
Read-modify-write instructions on PCL
(e.g. BSF PCL).
PCL
1998-2013 Microchip Technology Inc.
PIC17C7XX
7.8
Bank Select Register (BSR)
bank in order to address all peripherals related to a single task. To assist this, a MOVLB bank instruction has
been included in the instruction set.
The BSR is used to switch between banks in the data
memory area (Figure 7-9). In the PIC17C7XX devices,
the entire byte is implemented. The lower nibble is
used to select the peripheral register bank. The upper
nibble is used to select the general purpose memory
bank.
The need for a large general purpose memory space
dictated a general purpose RAM banking scheme. The
upper nibble of the BSR selects the currently active
general purpose RAM bank. To assist this, a MOVLR
bank instruction has been provided in the instruction
set.
All the Special Function Registers (SFRs) are mapped
into the data memory space. In order to accommodate
the large number of registers, a banking scheme has
been used. A segment of the SFRs, from address 10h
to address 17h, is banked. The lower nibble of the bank
select register (BSR) selects the currently active
“peripheral bank.” Effort has been made to group the
peripheral registers of related functionality in one bank.
However, it will still be necessary to switch from bank to
FIGURE 7-9:
Address
Range
Note:
Registers in Bank 15 in the Special Function Register area, are reserved for
Microchip use. Reading of registers in this
bank may cause random values to be read.
BSR OPERATION
BSR
7
4 3
(2)
If the currently selected bank is not implemented (such
as Bank 13), any read will read all '0's. Any write is
completed to the bit bucket and the ALU status bits will
be set/cleared as appropriate.
0
(1)
0
1
2
3
4
5
6
7
8
10h
15
SFR (Peripheral)
Banks
17h
Bank 0 Bank 1 Bank 2 Bank 3 Bank 4 Bank 5 Bank 6 Bank 7 Bank 8
0
1
2
3
15
4
20h
Bank 15
GPR (RAM)
Banks
FFh
Bank 0 Bank 1 Bank 2 Bank 3 Bank 4
Bank 15
Note 1: For the SFRs only Banks 0 through 8 are implemented. Selection of an unimplemented bank is not recommended.
Bank 15 is reserved for Microchip use, reading of registers in this bank may cause random values to be read.
2: For the GPRs, Bank 3 is unimplemented on the PIC17C752 and the PIC17C762. Selection of an unimplemented bank
is not recommended.
3: SFR Bank 8 is only implemented on the PIC17C76X.
1998-2013 Microchip Technology Inc.
DS30289C-page 57
PIC17C7XX
NOTES:
DS30289C-page 58
1998-2013 Microchip Technology Inc.
PIC17C7XX
8.0
TABLE READS AND TABLE
WRITES
FIGURE 8-2:
The PIC17C7XX has four instructions that allow the
processor to move data from the data memory space to
the program memory space, and vice versa. Since the
program memory space is 16-bits wide and the data
memory space is 8-bits wide, two operations are
required to move 16-bit values to/from the data
memory.
The TLWT t,f and TABLWT t,i,f instructions are
used to write data from the data memory space to the
program memory space. The TLRD t,f and TABLRD
t,i,f instructions are used to write data from the program memory space to the data memory space.
The program memory can be internal or external. For
the program memory access to be external, the device
needs to be operating in Microprocessor or Extended
Microcontroller mode.
Figure 8-1 through Figure 8-4 show the operation of
these four instructions. The steps show the sequence
of operation.
FIGURE 8-1:
TLWT INSTRUCTION
OPERATION
TABLWT INSTRUCTION
OPERATION
TABLE POINTER
TBLPTRH
TBLPTRL
TABLE LATCH (16-bit)
TABLATH
TABLATL
3
TABLWT 0,i,f
3
TABLWT 1,i,f
Data
Memory
f
Program Memory
1
Prog-Mem
(TBLPTR)
2
TABLE POINTER
TBLPTRH
TBLPTRL
TABLE LATCH (16-bit)
TABLATH
TLWT 1,f
Data
Memory
TABLATL
TLWT 0,f
Step 1: 8-bit value from register 'f', loaded into the high or low
byte in TABLAT (16-bit).
2: 16-bit TABLAT value written to address Program Memory
(TBLPTR).
3: If “i” = 1, then TBLPTR = TBLPTR + 1,
If “i” = 0, then TBLPTR is unchanged.
Program Memory
f
1
Step 1: 8-bit value from register 'f', loaded into the high or low
byte in TABLAT (16-bit).
1998-2013 Microchip Technology Inc.
DS30289C-page 59
PIC17C7XX
FIGURE 8-3:
TLRD INSTRUCTION
OPERATION
FIGURE 8-4:
TABLE POINTER
TABLE POINTER
TBLPTRH
TBLPTRH
TBLPTRL
TLRD 1,f
TBLPTRL
TABLE LATCH (16-bit)
TABLE LATCH (16-bit)
TABLATH
TABLRD INSTRUCTION
OPERATION
TABLATH
TABLATL
TABLATL
TLRD 0,f
3
TABLRD 0,i,f
3
TABLRD 1,i,f
Data
Memory
Program Memory
Data
Memory
f
Program Memory
1
f
1
Prog-Mem
(TBLPTR)
2
Step 1: 8-bit value from TABLAT (16-bit) high or low byte,
loaded into register 'f'.
DS30289C-page 60
Step 1: 8-bit value from TABLAT (16-bit) high or low byte,
loaded into register 'f'.
2: 16-bit value at Program Memory (TBLPTR), loaded into
TABLAT register.
3: If “i” = 1, then TBLPTR = TBLPTR + 1,
If “i” = 0, then TBLPTR is unchanged.
1998-2013 Microchip Technology Inc.
PIC17C7XX
8.1
8.1.1
Table Writes to Internal Memory
A table write operation to internal memory causes a
long write operation. The long write is necessary for
programming the internal EPROM. Instruction execution is halted while in a long write cycle. The long write
will be terminated by any enabled interrupt. To ensure
that the EPROM location has been well programmed,
a minimum programming time is required (see specification #D114). Having only one interrupt enabled to terminate the long write ensures that no unintentional
interrupts will prematurely terminate the long write.
The sequence of events for programming an internal
program memory location should be:
1.
2.
3.
4.
5.
Disable all interrupt sources, except the source
to terminate EPROM program write.
Raise MCLR/VPP pin to the programming
voltage.
Clear the WDT.
Do the table write. The interrupt will terminate
the long write.
Verify the memory location (table read).
Note 1: Programming requirements must be
met. See timing specification in electrical
specifications for the desired device.
Violating these specifications (including
temperature) may result in EPROM
locations that are not fully programmed
and may lose their state over time.
2: If the VPP requirement is not met, the
table write is a 2-cycle write and the program memory is unchanged.
TABLE 8-1:
Interrupt
Source
TERMINATING LONG WRITES
An interrupt source or RESET are the only events that
terminate a long write operation. Terminating the long
write from an interrupt source requires that the interrupt
enable and flag bits are set. The GLINTD bit only
enables the vectoring to the interrupt address.
If the T0CKI, RA0/INT, or TMR0 interrupt source is
used to terminate the long write, the interrupt flag of the
highest priority enabled interrupt, will terminate the long
write and automatically be cleared.
Note 1: If an interrupt is pending, the TABLWT is
aborted (a NOP is executed). The highest
priority pending interrupt, from the
T0CKI, RA0/INT, or TMR0 sources that
is enabled, has its flag cleared.
2: If the interrupt is not being used for the
program write timing, the interrupt
should be disabled. This will ensure that
the interrupt is not lost, nor will it terminate the long write prematurely.
If a peripheral interrupt source is used to terminate the
long write, the interrupt enable and flag bits must be
set. The interrupt flag will not be automatically cleared
upon the vectoring to the interrupt vector address.
The GLINTD bit determines whether the program will
branch to the interrupt vector when the long write is terminated. If GLINTD is clear, the program will vector, if
GLINTD is set, the program will not vector to the
interrupt address.
INTERRUPT - TABLE WRITE INTERACTION
GLINTD
Enable
Bit
Flag
Bit
RA0/INT,
TMR0,
T0CKI
0
1
1
0
1
1
1
0
1
0
x
1
Peripheral
0
0
1
1
1
1
0
1
1
0
x
1
1998-2013 Microchip Technology Inc.
Action
Terminate long table write (to internal program memory),
branch to interrupt vector (branch clears flag bit).
None.
None.
Terminate long table write, do not branch to interrupt
vector (flag is automatically cleared).
Terminate long table write, branch to interrupt vector.
None.
None.
Terminate long table write, do not branch to interrupt
vector (flag remains set).
DS30289C-page 61
PIC17C7XX
8.2
Table Writes to External Memory
EXAMPLE 8-1:
Table writes to external memory are always two-cycle
instructions. The second cycle writes the data to the
external memory location. The sequence of events for
an external memory write are the same for an internal
write.
8.2.1
TABLE WRITE CODE
The “i” operand of the TABLWT instruction can specify
that the value in the 16-bit TBLPTR register is automatically incremented (for the next write). In Example 8-1,
the TBLPTR register is not automatically incremented.
FIGURE 8-5:
CLRWDT
MOVLW
MOVWF
MOVLW
MOVWF
MOVLW
TLWT
MOVLW
TABLWT
TABLE WRITE
HIGH (TBL_ADDR)
TBLPTRH
LOW (TBL_ADDR)
TBLPTRL
HIGH (DATA)
1, WREG
LOW (DATA)
0,0,WREG
;
;
;
;
;
;
;
;
;
;
;
;
Clear WDT
Load the Table
address
Load HI byte
in TABLATH
Load LO byte
in TABLATL
and write to
program memory
(Ext. SRAM)
TABLWT WRITE TIMING (EXTERNAL MEMORY)
Q1 Q2 Q3 Q4
AD15:AD0
PC
Instruction
Fetched
TABLWT
Instruction
Executed
INST (PC-1)
Q1 Q2 Q3 Q4
PC+1
Q1 Q2 Q3 Q4
TBL
Data out
INST (PC+1)
TABLWT cycle1
Q1 Q2 Q3 Q4
PC+2
INST (PC+2)
TABLWT cycle2
INST (PC+1)
Data write cycle
ALE
OE
'1'
WR
Note: If external write and GLINTD = '1' and Enable bit = '1', then when '1' Flag bit, do table write.
The highest pending interrupt is cleared.
DS30289C-page 62
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 8-6:
CONSECUTIVE TABLWT WRITE TIMING (EXTERNAL MEMORY)
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
AD15:AD0
PC
Instruction
Fetched
TABLWT1
Instruction
Executed
INST (PC-1)
PC+1
TBL1
Data out 1
TABLWT2
PC+2
TBL2
Data out 2
INST (PC+2)
INST (PC+3)
TABLWT1 cycle1 TABLWT1 cycle2 TABLWT2 cycle1 TABLWT2 cycle2
Data write cycle
PC+3
INST (PC+2)
Data write cycle
ALE
OE
WR
1998-2013 Microchip Technology Inc.
DS30289C-page 63
PIC17C7XX
8.3
EXAMPLE 8-2:
Table Reads
The table read allows the program memory to be read.
This allows constants to be stored in the program memory space and retrieved into data memory when
needed. Example 8-2 reads the 16-bit value at program
memory address TBLPTR. After the dummy byte has
been read from the TABLATH, the TABLATH is loaded
with the 16-bit data from program memory address
TBLPTR and then increments the TBLPTR value. The
first read loads the data into the latch and can be considered a dummy read (unknown data loaded into 'f').
INDF0 should be configured for either auto-increment
or auto-decrement.
FIGURE 8-7:
MOVLW
MOVWF
MOVLW
MOVWF
TABLRD
TLRD
TABLRD
TABLE READ
HIGH (TBL_ADDR) ; Load the Table
TBLPTRH
;
address
LOW (TBL_ADDR) ;
TBLPTRL
;
0, 1, DUMMY ; Dummy read,
; Updates TABLATH
; Increments TBLPTR
1, INDF0
; Read HI byte
;
of TABLATH
0, 1, INDF0 ; Read LO byte
;
of TABLATL and
;
Update TABLATH
;
Increment TBLPTR
TABLRD TIMING
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
AD15:AD0
PC
Instruction
Fetched
TABLRD
Instruction
Executed
INST (PC-1)
PC+1
TBL
Data in
INST (PC+2)
INST (PC+1)
TABLRD cycle1
PC+2
TABLRD cycle2
INST (PC+1)
Data read cycle
ALE
OE
WR
FIGURE 8-8:
'1'
TABLRD TIMING (CONSECUTIVE TABLRD INSTRUCTIONS)
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
AD15:AD0
PC
Instruction
Fetched
TABLRD1
Instruction
Executed
INST (PC-1)
PC+1
TBL1 Data in 1
PC+2
TBL2
Data in 2
INST (PC+2)
TABLRD2
INST (PC+3)
TABLRD1 cycle1 TABLRD1 cycle2 TABLRD2 cycle1 TABLRD2 cycle2
Data read cycle
PC+3
INST (PC+2)
Data read cycle
ALE
OE
'1'
WR
DS30289C-page 64
1998-2013 Microchip Technology Inc.
PIC17C7XX
8.4
Operation with External Memory
Interface
When the table reads/writes are accessing external
memory (via the external system interface bus), the
table latch for the table reads is different from the table
latch for the table writes (see Figure 8-9).
This means that you cannot do a TABLRD instruction,
and use the values that were loaded into the table
latches for a TABLWT instruction. Any table write
sequence should use both the TLWT and then the
TABLWT instructions.
FIGURE 8-9:
ACCESSING EXTERNAL MEMORY WITH TABLRD AND TABLWT INSTRUCTIONS
TABLPTR
Program Memory
(In External Memory Space)
TABLATH (for Table Reads)
TABLRD
TABLATH (for Table Writes)
1998-2013 Microchip Technology Inc.
TABLWT
DS30289C-page 65
PIC17C7XX
NOTES:
DS30289C-page 66
1998-2013 Microchip Technology Inc.
PIC17C7XX
9.0
HARDWARE MULTIPLIER
Example 9-2 shows the sequence to do an 8 x 8 signed
multiply. To account for the sign bits of the arguments,
each argument’s most significant bit (MSb) is tested
and the appropriate subtractions are done.
All PIC17C7XX devices have an 8 x 8 hardware multiplier included in the ALU of the device. By making the
multiply a hardware operation, it completes in a single
instruction cycle. This is an unsigned multiply that gives
a 16-bit result. The result is stored into the 16-bit
Product register (PRODH:PRODL). The multiplier does
not affect any flags in the ALUSTA register.
EXAMPLE 9-1:
MOVFP
MULWF
Making the 8 x 8 multiplier execute in a single cycle
gives the following advantages:
• Higher computational throughput
• Reduces code size requirements for multiply algorithms
EXAMPLE 9-2:
The performance increase allows the device to be used
in applications previously reserved for Digital Signal
Processors.
Table 9-1 shows a performance comparison between
PIC17CXXX devices using the single cycle hardware
multiply and performing the same function without the
hardware multiply.
Example 9-1 shows the sequence to do an 8 x 8
unsigned multiply. Only one instruction is required
when one argument of the multiply is already loaded in
the WREG register.
TABLE 9-1:
Routine
8 x 8 unsigned
8 x 8 signed
16 x 16 unsigned
16 x 16 signed
8 x 8 UNSIGNED
MULTIPLY ROUTINE
ARG1, WREG
ARG2
;
; ARG1 * ARG2 ->
;
PRODH:PRODL
8 x 8 SIGNED MULTIPLY
ROUTINE
MOVFP
MULWF
ARG1, WREG
ARG2
BTFSC
SUBWF
ARG2, SB
PRODH, F
MOVFP
BTFSC
SUBWF
ARG2, WREG
ARG1, SB
PRODH, F
; ARG1 * ARG2 ->
;
PRODH:PRODL
; Test Sign Bit
; PRODH = PRODH
;
- ARG1
; Test Sign Bit
; PRODH = PRODH
;
- ARG2
PERFORMANCE COMPARISON
Multiply Method
Without hardware multiply
Hardware multiply
Without hardware multiply
Hardware multiply
Without hardware multiply
Hardware multiply
Without hardware multiply
Hardware multiply
1998-2013 Microchip Technology Inc.
Time
Program
Memory
(Words)
Cycles
(Max)
@ 33 MHz
@ 16 MHz
@ 8 MHz
13
1
—
6
21
24
52
36
69
1
—
6
242
24
254
36
8.364 s
0.121 s
—
0.727 s
29.333 s
2.91 s
30.788 s
4.36 s
17.25 s
0.25 s
—
1.50 s
60.50 s
6.0 s
63.50 s
9.0 s
34.50 s
0.50 s
—
3.0 s
121.0 s
12.0 s
127.0 s
18.0 s
DS30289C-page 67
PIC17C7XX
Example 9-3 shows the sequence to do a 16 x 16
unsigned multiply. Equation 9-1 shows the algorithm
that is used. The 32-bit result is stored in 4 registers,
RES3:RES0.
EQUATION 9-1:
RES3:RES0 =
=
16 x 16 UNSIGNED
MULTIPLICATION
ALGORITHM
EXAMPLE 9-3:
MOVFP
MULWF
MOVPF
MOVPF
16 x 16 UNSIGNED
MULTIPLY ROUTINE
ARG1L, WREG
ARG2L
; ARG1L * ARG2L ->
;
PRODH:PRODL
PRODH, RES1 ;
PRODL, RES0 ;
;
ARG1H:ARG1L ARG2H:ARG2L
16)
(ARG1H ARG2H 2
+
8)
(ARG1H ARG2L 2
+
(ARG1L ARG2H 28)
+
MOVFP
MULWF
MOVPF
MOVPF
ARG1H, WREG
ARG2H
; ARG1H * ARG2H ->
;
PRODH:PRODL
PRODH, RES3 ;
PRODL, RES2 ;
;
(ARG1L ARG2L)
MOVFP
MULWF
MOVFP
ADDWF
MOVFP
ADDWFC
CLRF
ADDWFC
ARG1L, WREG
ARG2H
; ARG1L * ARG2H ->
;
PRODH:PRODL
PRODL, WREG ;
RES1, F
; Add cross
PRODH, WREG ;
products
RES2, F
;
WREG, F
;
RES3, F
;
;
MOVFP
MULWF
MOVFP
ADDWF
MOVFP
ADDWFC
CLRF
ADDWFC
DS30289C-page 68
ARG1H, WREG ;
ARG2L
; ARG1H * ARG2L ->
;
PRODH:PRODL
PRODL, WREG ;
RES1, F
; Add cross
PRODH, WREG ;
products
RES2, F
;
WREG, F
;
RES3, F
;
1998-2013 Microchip Technology Inc.
PIC17C7XX
Example 9-4 shows the sequence to do a 16 x 16
signed multiply. Equation 9-2 shows the algorithm
used. The 32-bit result is stored in four registers,
RES3:RES0. To account for the sign bits of the arguments, each argument pairs most significant bit (MSb)
is tested and the appropriate subtractions are done.
EQUATION 9-2:
16 x 16 SIGNED
MULTIPLICATION
ALGORITHM
EXAMPLE 9-4:
MOVFP
MULWF
MOVPF
MOVPF
ARG1L, WREG
ARG2L
; ARG1L * ARG2L ->
;
PRODH:PRODL
PRODH, RES1 ;
PRODL, RES0 ;
;
MOVFP
MULWF
RES3:RES0
MOVPF
MOVPF
= ARG1H:ARG1L ARG2H:ARG2L
= (ARG1H ARG2H 216)
+
(ARG1H ARG2L 28)
+
(ARG1L ARG2H 28)
+
(ARG1L ARG2L)
+
(-1 ARG2H ARG1H:ARG1L 216)
(-1 ARG1H ARG2H:ARG2L 2
16 x 16 SIGNED
MULTIPLY ROUTINE
ARG1H, WREG
ARG2H
; ARG1H * ARG2H ->
;
PRODH:PRODL
PRODH, RES3 ;
PRODL, RES2 ;
;
MOVFP
MULWF
MOVFP
ADDWF
MOVFP
ADDWFC
CLRF
ADDWFC
+
16)
ARG1L, WREG
ARG2H
; ARG1L * ARG2H ->
;
PRODH:PRODL
PRODL, WREG ;
RES1, F
; Add cross
PRODH, WREG ;
products
RES2, F
;
WREG, F
;
RES3, F
;
;
MOVFP
MULWF
MOVFP
ADDWF
MOVFP
ADDWFC
CLRF
ADDWFC
ARG1H, WREG ;
ARG2L
; ARG1H * ARG2L ->
;
PRODH:PRODL
PRODL, WREG ;
RES1, F
; Add cross
PRODH, WREG ;
products
RES2, F
;
WREG, F
;
RES3, F
;
BTFSS
GOTO
MOVFP
SUBWF
MOVFP
SUBWFB
ARG2H, 7
SIGN_ARG1
ARG1L, WREG
RES2
ARG1H, WREG
RES3
; ARG2H:ARG2L neg?
; no, check ARG1
;
;
;
ARG1H, 7
CONT_CODE
ARG2L, WREG
RES2
ARG2H, WREG
RES3
; ARG1H:ARG1L neg?
; no, done
;
;
;
;
;
SIGN_ARG1
BTFSS
GOTO
MOVFP
SUBWF
MOVFP
SUBWFB
;
CONT_CODE
:
1998-2013 Microchip Technology Inc.
DS30289C-page 69
PIC17C7XX
NOTES:
DS30289C-page 70
1998-2013 Microchip Technology Inc.
PIC17C7XX
10.0
I/O PORTS
PIC17C75X devices have seven I/O ports, PORTA
through PORTG. PIC17C76X devices have nine I/O
ports, PORTA through PORTJ. PORTB through
PORTJ have a corresponding Data Direction Register
(DDR), which is used to configure the port pins as
inputs or outputs. Some of these ports pins are multiplexed with alternate functions.
PORTC, PORTD, and PORTE are multiplexed with the
system bus. These pins are configured as the system
bus when the device’s configuration bits are selected to
Microprocessor or Extended Microcontroller modes. In
the two other microcontroller modes, these pins are
general purpose I/O.
PORTA, PORTB, PORTE, PORTF, PORTG and
the upper four bits of PORTH are multiplexed with the
peripheral features of the device. These peripheral features are:
•
•
•
•
•
•
•
Timer Modules
Capture Modules
PWM Modules
USART/SCI Modules
SSP Module
A/D Module
External Interrupt pin
1998-2013 Microchip Technology Inc.
When some of these peripheral modules are turned on,
the port pin will automatically configure to the alternate
function. The modules that do this are:
• PWM Module
• SSP Module
• USART/SCI Module
When a pin is automatically configured as an output by
a peripheral module, the pins data direction (DDR) bit
is unknown. After disabling the peripheral module, the
user should re-initialize the DDR bit to the desired configuration.
The other peripheral modules (which require an input)
must have their data direction bits configured appropriately.
Note:
A pin that is a peripheral input, can be configured as an output (DDRx is cleared).
The peripheral events will be determined
by the action output on the port pin.
When the device enters the “RESET state”, the Data
Direction registers (DDR) are forced set, which will
make the I/O hi-impedance inputs. The RESET state of
some peripheral modules may force the I/O to other
operations, such as analog inputs or the system bus.
DS30289C-page 71
PIC17C7XX
10.1
PORTA Register
PORTA is a 6-bit wide latch. PORTA does not have a
corresponding Data Direction Register (DDR). Upon a
device RESET, the PORTA pins are forced to be hiimpedance inputs. For the RA4 and RA5 pins, the
peripheral module controls the output. When a device
RESET occurs, the peripheral module is disabled, so
these pins are forced to be hi-impedance inputs.
Reading PORTA reads the status of the pins.
The RA0 pin is multiplexed with the external interrupt,
INT. The RA1 pin is multiplexed with TMR0 clock input,
RA2 and RA3 are multiplexed with the SSP functions,
and RA4 and RA5 are multiplexed with the USART1
functions. The control of RA2, RA3, RA4 and RA5 as
outputs, is automatically configured by their multiplexed peripheral module when the module is enabled.
10.1.1
Example 10-1 shows an instruction sequence to initialize PORTA. The Bank Select Register (BSR) must be
selected to Bank 0 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
EXAMPLE 10-1:
MOVLB
MOVLW
MOVWF
0
0xF3
PORTA
FIGURE 10-1:
USING RA2, RA3 AS OUTPUTS
INITIALIZING PORTA
; Select Bank 0
;
; Initialize PORTA
;
RA are output low
;
RA and RA
;
are inputs
;
(outputs floating)
RA0 AND RA1 BLOCK
DIAGRAM
The RA2 and RA3 pins are open drain outputs. To use
the RA2 and/or the RA3 pin(s) as output(s), simply
write to the PORTA register the desired value. A '0' will
cause the pin to drive low, while a '1' will cause the pin
to float (hi-impedance). An external pull-up resistor
should be used to pull the pin high. Writes to the RA2
and RA3 pins will not affect the other PORTA pins.
Note:
When using the RA2 or RA3 pin(s) as output(s), read-modify-write instructions (such
as BCF, BSF, BTG) on PORTA are not
recommended.
Such operations read the port pins, do the
desired operation, and then write this value
to the data latch. This may inadvertently
cause the RA2 or RA3 pins to switch from
input to output (or vice-versa).
Data Bus
RD_PORTA
(Q2)
Note: Input pins have protection diodes to VDD and VSS.
FIGURE 10-2:
RA2 BLOCK DIAGRAM
Peripheral Data In
D
To avoid this possibility, use a shadow register for PORTA. Do the bit operations on
this shadow register and then move it to
PORTA.
Q
Data Bus
EN
RD_PORTA
(Q2)
Q
1
0
Q
D
CK
WR_PORTA
(Q4)
SCL Out
I2C Mode Enable
Note: I/O pin has protection diodes to VSS.
DS30289C-page 72
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 10-3:
RA3 BLOCK DIAGRAM
FIGURE 10-4:
Peripheral Data In
RA4 AND RA5 BLOCK
DIAGRAM
Serial Port Input Signal
D
Q
Data Bus
EN
Data Bus
RD_PORTA
(Q2)
RD_PORTA
(Q2)
Q
D
Q
Serial Port Output Signals
WR_PORTA
(Q4)
SDA Out
CK
OE = SPEN,SYNC,TXEN, CREN, SREN for RA4
OE = SPEN (SYNC+SYNC, CSRC) for RA5
'1'
Note: I/O pins have protection diodes to VDD and VSS.
SSP Mode
Note: I/O pin has protection diodes to VSS.
TABLE 10-1:
PORTA FUNCTIONS
Name
Bit0
Buffer Type
Function
RA0/INT
bit0
ST
Input or external interrupt input.
RA1/T0CKI
bit1
ST
Input or clock input to the TMR0 timer/counter and/or an external interrupt
input.
RA2/SS/SCL
bit2
ST
Input/output or slave select input for the SPI, or clock input for the I2C bus.
Output is open drain type.
RA3/SDI/SDA
bit3
ST
Input/output or data input for the SPI, or data for the I2C bus.
Output is open drain type.
RA4/RX1/DT1
bit4
ST
Input or USART1 Asynchronous Receive input, or
USART1 Synchronous Data input/output.
RA5/TX1/CK1
bit5
ST
Input or USART1 Asynchronous Transmit output, or
USART1 Synchronous Clock input/output.
RBPU
bit7
—
Control bit for PORTB weak pull-ups.
Legend: ST = Schmitt Trigger input
TABLE 10-2:
Address
REGISTERS/BITS ASSOCIATED WITH PORTA
Value on
POR,
BOR
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
MCLR, WDT
10h, Bank 0
PORTA(1)
RBPU
—
RA5/
TX1/CK1
RA4/
RX1/DT1
RA3/
SDI/SDA
RA2/
SS/SCL
RA1/T0CKI
RA0/INT
0-xx 11xx
0-uu 11uu
05h, Unbanked
T0STA
INTEDG
T0SE
T0CS
T0PS3
T0PS2
T0PS1
T0PS0
—
0000 000-
0000 000-
13h, Bank 0
RCSTA1
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
Legend: x = unknown, u = unchanged, - = unimplemented, reads as '0'. Shaded cells are not used by PORTA.
Note 1: On any device RESET, these pins are configured as inputs.
1998-2013 Microchip Technology Inc.
DS30289C-page 73
PIC17C7XX
10.2
PORTB and DDRB Registers
This interrupt can wake the device from SLEEP. The
user, in the Interrupt Service Routine, can clear the
interrupt by:
PORTB is an 8-bit wide, bi-directional port. The corresponding data direction register is DDRB. A '1' in DDRB
configures the corresponding port pin as an input. A '0'
in the DDRB register configures the corresponding port
pin as an output. Reading PORTB reads the status of
the pins, whereas writing to PORTB will write to the port
latch.
a)
b)
A mismatch condition will continue to set the RBIF bit.
Reading, then writing PORTB, will end the mismatch
condition and allow the RBIF bit to be cleared.
Each of the PORTB pins has a weak internal pull-up. A
single control bit can turn on all the pull-ups. This is
done by clearing the RBPU (PORTA) bit. The weak
pull-up is automatically turned off when the port pin is
configured as an output. The pull-ups are enabled on
any RESET.
This interrupt-on-mismatch feature, together with software configurable pull-ups on this port, allows easy
interface to a keypad and makes it possible for wakeup on key depression. For an example, refer to Application Note AN552, “Implementing Wake-up on
Keystroke.”
PORTB also has an interrupt-on-change feature. Only
pins configured as inputs can cause this interrupt to
occur (i.e., any RB7:RB0 pin configured as an output is
excluded from the interrupt-on-change comparison).
The input pins (of RB7:RB0) are compared with the
value in the PORTB data latch. The “mismatch” outputs
of RB7:RB0 are OR’d together to set the PORTB Interrupt Flag bit, RBIF (PIR1).
FIGURE 10-5:
Read-Write PORTB (such as: MOVPF PORTB,
PORTB). This will end the mismatch condition.
Then, clear the RBIF bit.
The interrupt-on-change feature is recommended for
wake-up on operations, where PORTB is only used for
the interrupt-on-change feature and key depression
operations.
Note:
On a device RESET, the RBIF bit is indeterminate, since the value in the latch may
be different than the pin.
BLOCK DIAGRAM OF RB5:RB4 AND RB1:RB0 PORT PINS
Peripheral Data In
RBPU (PORTA)
Weak
Pull-up
Match Signal
from other
port pins
RBIF
Port
Input Latch
Data Bus
RD_DDRB (Q2)
RD_PORTB (Q2)
D
OE
Q
WR_DDRB (Q4)
CK
D
Port
Data
Q
CK
WR_PORTB (Q4)
Note: I/O pins have protection diodes to VDD and VSS.
DS30289C-page 74
1998-2013 Microchip Technology Inc.
PIC17C7XX
EXAMPLE 10-2:
Example 10-2 shows an instruction sequence to initialize PORTB. The Bank Select Register (BSR) must be
selected to Bank 0 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
FIGURE 10-6:
MOVLB
CLRF
0
PORTB, F
MOVLW
0xCF
MOVWF
DDRB
INITIALIZING PORTB
;
;
;
;
;
;
;
;
Select Bank 0
Init PORTB by clearing
output data latches
Value used to initialize
data direction
Set RB as inputs
RB as outputs
RB as inputs
BLOCK DIAGRAM OF RB3:RB2 PORT PINS
Peripheral Data In
RBPU (PORTA)
Weak
Pull-up
Match Signal
from other
port pins
RBIF
Port
Input Latch
Data Bus
RD_DDRB (Q2)
RD_PORTB (Q2)
D
OE
Q
WR_DDRB (Q4)
CK
D
Port
Data
Q
CK
R
WR_PORTB (Q4)
Peripheral_output
Peripheral_enable
Note: I/O pins have protection diodes to VDD and VSS.
1998-2013 Microchip Technology Inc.
DS30289C-page 75
PIC17C7XX
FIGURE 10-7:
BLOCK DIAGRAM OF RB6 PORT PIN
Peripheral Data In
RBPU (PORTA)
Weak
Pull-up
Match Signal
from other
port pins
RBIF
D
Q
Data Bus
EN
RD_DDRB (Q2)
RD_PORTB (Q2)
D
OE
Q
WR_DDRB (Q4)
CK
P
Port
Data
0
Q
D
1
Q
WR_PORTB (Q4)
CK
N
SPI Output
SPI Output Enable
Note: I/O pin has protection diodes to Vdd and Vss.
FIGURE 10-8:
BLOCK DIAGRAM OF RB7 PORT PIN
Peripheral Data In
RBPU (PORTA)
Weak
Pull-up
Match Signal
from other
port pins
RBIF
D
Q
Data Bus
EN
RD_DDRB (Q2)
RD_PORTB (Q2)
D
Q
OE
WR_DDRB (Q4)
CK
P
0
Port
Data
SS Output Disable
Q
D
1
N
Q
CK
WR_PORTB (Q4)
SPI Output
SPI Output Enable
Note: I/O pin has protection diodes to VDD and VSS.
DS30289C-page 76
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 10-3:
PORTB FUNCTIONS
Name
Bit
Buffer Type
Function
RB0/CAP1
bit0
ST
Input/output or the Capture1 input pin. Software programmable weak
pull-up and interrupt-on-change features.
RB1/CAP2
bit1
ST
Input/output or the Capture2 input pin. Software programmable weak
pull-up and interrupt-on-change features.
RB2/PWM1
bit2
ST
Input/output or the PWM1 output pin. Software programmable weak pull-up
and interrupt-on-change features.
RB3/PWM2
bit3
ST
Input/output or the PWM2 output pin. Software programmable weak pull-up
and interrupt-on-change features.
RB4/TCLK12
bit4
ST
Input/output or the external clock input to Timer1 and Timer2. Software
programmable weak pull-up and interrupt-on-change features.
RB5/TCLK3
bit5
ST
Input/output or the external clock input to Timer3. Software programmable
weak pull-up and interrupt-on-change features.
RB6/SCK
bit6
ST
Input/output or the Master/Slave clock for the SPI. Software programmable
weak pull-up and interrupt-on-change features.
RB7/SDO
bit7
ST
Input/output or data output for the SPI. Software programmable weak
pull-up and interrupt-on-change features.
Legend: ST = Schmitt Trigger input
TABLE 10-4:
REGISTERS/BITS ASSOCIATED WITH PORTB
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
12h, Bank 0
PORTB
RB7/
SDO
RB6/
SCK
RB5/
TCLK3
RB4/
TCLK12
RB3/
PWM2
RB2/
PWM1
RB1/
CAP2
RB0/
CAP1
11h, Bank 0
DDRB
10h, Bank 0
PORTA
RA3/
SDI/SDA
RA2/
SS/SCL
RA1/T0CKI
RA0/INT
Data Direction Register for PORTB
RBPU
Value on
POR,
BOR
MCLR,
WDT
xxxx xxxx uuuu uuuu
1111 1111 1111 1111
—
RA5/
TX1/CK1
RA4/
RX1/DT1
0-xx 11xx 0-uu 11uu
06h, Unbanked
CPUSTA
—
—
STKAV
GLINTD
TO
PD
POR
BOR
--11 11qq --11 qquu
07h, Unbanked
INTSTA
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
0000 0000 0000 0000
16h, Bank 1
PIR1
RBIF
TMR3IF
TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010 u000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE
TMR2IE
TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000 0000 0000
CA1ED1
CA1ED0
T16
16h, Bank 3
TCON1
CA2ED1 CA2ED0
TMR3CS
TMR2CS
TMR1CS 0000 0000 0000 0000
17h, Bank 3
TCON2
CA2OVF CA1OVF PWM2ON PWM1ON CA1/PR3 TMR3ON
TMR2ON
TMR1ON 0000 0000 0000 0000
Legend:
x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends on condition. Shaded cells are not used by PORTB.
1998-2013 Microchip Technology Inc.
DS30289C-page 77
PIC17C7XX
10.3
PORTC and DDRC Registers
Example 10-3 shows an instruction sequence to initialize PORTC. The Bank Select Register (BSR) must be
selected to Bank 1 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
PORTC is an 8-bit bi-directional port. The corresponding data direction register is DDRC. A '1' in DDRC configures the corresponding port pin as an input. A '0' in
the DDRC register configures the corresponding port
pin as an output. Reading PORTC reads the status of
the pins, whereas writing to PORTC will write to the port
latch. PORTC is multiplexed with the system bus.
When operating as the system bus, PORTC is the low
order byte of the address/data bus (AD7:AD0). The timing for the system bus is shown in the Electrical Specifications section.
Note:
EXAMPLE 10-3:
MOVLB
CLRF
This port is configured as the system bus
when the device’s configuration bits are
selected to Microprocessor or Extended
Microcontroller modes. In the two other
microcontroller modes, this port is a
general purpose I/O.
FIGURE 10-9:
1
PORTC, F
MOVLW
0xCF
MOVWF
DDRC
INITIALIZING PORTC
;
;
;
;
;
;
;
;
;
Select Bank 1
Initialize PORTC data
latches before setting
the data direction reg
Value used to initialize
data direction
Set RC as inputs
RC as outputs
RC as inputs
BLOCK DIAGRAM OF RC7:RC0 PORT PINS
To D_Bus IR
INSTRUCTION READ
Data Bus
TTL
Input
Buffer
RD_PORTC
0
1
Port
Data
D
Q
WR_PORTC
CK
D
Q
R
CK
S
RD_DDRC
WR_DDRC
EX_EN
DATA/ADDR_OUT
DRV_SYS
System Bus
Control
Note: I/O pins have protection diodes to VDD and VSS.
DS30289C-page 78
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 10-5:
PORTC FUNCTIONS
Name
Bit
Buffer Type
Function
RC0/AD0
bit0
TTL
Input/output or system bus address/data pin.
RC1/AD1
bit1
TTL
Input/output or system bus address/data pin.
RC2/AD2
bit2
TTL
Input/output or system bus address/data pin.
RC3/AD3
bit3
TTL
Input/output or system bus address/data pin.
RC4/AD4
bit4
TTL
Input/output or system bus address/data pin.
RC5/AD5
bit5
TTL
Input/output or system bus address/data pin.
RC6/AD6
bit6
TTL
Input/output or system bus address/data pin.
RC7/AD7
bit7
TTL
Input/output or system bus address/data pin.
Legend: TTL = TTL input
TABLE 10-6:
REGISTERS/BITS ASSOCIATED WITH PORTC
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
11h, Bank 1
PORTC
RC7/
AD7
RC6/
AD6
RC5/
AD5
RC4/
AD4
RC3/
AD3
RC2/
AD2
RC1/
AD1
RC0/
AD0
10h, Bank 1
DDRC
Data Direction Register for PORTC
Value on
POR,
BOR
MCLR,
WDT
xxxx xxxx uuuu uuuu
1111 1111 1111 1111
Legend: x = unknown, u = unchanged
1998-2013 Microchip Technology Inc.
DS30289C-page 79
PIC17C7XX
10.4
PORTD and DDRD Registers
Example 10-4 shows an instruction sequence to initialize PORTD. The Bank Select Register (BSR) must be
selected to Bank 1 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
PORTD is an 8-bit bi-directional port. The corresponding data direction register is DDRD. A '1' in DDRD configures the corresponding port pin as an input. A '0' in
the DDRD register configures the corresponding port
pin as an output. Reading PORTD reads the status of
the pins, whereas writing to PORTD will write to the port
latch. PORTD is multiplexed with the system bus.
When operating as the system bus, PORTD is the high
order byte of the address/data bus (AD15:AD8). The
timing for the system bus is shown in the Electrical
Specifications section.
Note:
EXAMPLE 10-4:
MOVLB
CLRF
This port is configured as the system bus
when the device’s configuration bits are
selected to Microprocessor or Extended
Microcontroller modes. In the two other
microcontroller modes, this port is a general purpose I/O.
FIGURE 10-10:
1
PORTD, F
MOVLW
0xCF
MOVWF
DDRD
INITIALIZING PORTD
;
;
;
;
;
;
;
;
;
Select Bank 1
Initialize PORTD data
latches before setting
the data direction reg
Value used to initialize
data direction
Set RD as inputs
RD as outputs
RD as inputs
BLOCK DIAGRAM OF RD7:RD0 PORT PINS (IN I/O PORT MODE)
To D_Bus IR
INSTRUCTION READ
Data Bus
TTL
Input
Buffer
RD_PORTD
0
1
Port
Data
D
Q
WR_PORTD
CK
D
Q
R
CK
S
RD_DDRD
WR_DDRD
EX_EN
DATA/ADDR_OUT
DRV_SYS
System Bus
Control
Note: I/O pins have protection diodes to VDD and VSS.
DS30289C-page 80
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 10-7:
PORTD FUNCTIONS
Name
Bit
Buffer Type
RD0/AD8
bit0
TTL
Function
Input/output or system bus address/data pin.
RD1/AD9
bit1
TTL
Input/output or system bus address/data pin.
RD2/AD10
bit2
TTL
Input/output or system bus address/data pin.
RD3/AD11
bit3
TTL
Input/output or system bus address/data pin.
RD4/AD12
bit4
TTL
Input/output or system bus address/data pin.
RD5/AD13
bit5
TTL
Input/output or system bus address/data pin.
RD6/AD14
bit6
TTL
Input/output or system bus address/data pin.
RD7/AD15
bit7
TTL
Input/output or system bus address/data pin.
Legend: TTL = TTL input
TABLE 10-8:
Address
REGISTERS/BITS ASSOCIATED WITH PORTD
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
13h, Bank 1 PORTD
RD7/
AD15
RD6/
AD14
RD5/
AD13
RD4/
AD12
RD3/
AD11
RD2/
AD10
RD1/
AD9
RD0/
AD8
12h, Bank 1 DDRD
Data Direction Register for PORTD
Value on
POR,
BOR
MCLR,
WDT
xxxx xxxx uuuu uuuu
1111 1111 1111 1111
Legend: x = unknown, u = unchanged
1998-2013 Microchip Technology Inc.
DS30289C-page 81
PIC17C7XX
10.5
PORTE and DDRE Register
PORTE is a 4-bit bi-directional port. The corresponding
data direction register is DDRE. A '1' in DDRE configures the corresponding port pin as an input. A '0' in the
DDRE register configures the corresponding port pin
as an output. Reading PORTE reads the status of the
pins, whereas writing to PORTE will write to the port
latch. PORTE is multiplexed with the system bus.
When operating as the system bus, PORTE contains
the control signals for the address/data bus
(AD15:AD0). These control signals are Address Latch
Enable (ALE), Output Enable (OE) and Write (WR).
The control signals OE and WR are active low signals.
The timing for the system bus is shown in the Electrical
Specifications section.
Note:
Example 10-5 shows an instruction sequence to initialize PORTE. The Bank Select Register (BSR) must be
selected to Bank 1 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
EXAMPLE 10-5:
MOVLB
CLRF
1
PORTE, F
MOVLW
0x03
MOVWF
DDRE
Three pins of this port are configured as
the system bus when the device’s configuration bits are selected to Microprocessor
or Extended Microcontroller modes. The
other pin is a general purpose I/O or
Capture4 pin. In the two other microcontroller modes, RE2:RE0 are general
purpose I/O pins.
FIGURE 10-11:
INITIALIZING PORTE
;
;
;
;
;
;
;
;
;
;
;
Select Bank 1
Initialize PORTE data
latches before setting
the data direction
register
Value used to initialize
data direction
Set RE as inputs
RE as outputs
RE are always
read as '0'
BLOCK DIAGRAM OF RE2:RE0 (IN I/O PORT MODE)
Data Bus
TTL
Input
Buffer
RD_PORTE
0
1
Port
Data
D
Q
WR_PORTE
CK
D
Q
R
CK
S
RD_DDRE
WR_DDRE
EX_EN
CNTL
DRV_SYS
System Bus
Control
Note: I/O pins have protection diodes to VDD and VSS.
DS30289C-page 82
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 10-12:
BLOCK DIAGRAM OF RE3/CAP4 PORT PIN
Peripheral In
D
Data Bus
Q
EN
EN
VDD
RD_PORTE
P
Q
Port
Data
D
N
WR_PORTE
CK
Q
RD_DDRE
D
Q
WR_DDRE
CK
S
Q
Note: I/O pin has protection diodes to VDD and VSS.
TABLE 10-9:
PORTE FUNCTIONS
Name
Bit
Buffer Type
Function
RE0/ALE
bit0
TTL
Input/output or system bus Address Latch Enable (ALE) control pin.
RE1/OE
bit1
TTL
Input/output or system bus Output Enable (OE) control pin.
RE2/WR
bit2
TTL
Input/output or system bus Write (WR) control pin.
RE3/CAP4
bit3
ST
Input/output or Capture4 input pin.
Legend: TTL = TTL input, ST = Schmitt Trigger input
TABLE 10-10: REGISTERS/BITS ASSOCIATED WITH PORTE
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
—
—
—
—
RE3/CAP4
RE2/WR
RE1/OE
RE0/ALE
15h, Bank 1
PORTE
---- xxxx
---- uuuu
14h, Bank 1
DDRE
Data Direction Register for PORTE
---- 1111
---- 1111
14h, Bank 7
CA4L
Capture4 Low Byte
xxxx xxxx
uuuu uuuu
15h, Bank 7
CA4H
Capture4 High Byte
xxxx xxxx
uuuu uuuu
16h, Bank 7
TCON3
-000 0000
-000 0000
Legend:
—
CA4OVF
CA3OVF
CA4ED1
CA4ED0
CA3ED1
CA3ED0
PWM3ON
x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTE.
1998-2013 Microchip Technology Inc.
DS30289C-page 83
PIC17C7XX
10.6
PORTF and DDRF Registers
Example 10-6 shows an instruction sequence to initialize PORTF. The Bank Select Register (BSR) must be
selected to Bank 5 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
PORTF is an 8-bit wide bi-directional port. The corresponding data direction register is DDRF. A '1' in DDRF
configures the corresponding port pin as an input. A '0'
in the DDRF register configures the corresponding port
pin as an output. Reading PORTF reads the status of
the pins, whereas writing to PORTF will write to the
respective port latch.
EXAMPLE 10-6:
MOVLB
MOVWF
MOVWF
CLRF
All eight bits of PORTF are multiplexed with 8 channels
of the 10-bit A/D converter.
INITIALIZING PORTF
5
0x0E
ADCON1
PORTF, F
Upon RESET, the entire Port is automatically configured as analog inputs and must be configured in software to be a digital I/O.
FIGURE 10-13:
Data Bus
MOVLW
0x03
MOVWF
DDRF
;
;
;
;
;
;
;
;
;
;
;
Select Bank 5
Configure PORTF as
Digital
Initialize PORTF data
latches before
the data direction
register
Value used to init
data direction
Set RF as inputs
RF as outputs
BLOCK DIAGRAM OF RF7:RF0
D
Q
VDD
WR PORTF
CK
Q
P
Data Latch
I/O pin
WR DDRF
D
Q
CK
Q
N
VSS
DDRF Latch
ST
Input
Buffer
RD DDRF
Q
D
EN
EN
RD PORTF
PCFG3:PCFG0
To other pads
VAIN
CHS3:CHS0
To other pads
Note: I/O pins have protection diodes to VDD and VSS.
DS30289C-page 84
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 10-11: PORTF FUNCTIONS
Name
Bit
Buffer Type
Function
RF0/AN4
bit0
ST
Input/output or analog input 4.
RF1/AN5
bit1
ST
Input/output or analog input 5.
RF2/AN6
bit2
ST
Input/output or analog input 6.
RF3/AN7
bit3
ST
Input/output or analog input 7.
RF4/AN8
bit4
ST
Input/output or analog input 8.
RF5/AN9
bit5
ST
Input/output or analog input 9.
RF6/AN10
bit6
ST
Input/output or analog input 10.
RF7/AN11
bit7
ST
Input/output or analog input 11.
Legend: ST = Schmitt Trigger input
TABLE 10-12: REGISTERS/BITS ASSOCIATED WITH PORTF
Address
Name
10h, Bank 5 DDRF
11h, Bank 5 PORTF
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
RF0/
AN4
Data Direction Register for PORTF
RF7/
AN11
RF6/
AN10
15h, Bank 5 ADCON1 ADCS1 ADCS0
Value on
POR,
BOR
MCLR,
WDT
1111 1111 1111 1111
RF5/
AN9
RF4/
AN8
RF3/
AN7
RF2/
AN6
RF1/
AN5
ADFM
—
PCFG3
PCFG2
PCFG1
0000 0000 0000 0000
PCFG0 000- 0000 000- 0000
Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTF.
1998-2013 Microchip Technology Inc.
DS30289C-page 85
PIC17C7XX
10.7
PORTG and DDRG Registers
Example 10-7 shows the instruction sequence to initialize PORTG. The Bank Select Register (BSR) must be
selected to Bank 5 for the port to be initialized. The following example uses the MOVLB instruction to load the
BSR register for bank selection.
PORTG is an 8-bit wide, bi-directional port. The corresponding data direction register is DDRG. A '1' in
DDRG configures the corresponding port pin as an
input. A '0' in the DDRG register configures the corresponding port pin as an output. Reading PORTG reads
the status of the pins, whereas writing to PORTG will
write to the port latch.
EXAMPLE 10-7:
MOVLB
MOVLW
MOVPF
CLRF
The lower four bits of PORTG are multiplexed with four
channels of the 10-bit A/D converter.
The remaining bits of PORTG are multiplexed with
peripheral output and inputs. RG4 is multiplexed with
the CAP3 input, RG5 is multiplexed with the PWM3
output, RG6 and RG7 are multiplexed with the
USART2 functions.
MOVLW
MOVWF
Upon RESET, RG3:RG0 is automatically configured as
analog inputs and must be configured in software to be
a digital I/O.
FIGURE 10-14:
Data Bus
INITIALIZING PORTG
5
; Select Bank 5
0x0E
; Configure PORTG as
WREG, ADCON1 ; digital
PORTG, F
; Initialize PORTG data
;
latches before
;
the data direction
;
register
0x03
; Value used to init
;
data direction
DDRG
; Set RG as inputs
;
RG as outputs
BLOCK DIAGRAM OF RG3:RG0
D
Q
VDD
WR PORTG
CK
Q
P
Data Latch
I/O pin
WR DDRG
D
Q
CK
Q
N
VSS
DDRG Latch
ST
Input
Buffer
RD DDRG
Q
D
EN
EN
RD PORTG
PCFG3:PCFG0
To other pads
VAIN
CHS3:CHS0
To other pads
Note: I/O pins have protection diodes to VDD and VSS.
DS30289C-page 86
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 10-15:
RG4 BLOCK DIAGRAM
Peripheral Data In
Data Bus
Q
D
EN
EN
RD_PORTG
D
VDD
WR_PORTG
CK
Q
P
RD_DDRG
D
Q
N
Q
WR_DDRG
CK
Note: I/O pins have protection diodes to VDD and VSS.
FIGURE 10-16:
RG7:RG5 BLOCK DIAGRAM
Peripheral Data In
D
Data Bus
Q
NEN
RD_PORTG
VDD
1
P
Port
Data
D
Q
Q
WR_PORTG
CK
0
D
Q
N
Q
CK
R
RD_DDRG
WR_DDRG
OUTPUT
OUTPUT ENABLE
Note: I/O pins have protection diodes to VDD and VSS.
1998-2013 Microchip Technology Inc.
DS30289C-page 87
PIC17C7XX
TABLE 10-13: PORTG FUNCTIONS
Name
Bit
Buffer Type
bit0
ST
Input/output or analog input 3.
RG1/AN2
bit1
ST
Input/output or analog input 2.
RG2/AN1/VREF-
bit2
ST
Input/output or analog input 1 or the ground reference voltage.
RG3/AN0/VREF+
bit3
ST
Input/output or analog input 0 or the positive reference voltage.
RG4/CAP3
bit4
ST
Input/output or the Capture3 input pin.
RG5/PWM3
bit5
ST
Input/output or the PWM3 output pin.
RG6/RX2/DT2
bit6
ST
Input/output or the USART2 (SCI) Asynchronous Receive or USART2
(SCI) Synchronous Data.
RG7/TX2/CK2
bit7
ST
Input/output or the USART2 (SCI) Asynchronous Transmit or USART2
(SCI) Synchronous Clock.
RG0/AN3
Function
Legend: ST = Schmitt Trigger input
TABLE 10-14: REGISTERS/BITS ASSOCIATED WITH PORTG
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
12h, Bank 5
DDRG
Data Direction Register for PORTG
1111 1111
1111 1111
13h, Bank 5
PORTG
RG7/
TX2/CK2
RG6/
RX2/DT2
RG5/
PWM3
RG4/
CAP3
RG3/
AN0
RG2/
AN1
RG1/
AN2
RG0/
AN3
xxxx 0000
uuuu 0000
15h, Bank 5
ADCON1
ADCS1
ADCS0
ADFM
—
PCFG3
PCFG2
PCFG1
PCFG0
000- 0000
000- 0000
Legend:
x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PORTG.
DS30289C-page 88
1998-2013 Microchip Technology Inc.
PIC17C7XX
10.8
EXAMPLE 10-8:
PORTH and DDRH Registers
(PIC17C76X only)
MOVLB
MOVLW
MOVPF
CLRF
PORTH is an 8-bit wide, bi-directional port. The corresponding data direction register is DDRH. A '1' in
DDRH configures the corresponding port pin as an
input. A '0' in the DDRH register configures the corresponding port pin as an output. Reading PORTH reads
the status of the pins, whereas writing to PORTH will
write to the respective port latch.
The upper four bits of PORTH are multiplexed with
4 channels of the 10-bit A/D converter.
8
0x0E
ADCON1
PORTH, F
MOVLW
0x03
MOVWF
DDRH
INITIALIZING PORTH
;
;
;
;
;
;
;
;
;
;
;
Select Bank 8
Configure PORTH as
digital
Initialize PORTH data
latches before
the data direction
register
Value used to init
data direction
Set RH as inputs
RH as outputs
The remaining bits of PORTH are general purpose I/O.
Upon RESET, RH7:RH4 are automatically configured
as analog inputs and must be configured in software to
be a digital I/O.
FIGURE 10-17:
Data Bus
BLOCK DIAGRAM OF RH7:RH4
D
Q
VDD
WR PORTH
Q
CK
P
Data Latch
I/O pin
WR DDRH
D
Q
CK
Q
N
VSS
DDRH Latch
ST
Input
Buffer
RD DDRH
Q
D
EN
EN
RD PORT
PCFG3:PCFG0
To other pads
VAIN
CHS3:CHS0
To other pads
Note: I/O pins have protection diodes to VDD and VSS.
1998-2013 Microchip Technology Inc.
DS30289C-page 89
PIC17C7XX
FIGURE 10-18:
RH3:RH0 BLOCK DIAGRAM
Data Bus
Q
D
EN
EN
RD_PORTH
D
VDD
Q
RD_DDRH
D
Q
N
WR_PORTH
CK
Q
P
WR_DDRH
CK
Note: I/O pins have protection diodes to VDD and VSS.
TABLE 10-15: PORTH FUNCTIONS
Bit
Buffer Type
RH0
Name
bit0
ST
Input/output.
Function
RH1
bit1
ST
Input/output.
RH2
bit2
ST
Input/output.
RH3
bit3
ST
Input/output.
RH4/AN12
bit4
ST
Input/output or analog input 12.
RH5/AN13
bit5
ST
Input/output or analog input 13.
RH6/AN14
bit6
ST
Input/output or analog input 14.
RH7/AN15
bit7
ST
Input/output or analog input 15.
Legend: ST = Schmitt Trigger input
TABLE 10-16: REGISTERS/BITS ASSOCIATED WITH PORTH
Address
Name
10h, Bank 8
DDRH
11h, Bank 8
PORTH
15h, Bank 5
ADCON1
Legend:
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Data Direction Register for PORTH
Value on
POR,
BOR
MCLR, WDT
1111 1111 1111 1111
RH7/
AN15
RH6/
AN14
RH5/
AN13
RH4/
AN12
RH3
RH2
RH1
RH0
0000 xxxx 0000 uuuu
ADCS1
ADCS0
ADFM
—
PCFG3
PCFG2
PCFG1
PCFG0
000- 0000 000- 0000
x = unknown, u = unchanged
DS30289C-page 90
1998-2013 Microchip Technology Inc.
PIC17C7XX
10.9
EXAMPLE 10-9:
PORTJ and DDRJ Registers
(PIC17C76X only)
MOVLB
CLRF
PORTJ is an 8-bit wide, bi-directional port. The corresponding data direction register is DDRJ. A '1' in DDRJ
configures the corresponding port pin as an input. A '0'
in the DDRJ register configures the corresponding port
pin as an output. Reading PORTJ reads the status of
the pins, whereas writing to PORTJ will write to the
respective port latch.
PORTJ is a general purpose I/O port.
FIGURE 10-19:
8
PORTJ, F
MOVLW
0xCF
MOVWF
DDRJ
INITIALIZING PORTJ
;
;
;
;
;
;
;
;
;
;
Select Bank 8
Initialize PORTJ data
latches before setting
the data direction
register
Value used to initialize
data direction
Set RJ as inputs
RJ as outputs
RJ as inputs
PORTJ BLOCK DIAGRAM
D
Data Bus
Q
EN
EN
RD_PORTJ
D
VDD
P
Q
D
Q
N
Q
WR_PORTJ
CK
CK
RD_DDRJ
WR_DDRJ
Note: I/O pins have protection diodes to VDD and VSS.
1998-2013 Microchip Technology Inc.
DS30289C-page 91
PIC17C7XX
TABLE 10-17: PORTJ FUNCTIONS
Name
Bit
Buffer Type
Function
RJ0
bit0
ST
Input/output
RJ1
bit1
ST
Input/output
RJ2
bit2
ST
Input/output
RJ3
bit3
ST
Input/output
RJ4
bit4
ST
Input/output
RJ5
bit5
ST
Input/output
RJ6
bit6
ST
Input/output
RJ7
bit7
ST
Input/output
Legend: ST = Schmitt Trigger input
TABLE 10-18: REGISTERS/BITS ASSOCIATED WITH PORTJ
Address
Name
12h, Bank 8
DDRJ
13h, Bank 8
PORTJ
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
RJ2
RJ1
RJ0
Data Direction Register for PORTJ
RJ7
RJ6
RJ5
RJ4
RJ3
Value on,
POR,
BOR
MCLR,
WDT
1111 1111 1111 1111
xxxx xxxx uuuu uuuu
Legend: x = unknown, u = unchanged
DS30289C-page 92
1998-2013 Microchip Technology Inc.
PIC17C7XX
10.10 I/O Programming Considerations
10.10.1
EXAMPLE 10-10:
BI-DIRECTIONAL I/O PORTS
Any instruction which writes, operates internally as a
read, followed by a write operation. For example, the
BCF and BSF instructions read the register into the
CPU, execute the bit operation and write the result
back to the register. Caution must be used when these
instructions are applied to a port with both inputs and
outputs defined. For example, a BSF operation on bit5
of PORTB, will cause all eight bits of PORTB to be read
into the CPU. Then the BSF operation takes place on
bit5 and PORTB is written to the output latches. If
another bit of PORTB is used as a bi-directional I/O pin
(e.g. bit0) and it is defined as an input at this time, the
input signal present on the pin itself would be read into
the CPU and rewritten to the data latch of this particular
pin, overwriting the previous content. As long as the pin
stays in the input mode, no problem occurs. However,
if bit0 is switched into output mode later on, the content
of the data latch may now be unknown.
Reading a port reads the values of the port pins. Writing
to the port register writes the value to the port latch.
When using read-modify-write instructions (BCF, BSF,
BTG, etc.) on a port, the value of the port pins is read,
the desired operation is performed with this value and
the value is then written to the port latch.
READ-MODIFY-WRITE
INSTRUCTIONS ON AN
I/O PORT
; Initial PORT settings: PORTB Inputs
;
PORTB Outputs
; PORTB have pull-ups and are
; not connected to other circuitry
;
;
PORT latch PORT pins
;
---------- --------;
BCF
PORTB, 7
; 01pp pppp
11pp pppp
BCF
PORTB, 6
; 10pp pppp
11pp pppp
BCF
BCF
;
;
;
;
;
DDRB, 7
DDRB, 6
; 10pp pppp
; 10pp pppp
11pp pppp
10pp pppp
Note that the user may have expected the
pin values to be 00pp pppp. The 2nd BCF
caused RB7 to be latched as the pin value
(High).
Note:
A pin actively outputting a Low or High
should not be driven from external devices,
in order to change the level on this pin (i.e.,
“wired-or”, “wired-and”). The resulting high
output currents may damage the device.
Example 10-10 shows the possible effect of two
sequential read-modify-write instructions on an I/O port.
1998-2013 Microchip Technology Inc.
DS30289C-page 93
PIC17C7XX
10.10.2
SUCCESSIVE OPERATIONS ON I/O
PORTS
Figure 10-21 shows the I/O model which causes this
situation. As the effective capacitance (C) becomes
larger, the rise/fall time of the I/O pin increases. As the
device frequency increases, or the effective capacitance increases, the possibility of this subsequent
PORTx read-modify-write instruction issue increases.
This effective capacitance includes the effects of the
board traces.
The actual write to an I/O port happens at the end of an
instruction cycle, whereas for reading, the data must be
valid at the beginning of the instruction cycle
(Figure 10-20). Therefore, care must be exercised if a
write followed by a read operation is carried out on the
same I/O port. The sequence of instructions should be
such to allow the pin voltage to stabilize (load dependent) before executing the instruction that reads the
values on that I/O port. Otherwise, the previous state of
that pin may be read into the CPU, rather than the
“new” state. When in doubt, it is better to separate
these instructions with a NOP, or another instruction
not accessing this I/O port.
FIGURE 10-20:
The best way to address this is to add a series resistor
at the I/O pin. This resistor allows the I/O pin to get to
the desired level before the next instruction.
The use of NOP instructions between the subsequent
PORTx read-modify-write instructions, is a lower cost
solution, but has the issue that the number of NOP
instructions is dependent on the effective capacitance
C and the frequency of the device.
SUCCESSIVE I/O OPERATION
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4
Note:
PC
Instruction
Fetched
MOVWF PORTB
write to
PORTB
PC + 1
PC + 3
PC + 2
This example shows a write to PORTB,
followed by a read from PORTB.
MOVF PORTB,W
NOP
NOP
Note that:
data setup time = (0.25TCY - TPD)
RB7:RB0
where
Port pin
sampled here
Instruction
Executed
FIGURE 10-21:
MOVWF PORTB
write to
PORTB
MOVF PORTB,W
TCY = instruction cycle
TPD = propagation delay
Therefore, at higher clock frequencies, a
write followed by a read may be problematic.
NOP
I/O CONNECTION ISSUES
BSF PORTx, PINy
PIC17CXXX
Q2
I/O
Q3
Q4
BSF PORTx, PINz
Q1
Q2
Q3
Q4
Q1
VIL
C(1)
PORTx, PINy
Read PORTx, PINy as low
Note 1: This is not a capacitor to ground, but the effective
capacitive loading on the trace.
DS30289C-page 94
BSF PORTx, PINz clears the value
to be driven on the PORTx, PINy pin.
1998-2013 Microchip Technology Inc.
PIC17C7XX
11.0
OVERVIEW OF TIMER
RESOURCES
The PIC17C7XX has four timer modules. Each module
can generate an interrupt to indicate that an event has
occurred. These timers are called:
• Timer0 - 16-bit timer with programmable 8-bit
prescaler
• Timer1 - 8-bit timer
• Timer2 - 8-bit timer
• Timer3 - 16-bit timer
For enhanced time base functionality, four input Captures and three Pulse Width Modulation (PWM) outputs
are possible. The PWMs use the Timer1 and Timer2
resources and the input Captures use the Timer3
resource.
11.1
Timer0 Overview
The Timer0 module is a simple 16-bit overflow counter.
The clock source can be either the internal system
clock (Fosc/4) or an external clock.
When Timer0 uses an external clock source, it has the
flexibility to allow user selection of the incrementing
edge, rising or falling.
The Timer0 module also has a programmable prescaler. The T0PS3:T0PS0 bits (T0STA) determine
the prescale value. TMR0 can increment at the following rates: 1:1, 1:2, 1:4, 1:8, 1:16, 1:32, 1:64, 1:128,
1:256.
Synchronization of the external clock occurs after the
prescaler. When the prescaler is used, the external
clock frequency may be higher than the device’s frequency. The maximum external frequency on the
T0CKI pin is 50 MHz, given the high and low time
requirements of the clock.
11.2
11.3
Timer2 Overview
The Timer2 module is an 8-bit timer/counter with an 8bit period register (PR2). When the TMR2 value rolls
over from the period match value to 0h, the TMR2IF
flag is set and an interrupt will be generated, if enabled.
In Counter mode, the clock comes from the RB4/
TCLK12 pin, which can also provide the clock for the
Timer1 module.
TMR2 can be concatenated with TMR1 to form a 16-bit
timer. The TMR2 register is the MSB and TMR1 is the
LSB. When in the 16-bit timer mode, there is a corresponding 16-bit period register (PR2:PR1). When the
TMR2:TMR1 value rolls over from the period match
value to 0h, the TMR1IF flag is set and an interrupt will
be generated, if enabled.
11.4
Timer3 Overview
The Timer3 module is a 16-bit timer/counter with a 16bit period register. When the TMR3H:TMR3L value
rolls over to 0h, the TMR3IF bit is set and an interrupt
will be generated, if enabled. In Counter mode, the
clock comes from the RB5/TCLK3 pin.
When operating in the four Capture modes, the period
registers become the second (of four) 16-bit capture
registers.
11.5
Role of the Timer/Counters
The timer modules are general purpose, but have dedicated resources associated with them. TImer1 and
Timer2 are the time bases for the three Pulse Width
Modulation (PWM) outputs, while Timer3 is the time
base for the four input captures.
Timer1 Overview
The Timer1 module is an 8-bit timer/counter with an 8bit period register (PR1). When the TMR1 value rolls
over from the period match value to 0h, the TMR1IF
flag is set and an interrupt will be generated if enabled.
In Counter mode, the clock comes from the RB4/
TCLK12 pin, which can also be selected to be the clock
for the Timer2 module.
TMR1 can be concatenated with TMR2 to form a 16-bit
timer. The TMR1 register is the LSB and TMR2 is the
MSB. When in the 16-bit timer mode, there is a corresponding 16-bit period register (PR2:PR1). When the
TMR2:TMR1 value rolls over from the period match
value to 0h, the TMR1IF flag is set and an interrupt will
be generated, if enabled.
1998-2013 Microchip Technology Inc.
DS30289C-page 95
PIC17C7XX
NOTES:
DS30289C-page 96
1998-2013 Microchip Technology Inc.
PIC17C7XX
12.0
TIMER0
The Timer0 module consists of a 16-bit timer/counter,
TMR0. The high byte is register TMR0H and the low
byte is register TMR0L. A software programmable 8-bit
prescaler makes Timer0 an effective 24-bit overflow
timer. The clock source is software programmable as
either the internal instruction clock, or an external clock
on the RA1/T0CKI pin. The control bits for this module
are in register T0STA (Figure 12-1).
REGISTER 12-1: T0STA REGISTER (ADDRESS: 05h, UNBANKED)
R/W-0
INTEDG
R/W-0
T0SE
R/W-0
T0CS
R/W-0
T0PS3
R/W-0
T0PS2
R/W-0
T0PS1
R/W-0
T0PS0
bit 7
U-0
—
bit 0
bit 7
INTEDG: RA0/INT Pin Interrupt Edge Select bit
This bit selects the edge upon which the interrupt is detected.
1 = Rising edge of RA0/INT pin generates interrupt
0 = Falling edge of RA0/INT pin generates interrupt
bit 6
T0SE: Timer0 Clock Input Edge Select bit
This bit selects the edge upon which TMR0 will increment.
When T0CS = 0 (External Clock):
1 = Rising edge of RA1/T0CKI pin increments TMR0 and/or sets the T0CKIF bit
0 = Falling edge of RA1/T0CKI pin increments TMR0 and/or sets the T0CKIF bit
When T0CS = 1 (Internal Clock):
Don’t care
bit 5
T0CS: Timer0 Clock Source Select bit
This bit selects the clock source for TMR0.
1 = Internal instruction clock cycle (TCY)
0 = External clock input on the T0CKI pin
bit 4-1
T0PS3:T0PS0: Timer0 Prescale Selection bits
These bits select the prescale value for TMR0.
T0PS3:T0PS0 Prescale Value
0000
0001
0010
0011
0100
0101
0110
0111
1xxx
bit 0
1:1
1:2
1:4
1:8
1:16
1:32
1:64
1:128
1:256
Unimplemented: Read as '0'
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 97
PIC17C7XX
12.1
Timer0 Operation
12.2
When the T0CS (T0STA) bit is set, TMR0 increments on the internal clock. When T0CS is clear, TMR0
increments on the external clock (RA1/T0CKI pin). The
external clock edge can be selected in software. When
the T0SE (T0STA) bit is set, the timer will increment
on the rising edge of the RA1/T0CKI pin. When T0SE
is clear, the timer will increment on the falling edge of
the RA1/T0CKI pin. The prescaler can be programmed
to introduce a prescale of 1:1 to 1:256. The timer increments from 0000h to FFFFh and rolls over to 0000h.
On overflow, the TMR0 Interrupt Flag bit (T0IF) is set.
The TMR0 interrupt can be masked by clearing the corresponding TMR0 Interrupt Enable bit (T0IE). The
TMR0 Interrupt Flag bit (T0IF) is automatically cleared
when vectoring to the TMR0 interrupt vector.
FIGURE 12-1:
Using Timer0 with External Clock
When an external clock input is used for Timer0, it is
synchronized with the internal phase clocks. Figure 122 shows the synchronization of the external clock. This
synchronization is done after the prescaler. The output
of the prescaler (PSOUT) is sampled twice in every
instruction cycle to detect a rising or a falling edge. The
timing requirements for the external clock are detailed
in the electrical specification section.
12.2.1
DELAY FROM EXTERNAL CLOCK
EDGE
Since the prescaler output is synchronized with the
internal clocks, there is a small delay from the time the
external clock edge occurs to the time TMR0 is actually
incremented. Figure 12-2 shows that this delay is
between 3TOSC and 7TOSC. Thus, for example, measuring the interval between two edges (e.g. period) will
be accurate within 4TOSC (121 ns @ 33 MHz).
TIMER0 MODULE BLOCK DIAGRAM
Interrupt-on-Overflow
sets T0IF
(INTSTA)
0
RA1/T0CKI
FOSC/4
1
Prescaler
(8 Stage
Async Ripple
Counter)
T0SE
(T0STA)
TMR0H TMR0L
4
T0CS
(T0STA)
FIGURE 12-2:
Synchronization
PSOUT
T0PS3:T0PS0
(T0STA)
Q2
Q4
TMR0 TIMING WITH EXTERNAL CLOCK (INCREMENT ON FALLING EDGE)
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Prescaler
Output
(PSOUT)
(Note 3)
Sampled
(Note 2)
Prescaler
Output
(Note 1)
Increment
TMR0
TMR0
T0
T0 + 1
T0 + 2
Note 1: The delay from the T0CKI edge to the TMR0 increment is 3Tosc to 7Tosc.
2: = PSOUT is sampled here.
3: The PSOUT high time is too short and is missed by the sampling circuit.
DS30289C-page 98
1998-2013 Microchip Technology Inc.
PIC17C7XX
12.3
Read/Write Consideration for
TMR0
Although TMR0 is a 16-bit timer/counter, only 8-bits at
a time can be read or written during a single instruction
cycle. Care must be taken during any read or write.
12.3.1
READING 16-BIT VALUE
The problem in reading the entire 16-bit value is that
after reading the low (or high) byte, its value may
change from FFh to 00h.
Example 12-1 shows a 16-bit read. To ensure a proper
read, interrupts must be disabled during this routine.
EXAMPLE 12-1:
MOVPF
MOVPF
MOVFP
CPFSLT
RETURN
MOVPF
MOVPF
RETURN
16-BIT READ
TMR0L, TMPLO
TMR0H, TMPHI
TMPLO, WREG
TMR0L
;read low tmr0
;read high tmr0
;tmplo wreg
;tmr0l < wreg?
;no then return
;read low tmr0
;read high tmr0
;return
TMR0L, TMPLO
TMR0H, TMPHI
FIGURE 12-3:
WRITING A 16-BIT VALUE TO TMR0
Since writing to either TMR0L or TMR0H will effectively
inhibit increment of that half of the TMR0 in the next
cycle (following write), but not inhibit increment of the
other half, the user must write to TMR0L first and
TMR0H second, in two consecutive instructions, as
shown in Example 12-2. The interrupt must be disabled. Any write to either TMR0L or TMR0H clears the
prescaler.
EXAMPLE 12-2:
BSF
MOVFP
MOVFP
BCF
12.4
16-BIT WRITE
CPUSTA, GLINTD
RAM_L, TMR0L
RAM_H, TMR0H
CPUSTA, GLINTD
; Disable interrupts
;
;
; Done, enable
;
interrupts
Prescaler Assignments
Timer0 has an 8-bit prescaler. The prescaler selection
is fully under software control; i.e., it can be changed
“on the fly” during program execution. Clearing the
prescaler is recommended before changing its setting.
The value of the prescaler is “unknown” and assigning
a value that is less than the present value, makes it difficult to take this unknown time into account.
TMR0 TIMING: WRITE HIGH OR LOW BYTE
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
AD15:AD0
12.3.2
PC
PC+1
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
PC+2
PC+3
PC+4
ALE
TMR0L
T0
T0+1
New T0 (NT0)
New T0+1
Fetch
Instruction
Executed
MOVFP W,TMR0L MOVFP TMR0L,W MOVFP TMR0L,W MOVFP TMR0L,W
Write to TMR0L
Read TMR0L
Read TMR0L
Read TMR0L
(Value = NT0)
(Value = NT0)
(Value = NT0 +1)
TMR0H
1998-2013 Microchip Technology Inc.
DS30289C-page 99
PIC17C7XX
FIGURE 12-4:
TMR0 READ/WRITE IN TIMER MODE
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
AD15:AD0
ALE
WR_TRM0L
WR_TMR0H
RD_TMR0L
TMR0L
Instruction
Fetched
Instruction
Executed
12
12
TMR0H
FE
56
FF
MOVFP
MOVFP
DATAL,TMR0L DATAH,TMR0H
Write TMR0L Write TMR0H
Previously
Fetched
Instruction
AB
13
57
MOVPF
TMR0L,W
Read TMR0L
MOVFP
MOVFP
DATAL,TMR0L DATAH,TMR0H
Write TMR0L Write TMR0H
MOVPF
TMR0L,W
Read TMR0L
58
MOVPF
TMR0L,W
Read TMR0L
MOVPF
TMR0L,W
Read TMR0L
MOVPF
TMR0L,W
Read TMR0L
MOVPF
TMR0L,W
Read TMR0L
MOVPF
TMR0L,W
Read TMR0L
Note: In this example, old TMR0 value is 12FEh, new value of AB56h is written.
TABLE 12-1:
Address
REGISTERS/BITS ASSOCIATED WITH TIMER0
Name
Bit 7
Bit 6
Bit 5
INTEDG
T0SE
—
—
PEIF
T0CKIF
T0IF
Bit 0
Value on
POR,
BOR
MCLR, WDT
T0PS0
—
0000 000-
0000 000-
POR
BOR
--11 11qq
--11 qquu
T0IE
INTE
Bit 4
Bit 3
Bit 2
Bit 1
T0CS
T0PS3
T0PS2
T0PS1
STKAV
GLINTD
TO
PD
INTF
PEIE
T0CKIE
05h, Unbanked
T0STA
06h, Unbanked
CPUSTA
07h, Unbanked
INTSTA
0000 0000
0000 0000
0Bh, Unbanked
TMR0L
TMR0 Register; Low Byte
xxxx xxxx
uuuu uuuu
0Ch, Unbanked
TMR0H
TMR0 Register; High Byte
xxxx xxxx
uuuu uuuu
Legend:
x = unknown, u = unchanged, - = unimplemented, read as a '0', q = value depends on condition. Shaded cells are not used by Timer0.
DS30289C-page 100
1998-2013 Microchip Technology Inc.
PIC17C7XX
13.0
TIMER1, TIMER2, TIMER3,
PWMS AND CAPTURES
Six other registers comprise the Capture2, Capture3,
and Capture4 registers (CA2H:CA2L, CA3H:CA3L,
and CA4H:CA4L).
The PIC17C7XX has a wealth of timers and time based
functions to ease the implementation of control applications. These time base functions include three PWM
outputs and four Capture inputs.
Figure 13-1, Figure 13-2 and Figure 13-3 are the control registers for the operation of Timer1, Timer2 and
Timer3, as well as PWM1, PWM2, PWM3, Capture1,
Capture2, Capture3 and Capture4.
Timer1 and Timer2 are two 8-bit incrementing timers,
each with an 8-bit period register (PR1 and PR2, respectively) and separate overflow interrupt flags. Timer1 and
Timer2 can operate either as timers (increment on internal FOSC/4 clock), or as counters (increment on falling
edge of external clock on pin RB4/TCLK12). They are
also software configurable to operate as a single 16-bit
timer/counter. These timers are also used as the time
base for the PWM (Pulse Width Modulation) modules.
Table 13-1 shows the Timer resource requirements for
these time base functions. Each timer is an open
resource so that multiple functions may operate with it.
TABLE 13-1:
TIME-BASE FUNCTION/
RESOURCE REQUIREMENTS
Time Base Function
PWM1
PWM2
PWM3
Capture1
Capture2
Capture3
Capture4
Timer3 is a 16-bit timer/counter which uses the TMR3H
and TMR3L registers. Timer3 also has two additional
registers (PR3H/CA1H:PR3L/CA1L) that are configurable as a 16-bit period register or a 16-bit capture
register. TMR3 can be software configured to increment from the internal system clock (FOSC/4), or from
an external signal on the RB5/TCLK3 pin. Timer3 is the
time base for all of the 16-bit captures.
Timer Resource
Timer1
Timer1 or Timer2
Timer1 or Timer2
Timer3
Timer3
Timer3
Timer3
REGISTER 13-1: TCON1 REGISTER (ADDRESS: 16h, BANK 3)
R/W-0
CA2ED1
R/W-0
CA2ED0
R/W-0
CA1ED1
R/W-0
CA1ED0
R/W-0
T16
R/W-0
TMR3CS
R/W-0
TMR2CS
bit 7
R/W-0
TMR1CS
bit 0
bit 7-6
CA2ED1:CA2ED0: Capture2 Mode Select bits
00 = Capture on every falling edge
01 = Capture on every rising edge
10 = Capture on every 4th rising edge
11 = Capture on every 16th rising edge
bit 5-4
CA1ED1:CA1ED0: Capture1 Mode Select bits
00 = Capture on every falling edge
01 = Capture on every rising edge
10 = Capture on every 4th rising edge
11 = Capture on every 16th rising edge
bit 3
T16: Timer2:Timer1 Mode Select bit
1 = Timer2 and Timer1 form a 16-bit timer
0 = Timer2 and Timer1 are two 8-bit timers
bit 2
TMR3CS: Timer3 Clock Source Select bit
1 = TMR3 increments off the falling edge of the RB5/TCLK3 pin
0 = TMR3 increments off the internal clock
bit 1
TMR2CS: Timer2 Clock Source Select bit
1 = TMR2 increments off the falling edge of the RB4/TCLK12 pin
0 = TMR2 increments off the internal clock
bit 0
TMR1CS: Timer1 Clock Source Select bit
1 = TMR1 increments off the falling edge of the RB4/TCLK12 pin
0 = TMR1 increments off the internal clock
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 101
PIC17C7XX
REGISTER 13-2: TCON2 REGISTER (ADDRESS: 17h, BANK 3)
R-0
CA2OVF
R-0
CA1OVF
R/W-0
R/W-0
PWM2ON PWM1ON
R/W-0
CA1/PR3
R/W-0
TMR3ON
R/W-0
R/W-0
TMR2ON TMR1ON
bit 7
bit 0
bit 7
CA2OVF: Capture2 Overflow Status bit
This bit indicates that the capture value had not been read from the capture register pair
(CA2H:CA2L) before the next capture event occurred. The capture register retains the oldest
unread capture value (last capture before overflow). Subsequent capture events will not update
the capture register with the TMR3 value until the capture register has been read (both bytes).
1 = Overflow occurred on Capture2 register
0 = No overflow occurred on Capture2 register
bit 6
CA1OVF: Capture1 Overflow Status bit
This bit indicates that the capture value had not been read from the capture register pair (PR3H/
CA1H:PR3L/CA1L), before the next capture event occurred. The capture register retains the oldest unread capture value (last capture before overflow). Subsequent capture events will not
update the capture register with the TMR3 value until the capture register has been read (both
bytes).
1 = Overflow occurred on Capture1 register
0 = No overflow occurred on Capture1 register
bit 5
PWM2ON: PWM2 On bit
1 = PWM2 is enabled
(The RB3/PWM2 pin ignores the state of the DDRB bit.)
0 = PWM2 is disabled
(The RB3/PWM2 pin uses the state of the DDRB bit for data direction.)
bit 4
PWM1ON: PWM1 On bit
1 = PWM1 is enabled
(The RB2/PWM1 pin ignores the state of the DDRB bit.)
0 = PWM1 is disabled
(The RB2/PWM1 pin uses the state of the DDRB bit for data direction.)
bit 3
CA1/PR3: CA1/PR3 Register Mode Select bit
1 = Enables Capture1
(PR3H/CA1H:PR3L/CA1L is the Capture1 register. Timer3 runs without a period register.)
0 = Enables the Period register
(PR3H/CA1H:PR3L/CA1L is the Period register for Timer3.)
bit 2
TMR3ON: Timer3 On bit
1 = Starts Timer3
0 = Stops Timer3
bit 1
TMR2ON: Timer2 On bit
This bit controls the incrementing of the TMR2 register. When TMR2:TMR1 form the 16-bit timer
(T16 is set), TMR2ON must be set. This allows the MSB of the timer to increment.
1 = Starts Timer2 (must be enabled if the T16 bit (TCON1) is set)
0 = Stops Timer2
bit 0
TMR1ON: Timer1 On bit
When T16 is set (in 16-bit Timer mode):
1 = Starts 16-bit TMR2:TMR1
0 = Stops 16-bit TMR2:TMR1
When T16 is clear (in 8-bit Timer mode:
1 = Starts 8-bit Timer1
0 = Stops 8-bit Timer1
Legend:
DS30289C-page 102
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
REGISTER 13-3: TCON3 REGISTER (ADDRESS: 16h, BANK 7)
U-0
—
R-0
CA4OVF
R-0
CA3OVF
R/W-0
CA4ED1
R/W-0
CA4ED0
R/W-0
CA3ED1
R/W-0
R/W-0
CA3ED0 PWM3ON
bit 7
bit 0
bit 7
Unimplemented: Read as ‘0’
bit 6
CA4OVF: Capture4 Overflow Status bit
This bit indicates that the capture value had not been read from the capture register pair
(CA4H:CA4L) before the next capture event occurred. The capture register retains the oldest
unread capture value (last capture before overflow). Subsequent capture events will not update
the capture register with the TMR3 value until the capture register has been read (both bytes).
1 = Overflow occurred on Capture4 registers
0 = No overflow occurred on Capture4 registers
bit 5
CA3OVF: Capture3 Overflow Status bit
This bit indicates that the capture value had not been read from the capture register pair
(CA3H:CA3L) before the next capture event occurred. The capture register retains the oldest
unread capture value (last capture before overflow). Subsequent capture events will not update
the capture register with the TMR3 value until the capture register has been read (both bytes).
1 = Overflow occurred on Capture3 registers
0 = No overflow occurred on Capture3 registers
bit 4-3
CA4ED1:CA4ED0: Capture4 Mode Select bits
00 = Capture on every falling edge
01 = Capture on every rising edge
10 = Capture on every 4th rising edge
11 = Capture on every 16th rising edge
bit 2-1
CA3ED1:CA3ED0: Capture3 Mode Select bits
00 = Capture on every falling edge
01 = Capture on every rising edge
10 = Capture on every 4th rising edge
11 = Capture on every 16th rising edge
bit 0
PWM3ON: PWM3 On bit
1 = PWM3 is enabled (the RG5/PWM3 pin ignores the state of the DDRG bit)
0 = PWM3 is disabled (the RG5/PWM3 pin uses the state of the DDRG bit for data direction)
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 103
PIC17C7XX
13.1
13.1.1
Timer1 and Timer2
TIMER1, TIMER2 IN 8-BIT MODE
Both Timer1 and Timer2 will operate in 8-bit mode
when the T16 bit is clear. These two timers can be independently configured to increment from the internal
instruction cycle clock (TCY), or from an external clock
source on the RB4/TCLK12 pin. The timer clock source
is configured by the TMRxCS bit (x = 1 for Timer1,
or = 2 for Timer2). When TMRxCS is clear, the clock
source is internal and increments once every instruction cycle (FOSC/4). When TMRxCS is set, the clock
source is the RB4/TCLK12 pin and the counters will
increment on every falling edge of the RB4/TCLK12
pin.
The timer increments from 00h until it equals the Period
register (PRx). It then resets to 00h at the next increment cycle. The timer interrupt flag is set when the
timer is reset. TMR1 and TMR2 have individual interrupt flag bits. The TMR1 interrupt flag bit is latched into
TMR1IF and the TMR2 interrupt flag bit is latched into
TMR2IF.
FIGURE 13-1:
Each timer also has a corresponding interrupt enable
bit (TMRxIE). The timer interrupt can be enabled/
disabled by setting/clearing this bit. For peripheral
interrupts to be enabled, the Peripheral Interrupt
Enable bit must be set (PEIE = '1') and global interrupt
must be enabled (GLINTD = '0').
The timers can be turned on and off under software
control. When the timer on control bit (TMRxON) is set,
the timer increments from the clock source. When
TMRxON is cleared, the timer is turned off and cannot
cause the timer interrupt flag to be set.
13.1.1.1
External Clock Input for Timer1 and
Timer2
When TMRxCS is set, the clock source is the RB4/
TCLK12 pin, and the counter will increment on every
falling edge on the RB4/TCLK12 pin. The TCLK12
input is synchronized with internal phase clocks. This
causes a delay from the time a falling edge appears on
TCLK12 to the time TMR1 or TMR2 is actually incremented. For the external clock input timing requirements, see the Electrical Specification section.
TIMER1 AND TIMER2 IN TWO 8-BIT TIMER/COUNTER MODE
FOSC/4
0
TMR1
1
TMR1ON
(TCON2)
TMR1CS
(TCON1)
Comparator
Comparator x8
RESET
Set TMR1IF
(PIR1)
Equal
PR1
RB4/TCLK12
1
FOSC/4
TMR2
0
TMR2ON
(TCON2)
TMR2CS
(TCON1)
DS30289C-page 104
Comparator
Comparator x8
RESET
Set TMR2IF
(PIR1)
Equal
PR2
1998-2013 Microchip Technology Inc.
PIC17C7XX
13.1.2
TIMER1 AND TIMER2 IN 16-BIT
MODE
13.1.2.1
To select 16-bit mode, set the T16 bit. In this mode,
TMR2 and TMR1 are concatenated to form a 16-bit
timer (TMR2:TMR1). The 16-bit timer increments until
it matches the 16-bit period register (PR2:PR1). On the
following timer clock, the timer value is reset to 0h, and
the TMR1IF bit is set.
When selecting the clock source for the 16-bit timer, the
TMR1CS bit controls the entire 16-bit timer and
TMR2CS is a “don’t care”, however, ensure that
TMR2ON is set (allows TMR2 to increment). When
TMR1CS is clear, the timer increments once every
instruction cycle (FOSC/4). When TMR1CS is set, the
timer increments on every falling edge of the RB4/
TCLK12 pin. For the 16-bit timer to increment, both
TMR1ON and TMR2ON bits must be set (Table 13-2).
TABLE 13-2:
External Clock Input for
TMR2:TMR1
When TMR1CS is set, the 16-bit TMR2:TMR1 increments on the falling edge of clock input TCLK12. The
input on the RB4/TCLK12 pin is sampled and synchronized by the internal phase clocks twice every instruction cycle. This causes a delay from the time a falling
edge appears on RB4/TCLK12 to the time
TMR2:TMR1 is actually incremented. For the external
clock input timing requirements, see the Electrical
Specification section.
TURNING ON 16-BIT TIMER
T16 TMR2ON TMR1ON
Result
1
1
1
16-bit timer
(TMR2:TMR1) ON
1
0
1
Only TMR1 increments
1
x
0
16-bit timer OFF
0
1
1
Timers in 8-bit mode
FIGURE 13-2:
TMR2 AND TMR1 IN 16-BIT TIMER/COUNTER MODE
1
RB4/TCLK12
FOSC/4
0
TMR1ON
(TCON2)
TMR1CS
(TCON1)
Set Interrupt TMR1IF
(PIR1)
1998-2013 Microchip Technology Inc.
RESET
Equal
MSB
LSB
TMR2 x 8
TMR1 x 8
Comparator
Comparator
x16
PR2 x 8
PR1 x 8
DS30289C-page 105
PIC17C7XX
TABLE 13-3:
Address
SUMMARY OF TIMER1, TIMER2 AND TIMER3 REGISTERS
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
CA2ED0
CA1ED1
CA1ED0
T16
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
16h, Bank 3
TCON1
CA2ED1
TMR3CS TMR2CS
TMR1CS
0000 0000
0000 0000
17h, Bank 3
TCON2
CA2OVF CA1OVF PWM2ON PWM1ON CA1/PR3 TMR3ON TMR2ON
TMR1ON
0000 0000
0000 0000
16h, Bank 7
TCON3
PWM3ON
-000 0000
-000 0000
10h, Bank 2
TMR1
Timer1’s Register
xxxx xxxx
uuuu uuuu
11h, Bank 2
TMR2
Timer2’s Register
xxxx xxxx
uuuu uuuu
16h, Bank 1
PIR1
RBIF
TMR3IF
TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
u000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE
TMR2IE
TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
0000 0000
0000 0000
—
—
STKAV
GLINTD
TO
PD
POR
BOR
07h, Unbanked INTSTA
06h, Unbanked CPUSTA
—
CA4OVF
CA3OVF
CA4ED1
CA4ED0
CA3ED1
CA3ED0
--11 11qq
--11 qquu
14h, Bank 2
PR1
Timer1 Period Register
xxxx xxxx
uuuu uuuu
15h, Bank 2
PR2
Timer2 Period Register
xxxx xxxx
uuuu uuuu
10h, Bank 3
PW1DCL
DC1
DC0
—
—
—
—
—
—
xx-- ----
uu-- ----
11h, Bank 3
PW2DCL
DC1
DC0
TM2PW2
—
—
—
—
—
xx0- ----
uu0- ----
10h, Bank 7
PW3DCL
DC1
DC0
TM2PW3
—
—
—
—
—
xx0- ----
uu0- ----
12h, Bank 3
PW1DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx
uuuu uuuu
13h, Bank 3
PW2DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx
uuuu uuuu
11h, Bank 7
PW3DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx
uuuu uuuu
Legend:
x = unknown, u = unchanged, - = unimplemented, read as a '0', q = value depends on condition.
Shaded cells are not used by Timer1 or Timer2.
DS30289C-page 106
1998-2013 Microchip Technology Inc.
PIC17C7XX
13.1.3
USING PULSE WIDTH
MODULATION (PWM) OUTPUTS
WITH TIMER1 AND TIMER2
The user needs to set the PWM1ON bit (TCON2)
to enable the PWM1 output. When the PWM1ON bit is
set, the RB2/PWM1 pin is configured as PWM1 output
and forced as an output, irrespective of the data direction bit (DDRB). When the PWM1ON bit is clear,
the pin behaves as a port pin and its direction is controlled by its data direction bit (DDRB). Similarly,
the PWM2ON (TCON2) bit controls the configuration of the RB3/PWM2 pin and the PWM3ON
(TCON3) bit controls the configuration of the RG5/
PWM3 pin.
Three high speed pulse width modulation (PWM) outputs are provided. The PWM1 output uses Timer1 as
its time base, while PWM2 and PWM3 may independently be software configured to use either Timer1 or
Timer2 as the time base. The PWM outputs are on the
RB2/PWM1, RB3/PWM2 and RG5/PWM3 pins.
Each PWM output has a maximum resolution of 10bits. At 10-bit resolution, the PWM output frequency is
32.2 kHz (@ 32 MHz clock) and at 8-bit resolution the
PWM output frequency is 128.9 kHz. The duty cycle of
the output can vary from 0% to 100%.
FIGURE 13-3:
SIMPLIFIED PWM BLOCK
DIAGRAM
PWxDCL
Write
Duty Cycle Registers
Figure 13-3 shows a simplified block diagram of a
PWM module.
PWxDCH
The duty cycle registers are double buffered for glitch
free operation. Figure 13-4 shows how a glitch could
occur if the duty cycle registers were not double
buffered.
Read
(Slave)
PWMx
Comparator
R
TMRx
S
(Note 1)
Comparator
Q
PWMxON
Clear Timer,
PWMx pin and
Latch D.C.
PRy
Note 1: 8-bit timer is concatenated with 2-bit internal
Q clock or 2 bits of the prescaler to create
10-bit time base.
FIGURE 13-4:
PWM OUTPUT (NOT BUFFERED)
0
10
20
30
40
0
10
20
30
40
0
PWM
Output
Timer
Interrupt
Write New
PWM Duty Cycle Value
Timer Interrupt
New PWM Duty Cycle Value
Transferred to Slave
Note: The dotted line shows PWM output if duty cycle registers were not double buffered.
If the new duty cycle is written after the timer has passed that value, then the PWM does
not reset at all during the current cycle, causing a “glitch”.
In this example, PWM period = 50. Old duty cycle is 30. New duty cycle value is 10.
1998-2013 Microchip Technology Inc.
DS30289C-page 107
PIC17C7XX
13.1.3.1
PWM Periods
The period of the PWM1 output is determined by
Timer1 and its period register (PR1). The period of the
PWM2 and PWM3 outputs can be individually software
configured to use either Timer1 or Timer2 as the timebase. For PWM2, when TM2PW2 bit (PW2DCL) is
clear, the time base is determined by TMR1 and PR1
and when TM2PW2 is set, the time base is determined
by Timer2 and PR2. For PWM3, when TM2PW3 bit
(PW3DCL) is clear, the time base is determined by
TMR1 and PR1, and when TM2PW3 is set, the time
base is determined by Timer2 and PR2.
If DCx = 0, then the duty cycle is zero. If
PRx = PWxDCH, then the PWM output will be low for
one to four Q-clocks (depending on the state of the
PWxDCL bits). For a duty cycle to be 100%, the
PWxDCH value must be greater then the PRx value.
The duty cycle registers for both PWM outputs are double buffered. When the user writes to these registers,
they are stored in master latches. When TMR1 (or
TMR2) overflows and a new PWM period begins, the
master latch values are transferred to the slave latches
and the PWMx pin is forced high.
Note:
Running two different PWM outputs on two different
timers allows different PWM periods. Running all
PWMs from Timer1 allows the best use of resources by
freeing Timer2 to operate as an 8-bit timer. Timer1 and
Timer2 cannot be used as a 16-bit timer if any PWM is
being used.
The PWM periods can be calculated as follows:
The user should also avoid any "read-modify-write"
operations on the duty cycle registers, such as:
ADDWF PW1DCH. This may cause duty cycle outputs
that are unpredictable.
period of PWM1 = [(PR1) + 1] x 4TOSC
period of PWM2 = [(PR1) + 1] x 4TOSC or
[(PR2) + 1] x 4TOSC
period of PWM3 = [(PR1) + 1] x 4TOSC or
[(PR2) + 1] x 4TOSC
TABLE 13-4:
The duty cycle of PWMx is determined by the 10-bit
value DCx. The upper 8-bits are from register
PWxDCH and the lower 2-bits are from PWxDCL
(PWxDCH:PWxDCL). Table 13-4 shows the
maximum PWM frequency (FPWM), given the value in
the period register.
The number of bits of resolution that the PWM can
achieve depends on the operation frequency of the
device as well as the PWM frequency (FPWM).
Maximum PWM resolution (bits) for a given PWM
frequency:
log
=
( FF
OSC
PWM
bits
where: FPWM = 1 / period of PWM
The PWMx duty cycle is as follows:
PWMx Duty Cycle = (DCx) x TOSC
DS30289C-page 108
the
10-bit
PWM
Frequency
PRx Value
High
Resolution
Standard
Resolution
13.1.3.2
PWM FREQUENCY vs.
RESOLUTION AT 33 MHz
Frequency (kHz)
90.66
128.9
515.6
0xFF 0x7F 0x5A
10-bit 9-bit 8.5-bit
32.2
64.5
0x3F
8-bit
0x0F
6-bit
8-bit
6-bit
4-bit
7-bit
6.5-bit
PWM INTERRUPTS
The PWM modules make use of the TMR1 and/or
TMR2 interrupts. A timer interrupt is generated when
TMR1 or TMR2 equals its period register and on the
following increment is cleared to zero. This interrupt
also marks the beginning of a PWM cycle. The user
can write new duty cycle values before the timer
rollover. The TMR1 interrupt is latched into the TMR1IF
bit and the TMR2 interrupt is latched into the TMR2IF
bit. These flags must be cleared in software.
)
log (2)
where DCx represents
PWxDCH:PWxDCL.
For PW1DCH, PW1DCL, PW2DCH,
PW2DCL, PW3DCH and PW3DCL registers, a write operation writes to the "master
latches", while a read operation reads the
"slave latches". As a result, the user may
not read back what was just written to the
duty cycle registers (until transferred to
slave latch).
value
from
1998-2013 Microchip Technology Inc.
PIC17C7XX
13.1.3.3
External Clock Source
13.1.3.4
The PWMs will operate, regardless of the clock source
of the timer. The use of an external clock has ramifications that must be understood. Because the external
TCLK12 input is synchronized internally (sampled once
per instruction cycle), the time TCLK12 changes to the
time the timer increments, will vary by as much as 1TCY
(one instruction cycle). This will cause jitter in the duty
cycle as well as the period of the PWM output.
The use of an external clock for the PWM time base
(Timer1 or Timer2) limits the PWM output to a maximum resolution of 8-bits. The PWxDCL bits must
be kept cleared. Use of any other value will distort the
PWM output. All resolutions are supported when internal clock mode is selected. The maximum attainable
frequency is also lower. This is a result of the timing
requirements of an external clock input for a timer (see
the Electrical Specification section). The maximum
PWM frequency, when the timers clock source is the
RB4/TCLK12 pin, is shown in Table 13-4 (Standard
Resolution mode).
This jitter will be 1TCY, unless the external clock is synchronized with the processor clock. Use of one of the
PWM outputs as the clock source to the TCLK12 input,
will supply a synchronized clock.
In general, when using an external clock source for
PWM, its frequency should be much less than the
device frequency (FOSC).
TABLE 13-5:
Address
Maximum Resolution/Frequency for
External Clock Input
REGISTERS/BITS ASSOCIATED WITH PWM
Value on
POR,
BOR
MCLR,
WDT
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
TCON1
CA2ED1
CA2ED0
CA1ED1
CA1ED0
T16
TMR3CS
TMR2CS
TMR1CS
17h, Bank 3
TCON2
CA2OVF
CA1OVF
PWM2ON
PWM1ON
CA1/PR3 TMR3ON
TMR2ON
TMR1ON
0000 0000 0000 0000
16h, Bank 7
TCON3
—
CA4OVF
CA3OVF
CA4ED1
CA4ED0
CA3ED0
PWM3ON
-000 0000 -000 0000
16h, Bank 3
Name
CA3ED1
0000 0000 0000 0000
10h, Bank 2
TMR1
Timer1’s Register
11h, Bank 2
TMR2
Timer2’s Register
16h, Bank 1
PIR1
RBIF
TMR3IF
TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010 u000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE
TMR2IE
TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000 0000 0000
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
0000 0000 0000 0000
—
—
STKAV
GLINTD
TO
PD
POR
BOR
--11 11qq --11 qquu
07h, Unbanked INTSTA
06h, Unbanked CPUSTA
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
14h, Bank 2
PR1
Timer1 Period Register
15h, Bank 2
PR2
Timer2 Period Register
10h, Bank 3
PW1DCL
DC1
DC0
—
—
—
—
—
—
xx-- ---- uu-- ----
11h, Bank 3
PW2DCL
DC1
DC0
TM2PW2
—
—
—
—
—
xx0- ---- uu0- ----
10h, Bank 7
PW3DCL
DC1
DC0
TM2PW3
—
—
—
—
—
xx0- ---- uu0- ----
12h, Bank 3
PW1DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
xxxx xxxx uuuu uuuu
13h, Bank 3
PW2DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx uuuu uuuu
11h, Bank 7
PW3DCH
DC9
DC8
DC7
DC6
DC5
DC4
DC3
DC2
xxxx xxxx uuuu uuuu
Legend:
x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends on conditions.
Shaded cells are not used by PWM Module.
1998-2013 Microchip Technology Inc.
DS30289C-page 109
PIC17C7XX
13.2
Timer3
(RB0/CAP1, RB1/CAP2, RG4/CAP3, and RE3/CAP4),
one for each capture register pair. The capture pins are
multiplexed with the I/O pins. An event can be:
Timer3 is a 16-bit timer consisting of the TMR3H and
TMR3L registers. TMR3H is the high byte of the timer
and TMR3L is the low byte. This timer has an associated 16-bit period register (PR3H/CA1H:PR3L/CA1L).
This period register can be software configured to be a
another 16-bit capture register.
•
•
•
•
When the TMR3CS bit (TCON1) is clear, the timer
increments every instruction cycle (FOSC/4). When
TMR3CS is set, the counter increments on every falling
edge of the RB5/TCLK3 pin. In either mode, the
TMR3ON bit must be set for the timer/counter to increment. When TMR3ON is clear, the timer will not increment or set flag bit TMR3IF.
Each 16-bit capture register has an interrupt flag associated with it. The flag is set when a capture is made.
The capture modules are truly part of the Timer3 block.
Figure 13-5 and Figure 13-6 show the block diagrams
for the two modes of operation.
13.2.1
Timer3 has two modes of operation, depending on the
CA1/PR3 bit (TCON2). These modes are:
THREE CAPTURE AND ONE
PERIOD REGISTER MODE
In this mode, registers PR3H/CA1H and PR3L/CA1L
constitute a 16-bit period register. A block diagram is
shown in Figure 13-5. The timer increments until it
equals the period register and then resets to 0000h on
the next timer clock. TMR3 Interrupt Flag bit (TMR3IF)
is set at this point. This interrupt can be disabled by
clearing the TMR3 Interrupt Enable bit (TMR3IE).
TMR3IF must be cleared in software.
• Three capture and one period register mode
• Four capture register mode
The PIC17C7XX has up to four 16-bit capture registers
that capture the 16-bit value of TMR3 when events are
detected on capture pins. There are four capture pins
FIGURE 13-5:
A rising edge
A falling edge
Every 4th rising edge
Every 16th rising edge
TIMER3 WITH THREE CAPTURE AND ONE PERIOD REGISTER BLOCK DIAGRAM
TMR3CS
(TCON1)
PR3H/CA1H
PR3L/CA1L
Comparator x16
Comparator
0
FOSC/4
TMR3H
1
Set TMR3IF
(PIR1)
Equal
Reset
TMR3L
TMR3ON
(TCON2)
RB5/TCLK3
Edge select,
Prescaler select
RB1/CAP2
2
CA2ED1: CA2ED0
(TCON1)
Edge select,
Prescaler select
RG4/CAP3
2
CA3ED1: CA3ED0
(TCON3)
Edge select,
Prescaler select
RE3/CAP4
2
CA4ED1: CA4ED0
(TCON3)
DS30289C-page 110
Capture2
Enable
CA2H
CA2L
Set CA2IF
(PIR1)
Capture3
Enable
CA3H
CA3L
Set CA3IF
(PIR2)
Capture4
Enable
CA4H
CA4L
Set CA4IF
(PIR2)
1998-2013 Microchip Technology Inc.
PIC17C7XX
This mode (3 Capture, 1 Period) is selected if control bit
CA1/PR3 is clear. In this mode, the Capture1 register,
consisting of high byte (PR3H/CA1H) and low byte
(PR3L/CA1L), is configured as the period control register for TMR3. Capture1 is disabled in this mode and the
corresponding interrupt bit, CA1IF, is never set. TMR3
increments until it equals the value in the period register and then resets to 0000h on the next timer clock.
All other Captures are active in this mode.
13.2.1.1
Capture Operation
The CAxED1 and CAxED0 bits determine the event on
which capture will occur. The possible events are:
•
•
•
•
Capture on every falling edge
Capture on every rising edge
Capture every 4th rising edge
Capture every 16th rising edge
The input on the capture pin CAPx is synchronized
internally to internal phase clocks. This imposes certain
restrictions on the input waveform (see the Electrical
Specification section for timing).
The capture overflow status flag bit is double buffered.
The master bit is set if one captured word is already
residing in the Capture register (CAxH:CAxL) and
another “event” has occurred on the CAPx pin. The
new event will not transfer the TMR3 value to the capture register, protecting the previous unread capture
value. When the user reads both the high and the low
bytes (in any order) of the Capture register, the master
overflow bit is transferred to the slave overflow bit
(CAxOVF) and then the master bit is reset. The user
can then read TCONx to determine the value of CAxOVF.
The recommended sequence to read capture registers
and capture overflow flag bits is shown in Example 13-1.
When a capture takes place, an interrupt flag is latched
into the CAxIF bit. This interrupt can be enabled by setting the corresponding mask bit CAxIE. The Peripheral
Interrupt Enable bit (PEIE) must be set and the Global
Interrupt Disable bit (GLINTD) must be cleared for the
interrupt to be acknowledged. The CAxIF interrupt flag
bit is cleared in software.
When the capture prescale select is changed, the prescaler is not reset and an event may be generated.
Therefore, the first capture after such a change will be
ambiguous. However, it sets the time-base for the next
capture. The prescaler is reset upon chip RESET.
The capture pin, CAPx, is a multiplexed pin. When
used as a port pin, the capture is not disabled. However, the user can simply disable the Capture interrupt
by clearing CAxIE. If the CAPx pin is used as an output
pin, the user can activate a capture by writing to the
port pin. This may be useful during development phase
to emulate a capture interrupt.
1998-2013 Microchip Technology Inc.
DS30289C-page 111
PIC17C7XX
13.2.2
FOUR CAPTURE MODE
Registers PR3H/CA1H and PR3L/CA1L make a 16-bit
capture register (Capture1). It captures events on pin
RB0/CAP1. Capture mode is configured by the
CA1ED1 and CA1ED0 bits. Capture1 Interrupt Flag bit
(CA1IF) is set upon detection of the capture event. The
corresponding interrupt mask bit is CA1IE. The
Capture1 Overflow Status bit is CA1OVF.
This mode is selected by setting bit CA1/PR3. A block
diagram is shown in Figure 13-6. In this mode, TMR3
runs without a period register and increments from
0000h to FFFFh and rolls over to 0000h. The TMR3
interrupt Flag (TMR3IF) is set on this rollover. The
TMR3IF bit must be cleared in software.
FIGURE 13-6:
All the captures operate in the same manner. Refer to
Section 13.2.1 for the operation of capture.
TIMER3 WITH FOUR CAPTURES BLOCK DIAGRAM
FOSC/4
Set TMR3IF
(PIR1)
0
TMR3H
1
RB5/TCLK3
TMR3CS
(TCON1)
TMR3L
TMR3ON
(TCON2)
Edge Select,
Prescaler Select
RB0/CAP1
2
Capture1 Enable
Set CA1IF
(PIR1)
PR3H/CA1H
PR3L/CA1L
CA1ED1, CA1ED0
(TCON1)
Edge Select,
Prescaler Select
RB1/CAP2
2
CA2ED1, CA2ED0
(TCON1)
Edge Select,
Prescaler Select
RG4/CAP3
2
Capture2 Enable
Set CA2IF
(PIR1)
CA2H
CA2L
Capture3 Enable
Set CA3IF
(PIR2)
CA3H
CA3L
CA3ED1: CA3ED0
(TCON3)
Edge Select,
Prescaler Select
RE3/CAP4
2
Capture4 Enable
Set CA4IF
(PIR2)
CA4H
CA4L
CA4ED1: CA4ED0
(TCON3)
DS30289C-page 112
1998-2013 Microchip Technology Inc.
PIC17C7XX
13.2.3
READING THE CAPTURE
REGISTERS
order) of the Capture register, the master overflow bit is
transferred to the slave overflow bit (CAxOVF) and
then the master bit is reset. The user can then read
TCONx to determine the value of CAxOVF.
The Capture overflow status flag bits are double buffered. The master bit is set if one captured word is
already residing in the Capture register and another
“event” has occurred on the CAPx pin. The new event
will not transfer the TMR3 value to the capture register,
protecting the previous unread capture value. When
the user reads both the high and the low bytes (in any
EXAMPLE 13-1:
MOVLB
MOVPF
MOVPF
MOVPF
Address
SEQUENCE TO READ CAPTURE REGISTERS
3
CA2L, LO_BYTE
CA2H, HI_BYTE
TCON2, STAT_VAL
TABLE 13-6:
An example of an instruction sequence to read capture
registers and capture overflow flag bits is shown in
Example 13-1. Depending on the capture source, different registers will need to be read.
;
;
;
;
Select Bank 3
Read Capture2 low byte, store in LO_BYTE
Read Capture2 high byte, store in HI_BYTE
Read TCON2 into file STAT_VAL
REGISTERS ASSOCIATED WITH CAPTURE
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
CA1ED0
T16
Bit 2
Bit 1
Bit 0
TMR3CS TMR2CS TMR1CS
Value on
POR,
BOR
MCLR, WDT
16h, Bank 3
TCON1
CA2ED1 CA2ED0
CA1ED1
0000 0000
0000 0000
17h, Bank 3
TCON2
CA2OVF CA1OVF
PWM2ON
PWM1ON CA1/PR3 TMR3ON TMR2ON TMR1ON 0000 0000
0000 0000
16h, Bank 7
TCON3
CA3OVF
CA4ED1
12h, Bank 2
TMR3L
Holding Register for the Low Byte of the 16-bit TMR3 Register
13h, Bank 2
TMR3H
Holding Register for the High Byte of the 16-bit TMR3 Register
16h, Bank 1
PIR1
17h, Bank 1
10h, Bank 4
11h, Bank 4
—
CA4OVF
CA4ED0
CA3ED1
CA3ED0 PWM3ON -000 0000
-000 0000
xxxx xxxx
uuuu uuuu
xxxx xxxx
uuuu uuuu
x000 0010
u000 0010
RBIF
TMR3IF
TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
PIE1
RBIE
TMR3IE
TMR2IE
TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0010
000- 0010
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
0000 0000
0000 0000
—
—
STKAV
GLINTD
TO
PD
POR
BOR
--11 11qq
--11 qquu
xxxx xxxx
uuuu uuuu
07h, Unbanked INTSTA
06h, Unbanked CPUSTA
16h, Bank 2
PR3L/CA1L
17h, Bank 2
PR3H/CA1H Timer3 Period Register, High Byte/Capture1 Register, High Byte
xxxx xxxx
uuuu uuuu
14h, Bank 3
CA2L
Capture2 Low Byte
xxxx xxxx
uuuu uuuu
15h, Bank 3
CA2H
Capture2 High Byte
xxxx xxxx
uuuu uuuu
12h, Bank 7
CA3L
Capture3 Low Byte
xxxx xxxx
uuuu uuuu
13h, Bank 7
CA3H
Capture3 High Byte
xxxx xxxx
uuuu uuuu
14h, Bank 7
CA4L
Capture4 Low Byte
xxxx xxxx
uuuu uuuu
15h, Bank 7
CA4H
Capture4 High Byte
xxxx xxxx
uuuu uuuu
Legend:
Timer3 Period Register, Low Byte/Capture1 Register, Low Byte
x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends on condition.
Shaded cells are not used by Capture.
1998-2013 Microchip Technology Inc.
DS30289C-page 113
PIC17C7XX
13.2.4
EXTERNAL CLOCK INPUT FOR
TIMER3
13.2.5
Since Timer3 is a 16-bit timer and only 8-bits at a time
can be read or written, care should be taken when
reading or writing while the timer is running. The best
method is to stop the timer, perform any read or write
operation and then restart Timer3 (using the TMR3ON
bit). However, if it is necessary to keep Timer3 freerunning, care must be taken. For writing to the 16-bit
TMR3, Example 13-2 may be used. For reading the 16bit TMR3, Example 13-3 may be used. Interrupts must
be disabled during this routine.
When TMR3CS is set, the 16-bit TMR3 increments on
the falling edge of clock input TCLK3. The input on the
RB5/TCLK3 pin is sampled and synchronized by the
internal phase clocks, twice every instruction cycle.
This causes a delay from the time a falling edge
appears on TCLK3 to the time TMR3 is actually incremented. For the external clock input timing requirements, see the Electrical Specification section.
Figure 13-7 shows the timing diagram when operating
from an external clock.
EXAMPLE 13-2:
BSF
MOVFP
MOVFP
BCF
MOVPF
MOVPF
MOVFP
CPFSLT
RETURN
MOVPF
MOVPF
RETURN
WRITING TO TMR3
CPUSTA,
RAM_L,
RAM_H,
CPUSTA,
EXAMPLE 13-3:
GLINTD
TMR3L
TMR3H
GLINTD
; Disable interrupts
;
;
; Done, enable interrupts
READING FROM TMR3
TMR3L, TMPLO
TMR3H, TMPHI
TMPLO, WREG
TMR3L
TMR3L, TMPLO
TMR3H, TMPHI
FIGURE 13-7:
READING/WRITING TIMER3
;
;
;
;
;
;
;
;
read low TMR3
read high TMR3
tmplo wreg
TMR3L < wreg?
no then return
read low TMR3
read high TMR3
return
TIMER1, TIMER2 AND TIMER3 OPERATION (IN COUNTER MODE)
Q1Q2Q3Q4 Q1Q2Q3Q4 Q1Q2Q3Q4 Q1Q2Q3Q4 Q1Q2Q3Q4Q1Q2Q3Q4
TCLK12
or TCLK3
TMR1, TMR2, or TMR3
PR1, PR2, or PR3H:PR3L
34h
35h
A8h
A9h
'A9h'
00h
'A9h'
WR_TMR
RD_TMR
TMRxIF
Instruction
Executed
MOVWF
TMRx
MOVFP
TMRx,W
MOVFP
TMRx,W
Write to TMRx
Read TMRx
Read TMRx
Note 1: TCLK12 is sampled in Q2 and Q4.
2: indicates a sampling point.
3: The latency from TCLK12 to timer increment is between 2Tosc and 6Tosc.
DS30289C-page 114
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 13-8:
TIMER1, TIMER2 AND TIMER3 OPERATION (IN TIMER MODE)
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4
AD15:AD0
ALE
Instruction
Fetched
TMR1
MOVF
MOVWF
MOVF
TMR1, W
TMR1
TMR1, W
Write TMR1 Read TMR1 Read TMR1
04h
05h
03h
MOVLB 3
04h
BSF
TCON2, 0
Stop TMR1
05h
NOP
06h
BCF
TCON2, 0
Start TMR1
NOP
07h
NOP
NOP
08h
NOP
00h
PR1
TMR1ON
WR_TMR1
WR_TCON2
TMR1IF
RD_TMR1
TMR1
Reads 03h
1998-2013 Microchip Technology Inc.
TMR1
Reads 04h
DS30289C-page 115
PIC17C7XX
NOTES:
DS30289C-page 116
1998-2013 Microchip Technology Inc.
PIC17C7XX
14.0
UNIVERSAL SYNCHRONOUS
ASYNCHRONOUS RECEIVER
TRANSMITTER (USART)
MODULES
TABLE 14-1:
Generic Name
RCSTA
TXSTA
SPBRG
RCREG
TXREG
Each USART module is a serial I/O module. There are
two USART modules that are available on the
PIC17C7XX. They are specified as USART1 and
USART2. The description of the operation of these modules is generic in regard to the register names and pin
names used. Table 14-1 shows the generic names that
are used in the description of operation and the actual
names for both USART1 and USART2. Since the control
bits in each register have the same function, their names
are the same (there is no need to differentiate).
RCIE
RCIF
TXIE
TXIF
The Transmit Status and Control Register (TXSTA) is
shown in Figure 14-1, while the Receive Status and
Control Register (RCSTA) is shown in Figure 14-2.
REGISTER 14-1:
USART MODULE GENERIC
NAMES
RX/DT
TX/CK
USART1 Name USART2 Name
Registers
RCSTA1
RCSTA2
TXSTA1
TXSTA2
SPBRG1
SPBRG2
RCREG1
RCREG2
TXREG1
TXREG2
Interrupt Control Bits
RC1IE
RC2IE
RC1IF
RC2IF
TX1IE
TX2IE
TX1IF
TX2IF
Pins
RA4/RX1/DT1
RG6/RX2/DT2
RA5/TX1/CK1
RG7/TX2/CK2
TXSTA1 REGISTER (ADDRESS: 15h, BANK 0)
TXSTA2 REGISTER (ADDRESS: 15h, BANK 4)
R/W-0
CSRC
R/W-0
TX9
R/W-0
TXEN
R/W-0
SYNC
U-0
—
U-0
—
R-1
TRMT
bit 7
bit 7
R/W-x
TX9D
bit 0
CSRC: Clock Source Select bit
Synchronous mode:
1 = Master mode (clock generated internally from BRG)
0 = Slave mode (clock from external source)
Asynchronous mode:
Don’t care
bit 6
TX9: 9-bit Transmit Select bit
1 = Selects 9-bit transmission
0 = Selects 8-bit transmission
bit 5
TXEN: Transmit Enable bit
1 = Transmit enabled
0 = Transmit disabled
SREN/CREN overrides TXEN in SYNC mode
bit 4
SYNC: USART Mode Select bit
(Synchronous/Asynchronous)
1 = Synchronous mode
0 = Asynchronous mode
bit 3-2
Unimplemented: Read as '0'
bit 1
TRMT: Transmit Shift Register (TSR) Empty bit
1 = TSR empty
0 = TSR full
bit 0
TX9D: 9th bit of Transmit Data (can be used to calculate the parity in software)
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 117
PIC17C7XX
The USART can be configured as a full duplex asynchronous system that can communicate with peripheral
devices such as CRT terminals and personal computers, or it can be configured as a half duplex synchronous system that can communicate with peripheral
devices such as A/D or D/A integrated circuits, Serial
EEPROMs etc. The USART can be configured in the
following modes:
The SPEN (RCSTA) bit has to be set in order to
configure the I/O pins as the Serial Communication
Interface (USART).
The USART module will control the direction of the RX/
DT and TX/CK pins, depending on the states of the
USART configuration bits in the RCSTA and TXSTA
registers. The bits that control I/O direction are:
•
•
•
•
•
• Asynchronous (full duplex)
• Synchronous - Master (half duplex)
• Synchronous - Slave (half duplex)
SPEN
TXEN
SREN
CREN
CSRC
REGISTER 14-2: RCSTA1 REGISTER (ADDRESS: 13h, BANK 0)
RCSTA2 REGISTER (ADDRESS: 13h, BANK 4)
R/W-0
SPEN
R/W-0
RX9
R/W-0
SREN
R/W-0
CREN
U-0
—
R-0
FERR
R-0
OERR
bit 7
R-x
RX9D
bit 0
bit 7
SPEN: Serial Port Enable bit
1 = Configures TX/CK and RX/DT pins as serial port pins
0 = Serial port disabled
bit 6
RX9: 9-bit Receive Select bit
1 = Selects 9-bit reception
0 = Selects 8-bit reception
bit 5
SREN: Single Receive Enable bit
This bit enables the reception of a single byte. After receiving the byte, this bit is automatically
cleared.
Synchronous mode:
1 = Enable reception
0 = Disable reception
Note:
This bit is ignored in synchronous slave reception.
Asynchronous mode:
Don’t care
bit 4
CREN: Continuous Receive Enable bit
This bit enables the continuous reception of serial data.
Asynchronous mode:
1 = Enable continuous reception
0 = Disables continuous reception
Synchronous mode:
1 = Enables continuous reception until CREN is cleared (CREN overrides SREN)
0 = Disables continuous reception
bit 3
Unimplemented: Read as '0'
bit 2
FERR: Framing Error bit
1 = Framing error (updated by reading RCREG)
0 = No framing error
bit 1
bit OERR: Overrun Error bit
1 = Overrun (cleared by clearing CREN)
0 = No overrun error
bit 0
RX9D: 9th bit of Receive Data (can be the software calculated parity bit)
Legend:
DS30289C-page 118
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 14-1:
USART TRANSMIT
Sync
Master/Slave
4
BRG
Sync/Async
Sync/Async
TSR
Sync/Async
CK/TX
16
Start 0 1 7 8 Stop
Clock
Load
TXEN/
Write to TXREG
DT
TXREG
0 1 7
8
Bit Count
Interrupt
TXSTA
Data Bus
FIGURE 14-2:
OSC
USART RECEIVE
BRG
Interrupt
4
Master/Slave
Sync
CK
TXIE
Buffer
Logic
Sync/Async
Async/Sync
Enable
Bit Count
16
START
Detect
SPEN
RX
Buffer
Logic
RCIE
Majority
Detect
RSR
Clock
Data
SREN/
CREN/
Start_Bit
MSb
LSb
Stop 8 7 1 0
FIFO
Logic
RX9
Async/Sync
RCREG
FERR
FERR
RX9D
RX9D
Clk
FIFO
7 1 0
7 1 0
Data Bus
1998-2013 Microchip Technology Inc.
DS30289C-page 119
PIC17C7XX
14.1
EXAMPLE 14-1:
USART Baud Rate Generator
(BRG)
Desired Baud Rate = FOSC / (64 (X + 1))
The BRG supports both the Asynchronous and Synchronous modes of the USART. It is a dedicated 8-bit
baud rate generator. The SPBRG register controls the
period of a free running 8-bit timer. Table 14-2 shows
the formula for computation of the baud rate for different USART modes. These only apply when the USART
is in Synchronous Master mode (internal clock) and
Asynchronous mode.
9600 = 16000000 /(64 (X + 1))
X
SYNC
= 9615
Error = (Calculated Baud Rate - Desired Baud Rate)
Desired Baud Rate
= (9615 - 9600) / 9600
= 0.16%
Writing a new value to the SPBRG, causes the BRG
timer to be reset (or cleared). This ensures that the
BRG does not wait for a timer overflow before outputting the new baud rate.
BAUD RATE FORMULA
Mode
= 25.042 25
Calculated Baud Rate = 16000000 / (64 (25 + 1))
Given the desired baud rate and Fosc, the nearest integer value between 0 and 255 can be calculated using
the formula below. The error in baud rate can then be
determined.
TABLE 14-2:
CALCULATING BAUD
RATE ERROR
Baud Rate
Effects of Reset
0
Asynchronous
FOSC/(64(X+1))
FOSC/(4(X+1))
1
Synchronous
X = value in SPBRG (0 to 255)
After any device RESET, the SPBRG register is
cleared. The SPBRG register will need to be loaded
with the desired value after each RESET.
Example 14-1 shows the calculation of the baud rate
error for the following conditions:
FOSC = 16 MHz
Desired Baud Rate = 9600
SYNC = 0
TABLE 14-3:
REGISTERS ASSOCIATED WITH BAUD RATE GENERATOR
USART2
USART1
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
0000 -00x
0000 -00u
13h, Bank 0
RCSTA1
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
17h, Bank 0
SPBRG1
Baud Rate Generator Register
13h, Bank 4
RCSTA2
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
15h, Bank 4
TXSTA2
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
17h, Bank 4
SPBRG2
Legend:
Baud Rate Generator Register
0000 --1x
0000 --1u
0000 0000
0000 0000
0000 -00x
0000 -00u
0000 --1x
0000 --1u
0000 0000
0000 0000
x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Baud Rate Generator.
DS30289C-page 120
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 14-4:
BAUD
RATE
(K)
BAUD RATES FOR SYNCHRONOUS MODE
FOSC = 33 MHz
KBAUD
FOSC = 25 MHz
FOSC = 20 MHz
FOSC = 16 MHz
SPBRG
SPBRG
SPBRG
SPBRG
VALUE
VALUE
VALUE
VALUE
%ERROR (DECIMAL) KBAUD %ERROR (DECIMAL) KBAUD %ERROR (DECIMAL) KBAUD %ERROR (DECIMAL)
0.3
NA
—
—
NA
—
—
NA
—
—
NA
—
—
1.2
NA
—
—
NA
—
—
NA
—
—
NA
—
—
2.4
NA
—
—
NA
—
—
NA
—
—
NA
—
—
9.6
NA
—
—
NA
—
—
NA
—
—
NA
—
—
19.2
NA
—
—
NA
—
—
19.53
+1.73
255
19.23
+0.16
207
76.8
77.10
+0.39
106
77.16
+0.47
80
76.92
+0.16
64
76.92
+0.16
51
96
95.93
-0.07
85
96.15
+0.16
64
96.15
+0.16
51
95.24
-0.79
41
300
294.64
-1.79
27
297.62
-0.79
20
294.1
-1.96
16
307.69
+2.56
12
7
500
485.29
-2.94
16
480.77
-3.85
12
500
0
9
500
0
HIGH
8250
—
0
6250
—
0
5000
—
0
4000
—
0
LOW
32.22
—
255
24.41
—
255
19.53
—
255
15.625
—
255
BAUD
RATE
(K)
FOSC = 10 MHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
0.3
NA
—
1.2
NA
—
2.4
NA
9.6
FOSC = 7.159 MHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
—
NA
—
—
NA
—
—
—
NA
9.766
+1.73
255
19.2
19.23
+0.16
76.8
75.76
-1.36
96
96.15
300
500
FOSC = 5.068 MHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
—
NA
—
—
—
NA
—
—
—
—
NA
—
—
9.622
+0.23
185
9.6
0
131
129
19.24
+0.23
92
19.2
0
65
32
77.82
+1.32
22
79.2
+3.13
15
+0.16
25
94.20
-1.88
18
97.48
+1.54
12
312.5
+4.17
7
298.3
-0.57
5
316.8
+5.60
3
500
0
4
NA
—
—
NA
—
—
HIGH
2500
—
0
1789.8
—
0
1267
—
0
LOW
9.766
—
255
6.991
—
255
4.950
—
255
FOSC = 3.579 MHz
FOSC = 1 MHz
FOSC = 32.768 kHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
0.3
NA
—
—
NA
—
—
0.303
+1.14
26
1.2
NA
—
—
1.202
+0.16
207
1.170
-2.48
6
2.4
NA
—
—
2.404
+0.16
103
NA
—
—
BAUD
RATE
(K)
9.6
9.622
+0.23
92
9.615
+0.16
25
NA
—
—
19.2
19.04
-0.83
46
19.24
+0.16
12
NA
—
—
76.8
74.57
-2.90
11
83.34
+8.51
2
NA
—
—
96
99.43
_3.57
8
NA
—
—
NA
—
—
300
298.3
-0.57
2
NA
—
—
NA
—
—
500
NA
—
—
NA
—
—
NA
—
—
HIGH
894.9
—
0
250
—
0
8.192
—
0
LOW
3.496
—
255
0.976
—
255
0.032
—
255
1998-2013 Microchip Technology Inc.
DS30289C-page 121
PIC17C7XX
TABLE 14-5:
BAUD
RATE
(K)
BAUD RATES FOR ASYNCHRONOUS MODE
FOSC = 33 MHz
KBAUD
FOSC = 25 MHz
FOSC = 20 MHz
FOSC = 16 MHz
SPBRG
SPBRG
SPBRG
SPBRG
VALUE
VALUE
VALUE
VALUE
%ERROR (DECIMAL) KBAUD %ERROR (DECIMAL) KBAUD %ERROR (DECIMAL) KBAUD %ERROR (DECIMAL)
0.3
NA
—
—
NA
—
—
NA
—
—
NA
—
—
1.2
NA
—
—
NA
—
—
1.221
+1.73
255
1.202
+0.16
207
2.4
2.398
-0.07
214
2.396
0.14
162
2.404
+0.16
129
2.404
+0.16
103
9.6
9.548
-0.54
53
9.53
-0.76
40
9.469
-1.36
32
9.615
+0.16
25
19.2
19.09
-0.54
26
19.53
+1.73
19
19.53
+1.73
15
19.23
+0.16
12
76.8
73.66
-4.09
6
78.13
+1.73
4
78.13
+1.73
3
83.33
+8.51
2
96
103.12
+7.42
4
97.65
+1.73
3
104.2
+8.51
2
NA
—
—
300
257.81
-14.06
1
390.63
+30.21
0
312.5
+4.17
0
NA
—
—
500
515.62
+3.13
0
NA
—
—
NA
—
—
NA
—
—
HIGH
515.62
—
0
—
—
0
312.5
—
0
250
—
0
LOW
2.014
—
255
1.53
—
255
1.221
—
255
0.977
—
255
BAUD
RATE
(K)
FOSC = 10 MHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
FOSC = 7.159 MHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
FOSC = 5.068 MHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
0.3
NA
—
—
NA
—
—
0.31
+3.13
255
1.2
1.202
+0.16
129
1.203
_0.23
92
1.2
0
65
2.4
2.404
+0.16
64
2.380
-0.83
46
2.4
0
32
9.6
9.766
+1.73
15
9.322
-2.90
11
9.9
-3.13
7
19.2
19.53
+1.73
7
18.64
-2.90
5
19.8
+3.13
3
76.8
78.13
+1.73
1
NA
—
—
79.2
+3.13
0
96
NA
—
—
NA
—
—
NA
—
—
300
NA
—
—
NA
—
—
NA
—
—
—
500
NA
—
—
NA
—
—
NA
—
HIGH
156.3
—
0
111.9
—
0
79.2
—
0
LOW
0.610
—
255
0.437
—
255
0.309
—
255
SPBRG
VALUE
(DECIMAL)
FOSC = 3.579 MHz
FOSC = 1 MHz
FOSC = 32.768 kHz
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
KBAUD
%ERROR
SPBRG
VALUE
(DECIMAL)
KBAUD
%ERROR
0.3
0.301
+0.23
185
0.300
+0.16
51
0.256
-14.67
1
1.2
1.190
-0.83
46
1.202
+0.16
12
NA
—
—
2.4
2.432
+1.32
22
2.232
-6.99
6
NA
—
—
9.6
9.322
-2.90
5
NA
—
—
NA
—
—
19.2
18.64
-2.90
2
NA
—
—
NA
—
—
BAUD
RATE
(K)
76.8
NA
—
—
NA
—
—
NA
—
—
96
NA
—
—
NA
—
—
NA
—
—
300
NA
—
—
NA
—
—
NA
—
—
500
NA
—
—
NA
—
—
NA
—
—
HIGH
55.93
—
0
15.63
—
0
0.512
—
0
LOW
0.218
—
255
0.061
—
255
0.002
—
255
DS30289C-page 122
1998-2013 Microchip Technology Inc.
PIC17C7XX
14.2
USART Asynchronous Mode
In this mode, the USART uses standard nonreturn-tozero (NRZ) format (one START bit, eight or nine data
bits, and one STOP bit). The most common data format
is 8-bits. An on-chip dedicated 8-bit baud rate generator can be used to derive standard baud rate frequencies from the oscillator. The USART’s transmitter and
receiver are functionally independent but use the same
data format and baud rate. The baud rate generator
produces a clock x64 of the bit shift rate. Parity is not
supported by the hardware, but can be implemented in
software (and stored as the ninth data bit). Asynchronous mode is stopped during SLEEP.
The Asynchronous mode is selected by clearing the
SYNC bit (TXSTA).
The USART Asynchronous module consists of the following components:
•
•
•
•
Baud Rate Generator
Sampling Circuit
Asynchronous Transmitter
Asynchronous Receiver
14.2.1
Note:
The TSR is not mapped in data memory,
so it is not available to the user.
Transmission
is
enabled
by
setting
the
TXEN (TXSTA) bit. The actual transmission will not
occur until TXREG has been loaded with data and the
baud rate generator (BRG) has produced a shift clock
(Figure 14-3). The transmission can also be started by
first loading TXREG and then setting TXEN. Normally,
when transmission is first started, the TSR is empty, so
a transfer to TXREG will result in an immediate transfer
to TSR, resulting in an empty TXREG. A back-to-back
transfer is thus possible (Figure 14-4). Clearing TXEN
during a transmission will cause the transmission to be
aborted. This will reset the transmitter and the TX/CK
pin will revert to hi-impedance.
In order to select 9-bit transmission, the
TX9 (TXSTA) bit should be set and the ninth bit
value should be written to TX9D (TXSTA). The
ninth bit value must be written before writing the 8-bit
data to the TXREG. This is because a data write to
TXREG can result in an immediate transfer of the data
to the TSR (if the TSR is empty).
USART ASYNCHRONOUS
TRANSMITTER
The USART transmitter block diagram is shown in
Figure 14-1. The heart of the transmitter is the transmit
shift register (TSR). The shift register obtains its data
from the read/write transmit buffer (TXREG). TXREG is
loaded with data in software. The TSR is not loaded until
the STOP bit has been transmitted from the previous
load. As soon as the STOP bit is transmitted, the TSR is
loaded with new data from the TXREG (if available).
Once TXREG transfers the data to the TSR (occurs in
one TCY at the end of the current BRG cycle), the TXREG
is empty and an interrupt bit, TXIF, is set. This interrupt
can be enabled/disabled by setting/clearing the TXIE bit.
TXIF will be set, regardless of TXIE and cannot be reset
in software. It will reset only when new data is loaded into
TXREG. While TXIF indicates the status of the TXREG,
the TRMT (TXSTA) bit shows the status of the TSR.
FIGURE 14-3:
TRMT is a read only bit which is set when the TSR is
empty. No interrupt logic is tied to this bit, so the user has
to poll this bit in order to determine if the TSR is empty.
Steps to follow when setting up an Asynchronous
Transmission:
1.
2.
3.
4.
5.
6.
7.
Initialize the SPBRG register for the appropriate
baud rate.
Enable the asynchronous serial port by clearing
the SYNC bit and setting the SPEN bit.
If interrupts are desired, then set the TXIE bit.
If 9-bit transmission is desired, then set the TX9
bit.
If 9-bit transmission is selected, the ninth bit
should be loaded in TX9D.
Load data to the TXREG register.
Enable the transmission by setting TXEN (starts
transmission).
ASYNCHRONOUS MASTER TRANSMISSION
Write to TXREG
BRG Output
(Shift Clock)
TX
(TX/CK pin)
Word 1
START Bit
Bit 0
Bit 1
Bit 7/8
STOP Bit
Word 1
TXIF bit
TRMT bit
Word 1
Transmit Shift Reg
1998-2013 Microchip Technology Inc.
DS30289C-page 123
PIC17C7XX
FIGURE 14-4:
ASYNCHRONOUS MASTER TRANSMISSION (BACK TO BACK)
Write to TXREG
Word 1
BRG output
(shift clock)
TX
(TX/CK pin)
Word 2
START Bit
Bit 0
Bit 1
Word 1
TXIF bit
Bit 7/8
Bit 0
Word 2
Word 1
Transmit Shift Reg.
TRMT bit
START Bit
STOP Bit
Word 2
Transmit Shift Reg.
Note: This timing diagram shows two consecutive transmissions.
TABLE 14-6:
Address
REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
u000 0010
16h, Bank 1
PIR1
RBIF
TMR3IF TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE TMR2IE TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
13h, Bank 0
RCSTA1
SPEN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
16h, Bank 0
TXREG1
xxxx xxxx
uuuu uuuu
15h, Bank 0
TXSTA1
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 0
SPBRG1
10h, Bank 4
PIR2
SSPIF
BCLIF
11h, Bank 4
PIE2
SSPIE
BCLIE
13h, Bank 4
RCSTA2
SPEN
RX9
16h, Bank 4
TXREG2
15h, Bank 4
TXSTA2
17h, Bank 4
SPBRG2
Legend:
RX9
SREN
CREN
Serial Port Transmit Register (USART1)
CSRC
TX9
TXEN
SYNC
Baud Rate Generator Register (USART1)
ADIF
—
CA4IF
CA3IF
ADIE
—
CA4IE
SREN
CREN
—
TX9
—
TXEN
SYNC
Baud Rate Generator Register (USART2)
0000 0000
000- 0010
000- 0010
TX2IF
RC2IF
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
FERR
OERR
RX9D
0000 -00x
0000 -00u
xxxx xxxx
uuuu uuuu
—
TRMT
TX9D
0000 --1x
0000 --1u
0000 0000
0000 0000
Serial Port Transmit Register (USART2)
CSRC
0000 0000
x = unknown, u = unchanged, - = unimplemented, read as a '0'. Shaded cells are not used for asynchronous transmission.
DS30289C-page 124
1998-2013 Microchip Technology Inc.
PIC17C7XX
14.2.2
USART ASYNCHRONOUS
RECEIVER
ting the receive logic (CREN is set). If the OERR bit is
set, transfers from the RSR to RCREG are inhibited, so
it is essential to clear the OERR bit if it is set. The framing error bit FERR (RCSTA) is set if a STOP bit is
not detected.
The receiver block diagram is shown in Figure 14-2.
The data comes in the RX/DT pin and drives the data
recovery block. The data recovery block is actually a
high speed shifter operating at 16 times the baud rate,
whereas the main receive serial shifter operates at the
bit rate or at FOSC.
Note:
Once Asynchronous mode is selected, reception is
enabled by setting bit CREN (RCSTA).
The heart of the receiver is the receive (serial) shift register (RSR). After sampling the STOP bit, the received
data in the RSR is transferred to the RCREG (if it is
empty). If the transfer is complete, the interrupt bit,
RCIF, is set. The actual interrupt can be enabled/
disabled by setting/clearing the RCIE bit. RCIF is a
read only bit which is cleared by the hardware. It is
cleared when RCREG has been read and is empty.
RCREG is a double buffered register (i.e., it is a twodeep FIFO). It is possible for two bytes of data to be
received and transferred to the RCREG FIFO and a
third byte begin shifting to the RSR. On detection of the
STOP bit of the third byte, if the RCREG is still full, then
the overrun error bit, OERR (RCSTA) will be set.
The word in the RSR will be lost. RCREG can be read
twice to retrieve the two bytes in the FIFO. The OERR
bit has to be cleared in software which is done by reset-
FIGURE 14-5:
14.2.3
The FERR and the 9th receive bit are buffered the same way as the receive data.
Reading the RCREG register will allow the
RX9D and FERR bits to be loaded with values for the next received data. Therefore,
it is essential for the user to read the
RCSTA register before reading RCREG, in
order not to lose the old FERR and RX9D
information.
SAMPLING
The data on the RX/DT pin is sampled three times by a
majority detect circuit to determine if a high or a low
level is present at the RX/DT pin. The sampling is done
on the seventh, eighth and ninth falling edges of a x16
clock (Figure 14-5).
The x16 clock is a free running clock and the three
sample points occur at a frequency of every 16 falling
edges.
RX PIN SAMPLING SCHEME
START bit
RX
(RX/DT pin)
Bit0
Baud CLK for all but START bit
Baud CLK
x16 CLK
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
1
2
3
Samples
FIGURE 14-6:
START BIT DETECT
START bit
RX
(RX/DT pin)
x16 CLK
First rising edge of x16 clock after RX pin goes low
Q2, Q4 CLK
RX sampled low
1998-2013 Microchip Technology Inc.
DS30289C-page 125
PIC17C7XX
7.
Steps to follow when setting up an Asynchronous
Reception:
1.
2.
3.
4.
5.
6.
Initialize the SPBRG register for the appropriate
baud rate.
Enable the asynchronous serial port by clearing
the SYNC bit and setting the SPEN bit.
If interrupts are desired, then set the RCIE bit.
If 9-bit reception is desired, then set the RX9 bit.
Enable the reception by setting the CREN bit.
The RCIF bit will be set when reception completes and an interrupt will be generated if the
RCIE bit was set.
FIGURE 14-7:
Read RCSTA to get the ninth bit (if enabled) and
FERR bit to determine if any error occurred during reception.
Read RCREG for the 8-bit received data.
If an overrun error occurred, clear the error by
clearing the OERR bit.
8.
9.
Note:
To terminate a reception, either clear the
SREN and CREN bits, or the SPEN bit.
This will reset the receive logic, so that it
will be in the proper state when receive is
re-enabled.
ASYNCHRONOUS RECEPTION
START
bit
bit0
RX
(RX/DT pin)
bit1
START
bit
bit0
bit7/8 STOP
bit
bit7/8 STOP
bit
START
bit
bit7/8
Rcv Shift
Reg
Rcv Buffer Reg
Word 3
Word 2
RCREG
Word 1
RCREG
Read Rcv
Buffer Reg
RCREG
STOP
bit
RCIF
(Interrupt Flag)
OERR bit
CREN
Note: This timing diagram shows three words appearing on the RX input. The RCREG (receive buffer) is read after the third word,
causing the OERR (overrun) bit to be set.
TABLE 14-7:
Address
REGISTERS ASSOCIATED WITH ASYNCHRONOUS RECEPTION
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
u000 0010
16h, Bank 1
PIR1
RBIF
TMR3IF TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE TMR2IE TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
13h, Bank 0
RCSTA1
SPEN
RX9
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
SREN
14h, Bank 0
RCREG1
RX7
RX6
RX5
RX4
RX3
RX2
RX1
RX0
xxxx xxxx
uuuu uuuu
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 0
SPBRG1
10h, Bank 4
PIR2
SSPIF
BCLIF
11h, Bank 4
PIE2
SSPIE
BCLIE
13h, Bank 4
RCSTA2
SPEN
RX9
Baud Rate Generator Register
ADIF
—
CA4IF
CA3IF
ADIE
—
CA4IE
SREN
CREN
—
0000 0000
0000 0000
000- 0010
000- 0010
TX2IF
RC2IF
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
FERR
OERR
RX9D
0000 -00x
0000 -00u
14h, Bank 4
RCREG2
RX7
RX6
RX5
RX4
RX3
RX2
RX1
RX0
xxxx xxxx
uuuu uuuu
15h, Bank 4
TXSTA2
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 4
SPBRG2
0000 0000
0000 0000
Legend:
Baud Rate Generator Register
x = unknown, u = unchanged, - = unimplemented, read as a '0'. Shaded cells are not used for asynchronous reception.
DS30289C-page 126
1998-2013 Microchip Technology Inc.
PIC17C7XX
14.3
USART Synchronous Master
Mode
In Master Synchronous mode, the data is transmitted in
a half-duplex manner; i.e., transmission and reception
do not occur at the same time: when transmitting data,
the reception is inhibited and vice versa. The synchronous mode is entered by setting the SYNC
(TXSTA) bit. In addition, the SPEN (RCSTA) bit
is set in order to configure the I/O pins to CK (clock) and
DT (data) lines, respectively. The Master mode indicates that the processor transmits the master clock on
the CK line. The Master mode is entered by setting the
CSRC (TXSTA) bit.
14.3.1
USART SYNCHRONOUS MASTER
TRANSMISSION
The USART transmitter block diagram is shown in
Figure 14-1. The heart of the transmitter is the transmit
(serial) shift register (TSR). The shift register obtains its
data from the read/write transmit buffer TXREG.
TXREG is loaded with data in software. The TSR is not
loaded until the last bit has been transmitted from the
previous load. As soon as the last bit is transmitted, the
TSR is loaded with new data from TXREG (if available).
Once TXREG transfers the data to the TSR (occurs in
one TCY at the end of the current BRG cycle), TXREG
is empty and the TXIF bit is set. This interrupt can be
enabled/disabled by setting/clearing the TXIE bit. TXIF
will be set regardless of the state of bit TXIE and cannot
be cleared in software. It will reset only when new data
is loaded into TXREG. While TXIF indicates the status
of TXREG, TRMT (TXSTA) shows the status of the
TSR. TRMT is a read only bit which is set when the
TSR is empty. No interrupt logic is tied to this bit, so the
user has to poll this bit in order to determine if the TSR
is empty. The TSR is not mapped in data memory, so it
is not available to the user.
Transmission is enabled by setting the TXEN
(TXSTA) bit. The actual transmission will not occur
until TXREG has been loaded with data. The first data
bit will be shifted out on the next available rising edge
of the clock on the TX/CK pin. Data out is stable around
the falling edge of the synchronous clock (Figure 14-9).
The transmission can also be started by first loading
TXREG and then setting TXEN. This is advantageous
when slow baud rates are selected, since BRG is kept
in RESET when the TXEN, CREN, and SREN bits are
clear. Setting the TXEN bit will start the BRG, creating
a shift clock immediately. Normally when transmission
is first started, the TSR is empty, so a transfer to
TXREG will result in an immediate transfer to the TSR,
resulting in an empty TXREG. Back-to-back transfers
are possible.
1998-2013 Microchip Technology Inc.
Clearing TXEN during a transmission will cause the
transmission to be aborted and will reset the transmitter. The RX/DT and TX/CK pins will revert to hi-impedance. If either CREN or SREN are set during a
transmission, the transmission is aborted and the RX/
DT pin reverts to a hi-impedance state (for a reception).
The TX/CK pin will remain an output if the CSRC bit is
set (internal clock). The transmitter logic is not reset,
although it is disconnected from the pins. In order to
reset the transmitter, the user has to clear the TXEN bit.
If the SREN bit is set (to interrupt an ongoing transmission and receive a single word), then after the single
word is received, SREN will be cleared and the serial
port will revert back to transmitting, since the TXEN bit
is still set. The DT line will immediately switch from hiimpedance Receive mode to transmit and start driving.
To avoid this, TXEN should be cleared.
In order to select 9-bit transmission, the
TX9 (TXSTA) bit should be set and the ninth bit
should be written to TX9D (TXSTA). The ninth bit
must be written before writing the 8-bit data to TXREG.
This is because a data write to TXREG can result in an
immediate transfer of the data to the TSR (if the TSR is
empty). If the TSR was empty and TXREG was written
before writing the “new” TX9D, the “present” value of
TX9D is loaded.
Steps to follow when setting up a Synchronous Master
Transmission:
1.
2.
3.
4.
5.
6.
7.
8.
Initialize the SPBRG register for the appropriate
baud rate (see Baud Rate Generator Section for
details).
Enable the synchronous master serial port by
setting the SYNC, SPEN, and CSRC bits.
Ensure that the CREN and SREN bits are clear
(these bits override transmission when set).
If interrupts are desired, then set the TXIE bit
(the GLINTD bit must be clear and the PEIE bit
must be set).
If 9-bit transmission is desired, then set the TX9 bit.
If 9-bit transmission is selected, the ninth bit
should be loaded in TX9D.
Start transmission by loading data to the TXREG
register.
Enable the transmission by setting TXEN.
Writing the transmit data to the TXREG, then enabling
the transmit (setting TXEN), allows transmission to start
sooner than doing these two events in the reverse order.
Note:
To terminate a transmission, either clear
the SPEN bit, or the TXEN bit. This will
reset the transmit logic, so that it will be in
the proper state when transmit is reenabled.
DS30289C-page 127
PIC17C7XX
TABLE 14-8:
Address
REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER TRANSMISSION
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
16h, Bank 1
PIR1
RBIF
TMR3IF TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
u000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE TMR2IE TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
13h, Bank 0
RCSTA1
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
16h, Bank 0
TXREG1
TX7
TX6
TX5
TX4
TX3
TX2
TX1
TX0
xxxx xxxx
uuuu uuuu
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 0
SPBRG1
0000 0000
0000 0000
10h, Bank 4
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0010
000- 0010
11h, Bank 4
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
13h, Bank 4
RCSTA2
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
16h, Bank 4
TXREG2
TX7
TX6
TX5
TX4
TX3
TX2
TX1
TX0
xxxx xxxx
uuuu uuuu
15h, Bank 4
TXSTA2
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 4
SPBRG2
0000 0000
0000 0000
Legend:
Baud Rate Generator Register
Baud Rate Generator Register
x = unknown, u = unchanged, - = unimplemented, read as a '0'. Shaded cells are not used for synchronous master transmission.
FIGURE 14-8:
SYNCHRONOUS TRANSMISSION
Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4
bit0
DT
(RX/DT pin)
bit1
bit2
Q3 Q4 Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4Q1 Q2Q3 Q4
bit7
Word 1
bit0
Word 2
CK
(TX/CK pin)
Write to
TXREG
Write Word 1
Write Word 2
TXIF
Interrupt Flag
TRMT
TXEN
'1'
FIGURE 14-9:
DT
(RX/DT pin)
SYNCHRONOUS TRANSMISSION (THROUGH TXEN)
bit0
bit1
bit2
bit6
bit7
CK
(TX/CK pin)
Write to
TXREG
TXIF bit
TRMT bit
DS30289C-page 128
1998-2013 Microchip Technology Inc.
PIC17C7XX
14.3.2
USART SYNCHRONOUS MASTER
RECEPTION
Steps to follow when setting up a Synchronous Master
Reception:
1.
Once Synchronous mode is selected, reception is
enabled by setting either the SREN (RCSTA) bit or
the CREN (RCSTA) bit. Data is sampled on the RX/
DT pin on the falling edge of the clock. If SREN is set,
then only a single word is received. If CREN is set, the
reception is continuous until CREN is reset. If both bits
are set, then CREN takes precedence. After clocking
the last bit, the received data in the Receive Shift
Register (RSR) is transferred to RCREG (if it is empty).
If the transfer is complete, the interrupt bit RCIF is set.
The actual interrupt can be enabled/disabled by setting/clearing the RCIE bit. RCIF is a read only bit which
is reset by the hardware. In this case, it is reset when
RCREG has been read and is empty. RCREG is a double buffered register; i.e., it is a two deep FIFO. It is
possible for two bytes of data to be received and transferred to the RCREG FIFO and a third byte to begin
shifting into the RSR. On the clocking of the last bit of
the third byte, if RCREG is still full, then the overrun
error bit OERR (RCSTA) is set. The word in the
RSR will be lost. RCREG can be read twice to retrieve
the two bytes in the FIFO. The OERR bit has to be
cleared in software. This is done by clearing the CREN
bit. If OERR is set, transfers from RSR to RCREG are
inhibited, so it is essential to clear the OERR bit if it is
set. The 9th receive bit is buffered the same way as the
receive data. Reading the RCREG register will allow
the RX9D and FERR bits to be loaded with values for
the next received data; therefore, it is essential for the
user to read the RCSTA register before reading
RCREG in order not to lose the old FERR and RX9D
information.
FIGURE 14-10:
2.
3.
4.
5.
6.
7.
8.
9.
Initialize the SPBRG register for the appropriate
baud rate. See Section 14.1 for details.
Enable the synchronous master serial port by
setting bits SYNC, SPEN, and CSRC.
If interrupts are desired, then set the RCIE bit.
If 9-bit reception is desired, then set the RX9 bit.
If a single reception is required, set bit SREN.
For continuous reception set bit CREN.
The RCIF bit will be set when reception is complete and an interrupt will be generated if the
RCIE bit was set.
Read RCSTA to get the ninth bit (if enabled) and
determine if any error occurred during reception.
Read the 8-bit received data by reading
RCREG.
If any error occurred, clear the error by clearing
CREN.
Note:
To terminate a reception, either clear the
SREN and CREN bits, or the SPEN bit.
This will reset the receive logic so that it will
be in the proper state when receive is reenabled.
SYNCHRONOUS RECEPTION (MASTER MODE, SREN)
Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
DT
(RX/DT pin)
bit0
bit1
bit2
bit3
bit4
bit5
bit6
bit7
CK
(TX/CK pin)
Write to the
SREN bit
SREN bit
CREN bit
'0'
'0'
RCIF bit
Read
RCREG
Note: Timing diagram demonstrates SYNC Master mode with SREN = 1.
1998-2013 Microchip Technology Inc.
DS30289C-page 129
PIC17C7XX
TABLE 14-9:
Address
REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER RECEPTION
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
u000 0010
16h, Bank 1
PIR1
RBIF
TMR3IF TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE TMR2IE TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
13h, Bank 0
RCSTA1
SPEN
RX9
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
SREN
14h, Bank 0
RCREG1
RX7
RX6
RX5
RX4
RX3
RX2
RX1
RX0
xxxx xxxx
uuuu uuuu
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 0
SPBRG1
10h, Bank 4
PIR2
SSPIF
BCLIF
11h, Bank 4
PIE2
SSPIE
BCLIE
13h, Bank 4
RCSTA2
SPEN
RX9
Baud Rate Generator Register
ADIF
—
CA4IF
CA3IF
ADIE
—
CA4IE
SREN
CREN
—
0000 0000
0000 0000
000- 0010
000- 0010
TX2IF
RC2IF
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
FERR
OERR
RX9D
0000 -00x
0000 -00u
14h, Bank 4
RCREG2
RX7
RX6
RX5
RX4
RX3
RX2
RX1
RX0
xxxx xxxx
uuuu uuuu
15h, Bank 4
TXSTA2
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 4
SPBRG2
0000 0000
0000 0000
Legend:
Baud Rate Generator Register
x = unknown, u = unchanged, - = unimplemented, read as a '0'. Shaded cells are not used for synchronous master reception.
DS30289C-page 130
1998-2013 Microchip Technology Inc.
PIC17C7XX
14.4
USART Synchronous Slave Mode
The Synchronous Slave mode differs from the Master
mode, in the fact that the shift clock is supplied externally at the TX/CK pin (instead of being supplied internally in the Master mode). This allows the device to
transfer or receive data in the SLEEP mode. The Slave
mode is entered by clearing the CSRC (TXSTA) bit.
14.4.1
USART SYNCHRONOUS SLAVE
TRANSMIT
The operation of the SYNC Master and Slave modes
are identical except in the case of the SLEEP mode.
If two words are written to TXREG and then the SLEEP
instruction executes, the following will occur. The first
word will immediately transfer to the TSR and will transmit as the shift clock is supplied. The second word will
remain in TXREG. TXIF will not be set. When the first
word has been shifted out of TSR, TXREG will transfer
the second word to the TSR and the TXIF flag will now
be set. If TXIE is enabled, the interrupt will wake the
chip from SLEEP and if the global interrupt is enabled,
then the program will branch to the interrupt vector
(0020h).
Steps to follow when setting up a Synchronous Slave
Transmission:
1.
2.
3.
4.
5.
6.
7.
Enable the synchronous slave serial port by setting the SYNC and SPEN bits and clearing the
CSRC bit.
Clear the CREN bit.
If interrupts are desired, then set the TXIE bit.
If 9-bit transmission is desired, then set the TX9
bit.
If 9-bit transmission is selected, the ninth bit
should be loaded in TX9D.
Start transmission by loading data to TXREG.
Enable the transmission by setting TXEN.
14.4.2
USART SYNCHRONOUS SLAVE
RECEPTION
Operation of the Synchronous Master and Slave
modes are identical except in the case of the SLEEP
mode. Also, SREN is a “don't care” in Slave mode.
If receive is enabled (CREN) prior to the SLEEP instruction, then a word may be received during SLEEP. On
completely receiving the word, the RSR will transfer the
data to RCREG (setting RCIF) and if the RCIE bit is set,
the interrupt generated will wake the chip from SLEEP.
If the global interrupt is enabled, the program will
branch to the interrupt vector (0020h).
Steps to follow when setting up a Synchronous Slave
Reception:
1.
2.
3.
4.
5.
6.
7.
8.
Enable the synchronous master serial port by
setting the SYNC and SPEN bits and clearing
the CSRC bit.
If interrupts are desired, then set the RCIE bit.
If 9-bit reception is desired, then set the RX9 bit.
To enable reception, set the CREN bit.
The RCIF bit will be set when reception is complete and an interrupt will be generated if the
RCIE bit was set.
Read RCSTA to get the ninth bit (if enabled) and
determine if any error occurred during reception.
Read the 8-bit received data by reading
RCREG.
If any error occurred, clear the error by clearing
the CREN bit.
Note:
To abort reception, either clear the SPEN
bit, or the CREN bit (when in Continuous
Receive mode). This will reset the receive
logic, so that it will be in the proper state
when receive is re-enabled.
Writing the transmit data to the TXREG, then enabling
the transmit (setting TXEN), allows transmission to
start sooner than doing these two events in the reverse
order.
Note:
To terminate a transmission, either clear
the SPEN bit, or the TXEN bit. This will
reset the transmit logic, so that it will be in
the proper state when transmit is reenabled.
1998-2013 Microchip Technology Inc.
DS30289C-page 131
PIC17C7XX
TABLE 14-10: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE TRANSMISSION
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
16h, Bank 1
PIR1
RBIF
TMR3IF TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
u000 0010
17h, Bank 1
PIE1
RBIE
TMR3IE TMR2IE TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
13h, Bank 0
RCSTA1
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
TX7
TX6
TX5
TX4
TX3
TX2
TX1
TX0
xxxx xxxx
uuuu uuuu
0000 0000
0000 0000
16h, Bank 0
TXREG1
17h, Bank 0
SPBRG1
10h, Bank 4
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0010
000- 0010
11h, Bank 4
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
13h, Bank 4
RCSTA2
SPEN
RX9
SREN
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
16h, Bank 4
TXREG2
TX7
TX6
TX5
TX4
TX3
TX2
TX1
TX0
xxxx xxxx
uuuu uuuu
15h, Bank 4
TXSTA2
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 4
SPBRG2
0000 0000
0000 0000
Legend:
Baud Rate Generator Register
Baud Rate Generator Register
x = unknown, u = unchanged, - = unimplemented, read as a '0'. Shaded cells are not used for synchronous slave transmission.
TABLE 14-11: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION
Address
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR,
BOR
MCLR, WDT
16h, Bank1
PIR1
RBIF
TMR3IF TMR2IF
TMR1IF
CA2IF
CA1IF
TX1IF
RC1IF
x000 0010
17h, Bank1
PIE1
RBIE
TMR3IE TMR2IE TMR1IE
CA2IE
CA1IE
TX1IE
RC1IE
0000 0000
0000 0000
13h, Bank0
RCSTA1
SPEN
RX9
CREN
—
FERR
OERR
RX9D
0000 -00x
0000 -00u
SREN
u000 0010
14h, Bank0
RCREG1
RX7
RX6
RX5
RX4
RX3
RX2
RX1
RX0
xxxx xxxx
uuuu uuuu
15h, Bank 0
TXSTA1
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 0
SPBRG1
10h, Bank 4
PIR2
SSPIF
BCLIF
11h, Bank 4
PIE2
SSPIE
BCLIE
13h, Bank 4
RCSTA2
SPEN
RX9
Baud Rate Generator Register
ADIF
—
CA4IF
CA3IF
ADIE
—
CA4IE
SREN
CREN
—
0000 0000
0000 0000
000- 0010
000- 0010
TX2IF
RC2IF
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
FERR
OERR
RX9D
0000 -00x
0000 -00u
14h, Bank 4
RCREG2
RX7
RX6
RX5
RX4
RX3
RX2
RX1
RX0
xxxx xxxx
uuuu uuuu
15h, Bank 4
TXSTA2
CSRC
TX9
TXEN
SYNC
—
—
TRMT
TX9D
0000 --1x
0000 --1u
17h, Bank 4
SPBRG2
0000 0000
0000 0000
Legend:
Baud Rate Generator Register
x = unknown, u = unchanged, - = unimplemented, read as a '0'. Shaded cells are not used for synchronous slave reception.
DS30289C-page 132
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.0
MASTER SYNCHRONOUS
SERIAL PORT (MSSP)
MODULE
The Master Synchronous Serial Port (MSSP) module is
a serial interface useful for communicating with other
peripheral or microcontroller devices. These peripheral
devices may be serial EEPROMs, shift registers, display drivers, A/D converters, etc. The MSSP module
can operate in one of two modes:
• Serial Peripheral Interface (SPI)
• Inter-Integrated CircuitTM (I 2C)
I2C SLAVE MODE BLOCK
DIAGRAM
FIGURE 15-2:
Internal
Data Bus
Read
Write
SSPBUF reg
SCL
Shift
Clock
SSPSR reg
SDA
MSb
Figure 15-1 shows a block diagram for the SPI mode,
while Figure 15-2 and Figure 15-3 show the block
diagrams for the two different I2C modes of operation.
FIGURE 15-1:
Addr Match
or General
Call Detected
Match Detect
SPI MODE BLOCK
DIAGRAM
SSPADD reg
Set, Reset
S, P bits
(SSPSTAT reg)
START and
STOP bit Detect
Internal
Data Bus
Read
LSb
Write
SSPBUF reg
I2C MASTER MODE
BLOCK DIAGRAM
FIGURE 15-3:
Internal
Data Bus
SSPSR reg
SDI
Shift
Clock
bit0
SDO
Read
SSPADD
7
Write
Baud Rate Generator
SS Control
Enable
SS
SSPBUF reg
SCL
Shift
Clock
Edge
Select
SSPSR reg
2
Clock Select
SCK
SSPM3:SSPM0
SMP:CKE 4
TMR2 Output
2
2
Edge
Select
Prescaler Tosc
4, 16, 64
Data to TX/RX in SSPSR
Data Direction bit
1998-2013 Microchip Technology Inc.
SDA
MSb
LSb
Match detect
Addr Match
or General
Call Detected
SSPADD reg
S bit
START and STOP bit Set/Clear
and
Detect/Generate
Clear/Set P, bit
(SSPSTAT reg)
and Set SSPIF
DS30289C-page 133
PIC17C7XX
REGISTER 15-1: SSPSTAT: SYNC SERIAL PORT STATUS REGISTER (ADDRESS: 13h, BANK 6)
R/W-0
R/W-0
R-0
R-0
R-0
R-0
R-0
R-0
SMP
CKE
D/A
P
S
R/W
UA
BF
bit 7
bit 7
bit 0
SMP: Sample bit
SPI Master mode:
1 = Input data sampled at end of data output time
0 = Input data sampled at middle of data output time
SPI Slave mode:
SMP must be cleared when SPI is used in Slave mode
In I2 C Master or Slave mode:
1 = Slew rate control disabled for Standard Speed mode (100 kHz and 1 MHz)
0 = Slew rate control enabled for High Speed mode (400 kHz)
bit 6
CKE: SPI Clock Edge Select (Figure 15-6, Figure 15-8 and Figure 15-9)
CKP = 0:
1 = Data transmitted on rising edge of SCK
0 = Data transmitted on falling edge of SCK
CKP = 1:
1 = Data transmitted on falling edge of SCK
0 = Data transmitted on rising edge of SCK
bit 5
D/A: Data/Address bit (I2C mode only)
1 = Indicates that the last byte received or transmitted was data
0 = Indicates that the last byte received or transmitted was address
bit 4
P: STOP bit
(I2C mode only. This bit is cleared when the MSSP module is disabled, SSPEN is cleared.)
1 = Indicates that a STOP bit has been detected last (this bit is '0' on RESET)
0 = STOP bit was not detected last
bit 3
S: START bit
(I2C mode only. This bit is cleared when the MSSP module is disabled, SSPEN is cleared.)
1 = Indicates that a START bit has been detected last (this bit is '0' on RESET)
0 = START bit was not detected last
bit 2
R/W: Read/Write bit Information (I2C mode only)
This bit holds the R/W bit information following the last address match. This bit is only valid from
the address match to the next START bit, STOP bit, or not ACK bit.
In I2 C Slave mode:
1 = Read
0 = Write
In I2 C Master mode:
1 = Transmit is in progress
0 = Transmit is not in progress
Or’ing this bit with SEN, RSEN, PEN, RCEN, or ACKEN will indicate if the MSSP is in IDLE mode.
bit 1
UA: Update Address (10-bit I2C mode only)
1 = Indicates that the user needs to update the address in the SSPADD register
0 = Address does not need to be updated
bit 0
BF: Buffer Full Status bit
Receive (SPI and I2C modes)
1 = Receive complete, SSPBUF is full
0 = Receive not complete, SSPBUF is empty
Transmit (I2C mode only)
1 = Data transmit in progress (does not include the ACK and STOP bits), SSPBUF is full
0 = Data transmit complete (does not include the ACK and STOP bits), SSPBUF is empty
Legend:
DS30289C-page 134
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
REGISTER 15-2: SSPCON1: SYNC SERIAL PORT CONTROL REGISTER1 (ADDRESS 11h, BANK 6)
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
WCOL
SSPOV
SSPEN
CKP
SSPM3
SSPM2
SSPM1
SSPM0
bit 7
bit 0
bit 7
WCOL: Write Collision Detect bit
Master mode:
1 = A write to the SSPBUF register was attempted while the I2C conditions were not valid for a
transmission to be started
0 = No collision
Slave mode:
1 = The SSPBUF register is written while it is still transmitting the previous word (must be cleared
in software)
0 = No collision
bit 6
SSPOV: Receive Overflow Indicator bit
In SPI mode:
1 = A new byte is received while the SSPBUF register is still holding the previous data. In case
of overflow, the data in SSPSR is lost. Overflow can only occur in Slave mode. In Slave
mode, the user must read the SSPBUF, even if only transmitting data, to avoid setting
overflow. In Master mode, the overflow bit is not set, since each new reception (and
transmission) is initiated by writing to the SSPBUF register. (Must be cleared in software.)
0 = No overflow
In I2 C mode:
1 = A byte is received while the SSPBUF register is still holding the previous byte. SSPOV is a
“don’t care” in Transmit mode. (Must be cleared in software.)
0 = No overflow
bit 5
SSPEN: Synchronous Serial Port Enable bit
In both modes, when enabled, these pins must be properly configured as input or output.
In SPI mode:
1 = Enables serial port and configures SCK, SDO, SDI and SS as the source of the serial port pins
0 = Disables serial port and configures these pins as I/O port pins
In I2 C mode:
1 = Enables the serial port and configures the SDA and SCL pins as the source of the serial port pins
0 = Disables serial port and configures these pins as I/O port pins
Note:
In SPI mode, these pins must be properly configured as input or output.
bit 4
CKP: Clock Polarity Select bit
In SPI mode:
1 = Idle state for clock is a high level
0 = Idle state for clock is a low level
In I2 C Slave mode:
SCK release control
1 = Enable clock
0 = Holds clock low (clock stretch). (Used to ensure data setup time.)
In I2 C Master mode:
Unused in this mode
bit 3-0
SSPM3:SSPM0: Synchronous Serial Port Mode Select bits
0000 = SPI Master mode, clock = FOSC/4
0001 = SPI Master mode, clock = FOSC/16
0010 = SPI Master mode, clock = FOSC/64
0011 = SPI Master mode, clock = TMR2 output/2
0100 = SPI Slave mode, clock = SCK pin, SS pin control enabled
0101 = SPI Slave mode, clock = SCK pin, SS pin control disabled, SS can be used as I/O pin
0110 = I2C Slave mode, 7-bit address
0111 = I2C Slave mode, 10-bit address
1000 = I2C Master mode, clock = FOSC / (4 * (SSPADD+1) )
1xx1 = Reserved
1x1x = Reserved
Legend:
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
1998-2013 Microchip Technology Inc.
x = Bit is unknown
DS30289C-page 135
PIC17C7XX
REGISTER 15-3: SSPCON2: SYNC SERIAL PORT CONTROL REGISTER2 (ADDRESS 12h, BANK 6)
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
R/W-0
GCEN
ACKSTAT
ACKDT
ACKEN
RCEN
PEN
RSEN
SEN
bit 7
bit 0
bit 7
GCEN: General Call Enable bit (in I2C Slave mode only)
1 = Enable interrupt when a general call address (0000h) is received in the SSPSR
0 = General call address disabled
bit 6
ACKSTAT: Acknowledge Status bit (in I2C Master mode only)
In Master Transmit mode:
1 = Acknowledge was not received from slave
0 = Acknowledge was received from slave
bit 5
ACKDT: Acknowledge Data bit (in I2C Master mode only)
In Master Receive mode:
Value that will be transmitted when the user initiates an Acknowledge sequence at the end of a
receive.
1 = Not Acknowledge
0 = Acknowledge
bit 4
ACKEN: Acknowledge Sequence Enable bit (in I2C Master mode only)
In Master Receive mode:
1 = Initiate Acknowledge sequence on SDA and SCL pins and transmit AKDT data bit.
Automatically cleared by hardware.
0 = Acknowledge sequence idle
Note:
bit 3
RCEN: Receive Enable bit (in I2C Master mode only)
1 = Enables Receive mode for I2C
0 = Receive idle
Note:
bit 2
If the I2C module is not in the IDLE mode, this bit may not be set (no spooling) and
the SSPBUF may not be written (or writes to the SSPBUF are disabled).
If the I2C module is not in the IDLE mode, this bit may not be set (no spooling) and
the SSPBUF may not be written (or writes to the SSPBUF are disabled).
PEN: STOP Condition Enable bit (in I2C Master mode only)
SCK Release Control:
1 = Initiate STOP condition on SDA and SCL pins. Automatically cleared by hardware.
0 = STOP condition idle
Note:
bit 1
RSEN: Repeated Start Condition Enabled bit (in I2C Master mode only)
1 = Initiate Repeated Start condition on SDA and SCL pins. Automatically cleared by hardware.
0 = Repeated Start condition idle
Note:
bit 0
If the I2C module is not in the IDLE mode, this bit may not be set (no spooling) and
the SSPBUF may not be written (or writes to the SSPBUF are disabled).
If the I2C module is not in the IDLE mode, this bit may not be set (no spooling) and
the SSPBUF may not be written (or writes to the SSPBUF are disabled).
SEN: START Condition Enabled bit (In I2C Master mode only)
1 = Initiate START condition on SDA and SCL pins. Automatically cleared by hardware.
0 = START condition idle.
Note:
If the I2C module is not in the IDLE mode, this bit may not be set (no spooling) and
the SSPBUF may not be written (or writes to the SSPBUF are disabled).
Legend:
DS30289C-page 136
R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
- n = Value at POR Reset
’1’ = Bit is set
’0’ = Bit is cleared
x = Bit is unknown
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.1
SPI Mode
FIGURE 15-4:
The SPI mode allows 8-bits of data to be synchronously
transmitted and received simultaneously. All four
modes of SPI are supported. To accomplish communication, typically three pins are used:
MSSP BLOCK DIAGRAM
(SPI MODE)
Internal
Data Bus
Read
• Serial Data Out (SDO)
• Serial Data In (SDI)
• Serial Clock (SCK)
Write
SSPBUF reg
Additionally, a fourth pin may be used when in a Slave
mode of operation:
SSPSR reg
• Slave Select (SS)
SDI
15.1.1
SDO
OPERATION
When initializing the SPI, several options need to be
specified. This is done by programming the appropriate
control
bits
in
the
SSPCON1
register
(SSPCON1) and SSPSTAT. These control
bits allow the following to be specified:
Master mode (SCK is the clock output)
Slave mode (SCK is the clock input)
Clock Polarity (Idle state of SCK)
Data Input Sample Phase
(middle or end of data output time)
• Clock Edge
(output data on rising/falling edge of SCK)
• Clock Rate (Master mode only)
• Slave Select mode (Slave mode only)
SS Control
Enable
SS
•
•
•
•
Figure 15-4 shows the block diagram of the MSSP
module when in SPI mode.
Shift
Clock
bit0
Edge
Select
2
Clock Select
SCK
SSPM3:SSPM0
SMP:CKE 4
TMR2 Output
2
2
Edge
Select
Prescaler Tosc
4, 16, 64
Data to TX/RX in SSPSR
Data Direction bit
The MSSP consists of a transmit/receive Shift Register
(SSPSR) and a Buffer register (SSPBUF). The SSPSR
shifts the data in and out of the device, MSb first. The
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 detect bit BF
(SSPSTAT) and the interrupt flag bit SSPIF
(PIR2) are set. This double buffering of the
received data (SSPBUF) allows the next byte to start
reception before reading the data that was just
received. Any write to the SSPBUF register during
transmission/reception of data will be ignored, and the
write collision detect bit WCOL (SSPCON1) will be
set. User software must clear the WCOL bit so that it
can be determined if the following write(s) to the
SSPBUF register completed successfully.
1998-2013 Microchip Technology Inc.
DS30289C-page 137
PIC17C7XX
When the application software is expecting to receive
valid data, the SSPBUF should be read before the next
byte of data to transfer is written to the SSPBUF. Buffer
full bit, BF (SSPSTAT), indicates when SSPBUF
has been loaded with the received data (transmission
is complete). When the SSPBUF is read, bit BF is
cleared. This data may be irrelevant if the SPI is only a
transmitter. Generally the MSSP interrupt is used to
determine when the transmission/reception has completed. The SSPBUF must be read and/or written. If the
interrupt method is not going to be used, then software
polling can be done to ensure that a write collision does
not occur. Example 15-1 shows the loading of the
SSPBUF (SSPSR) for data transmission.
EXAMPLE 15-1:
LOADING THE SSPBUF
(SSPSR) REGISTER
MOVLB 6
LOOP BTFSS SSPSTAT, BF
;
;
;
;
;
GOTO LOOP
;
MOVPF SSPBUF, RXDATA ;
MOVFP TXDATA, SSPBUF ;
15.1.2
ENABLING SPI I/O
To enable the serial port, MSSP Enable bit, SSPEN
(SSPCON1), must be set. To reset or reconfigure
SPI mode, clear bit SSPEN, re-initialize the SSPCON
registers and then set bit SSPEN. This configures the
SDI, SDO, SCK and SS pins as serial port pins. For the
pins to behave as the serial port function, some must
have their data direction bits (in the DDR register)
appropriately programmed. That is:
•
•
•
•
•
SDI is automatically controlled by the SPI module
SDO must have DDRB cleared
SCK (Master mode) must have DDRB cleared
SCK (Slave mode) must have DDRB set
SS must have PORTA set
Any serial port function that is not desired may be overridden by programming the corresponding data direction (DDR) register to the opposite value.
Bank 6
Has data been
received
(transmit
complete)?
No
Save in user RAM
New data to xmit
15.1.3
The SSPSR is not directly readable, or writable and
can only be accessed by addressing the SSPBUF register. Additionally, the MSSP status register (SSPSTAT)
indicates the various status conditions.
TYPICAL CONNECTION
Figure 15-5 shows a typical connection between two
microcontrollers. The master controller (Processor 1)
initiates the data transfer by sending the SCK signal.
Data is shifted out of both shift registers on their programmed clock edge and latched on the opposite edge
of the clock. Both processors should be programmed to
same Clock Polarity (CKP), then both controllers would
send and receive data at the same time. Whether the
data is meaningful (or dummy data) depends on the
application software. This leads to three scenarios for
data transmission:
• Master sends data—Slave sends dummy data
• Master sends data—Slave sends data
• Master sends dummy data—Slave sends data
FIGURE 15-5:
SPI MASTER/SLAVE CONNECTION
SPI Master SSPM3:SSPM0 = 00xxb
SPI Slave SSPM3:SSPM0 = 010xb
SDO
SDI
Serial Input Buffer
(SSPBUF)
Serial Input Buffer
(SSPBUF)
SDI
Shift Register
(SSPSR)
MSb
SDO
LSb
Shift Register
(SSPSR)
MSb
LSb
Serial Clock
SCK
PROCESSOR 1
DS30289C-page 138
SCK
PROCESSOR 2
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.1.4
MASTER MODE
Figure 15-6, Figure 15-8 and Figure 15-9, where the
MSb is transmitted first. In Master mode, the SPI clock
rate (bit rate) is user programmable to be one of the
following:
The master can initiate the data transfer at any time
because it controls the SCK. The master determines
when the slave (Processor 2, Figure 15-5) is to broadcast data by the software protocol.
•
•
•
•
In Master mode, the data is transmitted/received as
soon as the SSPBUF register is written to. If the SPI is
only going to receive, the SDO output could be disabled (programmed as an input). The SSPSR register
will continue to shift in the signal present on the SDI pin
at the programmed clock rate. As each byte is
received, it will be loaded into the SSPBUF register as
if a normal received byte (interrupts and status bits
appropriately set). This could be useful in receiver
applications as a “Line Activity Monitor” mode.
This allows a maximum bit clock frequency (at 33 MHz)
of 8.25 MHz.
Figure 15-6 shows the waveforms for Master mode.
When CKE = 1, the SDO data is valid before there is a
clock edge on SCK. The change of the input sample is
shown based on the state of the SMP bit. The time
when the SSPBUF is loaded with the received data is
shown.
The clock polarity is selected by appropriately programming bit CKP (SSPCON1). This then, would give
waveforms for SPI communication as shown in
FIGURE 15-6:
FOSC/4 (or TCY)
FOSC/16 (or 4 • TCY)
FOSC/64 (or 16 • TCY)
Timer2 output/2
SPI MODE WAVEFORM (MASTER MODE)
Write to
SSPBUF
SCK
(CKP = 0
CKE = 0)
SCK
(CKP = 1
CKE = 0)
4 clock
modes
SCK
(CKP = 0
CKE = 1)
SCK
(CKP = 1
CKE = 1)
SDO
(CKE = 0)
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
SDO
(CKE = 1)
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
SDI
(SMP = 0)
bit0
bit7
Input
Sample
(SMP = 0)
SDI
(SMP = 1)
bit7
bit0
Input
Sample
(SMP = 1)
SSPIF
SSPSR to
SSPBUF
1998-2013 Microchip Technology Inc.
Next Q4 cycle
after Q2
DS30289C-page 139
PIC17C7XX
15.1.5
SLAVE MODE
In Slave mode, the data is transmitted and received as
the external clock pulses appear on SCK. When the
last bit is latched, the interrupt flag bit SSPIF (PIR2)
is set.
While in Slave mode, the external clock is supplied by
the external clock source on the SCK pin. This external
clock must meet the minimum high and low times as
specified in the electrical specifications.
the SDO pin is driven. When the SS pin goes high,
the SDO pin is no longer driven, even if in the middle of a transmitted byte and becomes a floating
output. External pull-up/pull-down resistors may be
desirable, depending on the application.
Note 1: When the SPI is in Slave mode with SS
pin control enabled (SSPCON =
0100), the SPI module will reset if the SS
pin is set to VDD.
2: If the SPI is used in Slave mode with
CKE = '1', then the SS pin control must be
enabled.
While in SLEEP mode, the slave can transmit/receive
data. When a byte is received, the device will wake-up
from SLEEP.
15.1.6
When the SPI module resets, the bit counter is forced
to 0. This can be done by either forcing the SS pin to a
high level, or clearing the SSPEN bit.
SLAVE SELECT
SYNCHRONIZATION
The SS pin allows a Synchronous Slave mode. The
SPI must be in Slave mode with SS pin control
enabled (SSPCON1 = 04h). The pin must not
be driven low for the SS pin to function as an input.
The RA2 Data Latch must be high. When the SS pin
is low, transmission and reception are enabled and
FIGURE 15-7:
To emulate two-wire communication, the SDO pin can
be connected to the SDI pin. When the SPI needs to
operate as a receiver, the SDO pin can be configured
as an input. This disables transmissions from the SDO.
The SDI can always be left as an input (SDI function),
since it cannot create a bus conflict.
SLAVE SYNCHRONIZATION WAVEFORM
SS
SCK
(CKP = 0
CKE = 0)
SCK
(CKP = 1
CKE = 0)
Write to
SSPBUF
SDO
SDI
(SMP = 0)
bit7
bit6
bit7
bit0
bit0
bit7
bit7
Input
Sample
(SMP = 0)
SSPIF
Interrupt
Flag
SSPSR to
SSPBUF
DS30289C-page 140
Next Q4 cycle
after Q2
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 15-8:
SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 0)
SS
optional
SCK
(CKP = 0
CKE = 0)
SCK
(CKP = 1
CKE = 0)
Write to
SSPBUF
SDO
SDI
(SMP = 0)
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
bit0
bit7
Input
Sample
(SMP = 0)
SSPIF
Interrupt
Flag
Next Q4 cycle
after Q2
SSPSR to
SSPBUF
FIGURE 15-9:
SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 1)
SS
not optional
SCK
(CKP = 0
CKE = 1)
SCK
(CKP = 1
CKE = 1)
Write to
SSPBUF
SDO
SDI
(SMP = 0)
bit7
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
bit0
Input
Sample
(SMP = 0)
SSPIF
Interrupt
Flag
SSPSR to
SSPBUF
1998-2013 Microchip Technology Inc.
Next Q4 cycle
after Q2
DS30289C-page 141
PIC17C7XX
15.1.7
SLEEP OPERATION
shifted into the SPI transmit/receive shift register.
When all 8-bits have been received, the MSSP interrupt flag bit will be set and if enabled, will wake the
device from SLEEP.
In Master mode, all module clocks are halted, and the
transmission/reception will remain in that state until the
device wakes from SLEEP. After the device returns to
normal mode, the module will continue to transmit/
receive data.
15.1.8
A RESET disables the MSSP module and terminates
the current transfer.
In Slave mode, the SPI transmit/receive shift register
operates asynchronously to the device. This allows the
device to be placed in SLEEP mode and data to be
TABLE 15-1:
Address
EFFECTS OF A RESET
REGISTERS ASSOCIATED WITH SPI OPERATION
Name
07h, Unbanked INTSTA
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
POR, BOR
MCLR, WDT
0000 0000 0000 0000
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
10h, Bank 4
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0010 000- 0010
11h, Bank 4
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000 000- 0000
14h, Bank 6
SSPBUF
Synchronous Serial Port Receive Buffer/Transmit Register
11h, Bank 6
SSPCON1 WCOL SSPOV SSPEN
13h, Bank 6
SSPSTAT
SMP
CKE
D/A
CKP
P
SSPM3 SSPM2
S
R/W
xxxx xxxx uuuu uuuu
SSPM1
UA
SSPM0 0000 0000 0000 0000
BF
0000 0000 0000 0000
Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the SSP in SPI mode.
DS30289C-page 142
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2
MSSP I2 C Operation
I2C MASTER MODE
BLOCK DIAGRAM
FIGURE 15-11:
The MSSP module in I 2C mode fully implements all
master and slave functions (including general call support) and provides interrupts on START and STOP bits
in hardware to determine a free bus (multi-master function). The MSSP module implements the standard
mode specifications as well as 7-bit and 10-bit
addressing.
Baud Rate Generator
Refer to Application Note AN578, “Use of the SSP
Module in the I 2C Multi-Master Environment.”
SCL
Internal
Data Bus
Read
SSPADD
7
A “glitch” filter is on the SCL and SDA pins when the pin
is an input. This filter operates in both the 100 kHz and
400 kHz modes. In the 100 kHz mode, when these pins
are an output, there is a slew rate control of the pin that
is independent of device frequency.
SSPSR reg
SDA
Write
SSPSR reg
MSb
LSb
Match Detect
Addr Match
Two pins are used for data transfer. These are the SCL
pin, which is the clock and the SDA pin, which is the
data. The SDA and SCL pins are automatically configured when the I2C mode is enabled. The SSP module
functions are enabled by setting SSP Enable bit
SSPEN (SSPCON1).
The MSSP module has six registers for I2C operation.
These are the:
SSPADD reg
START and
STOP bit Detect
Addr Match
S bit
START and STOP bit Set/Clear
and
Detect/Generate Clear/Set P, bit
(SSPSTAT reg)
and Set SSPIF
Shift
Clock
SDA
LSb
SSPADD reg
SSPBUF reg
SCL
MSb
Match Detect
Internal
Data Bus
Read
SSPBUF reg
Shift
Clock
I2C SLAVE MODE BLOCK
DIAGRAM
FIGURE 15-10:
Write
Set, Reset
S, P bits
(SSPSTAT reg)
•
•
•
•
•
SSP Control Register1 (SSPCON1)
SSP Control Register2 (SSPCON2)
SSP Status Register (SSPSTAT)
Serial Receive/Transmit Buffer (SSPBUF)
SSP Shift Register (SSPSR) - Not directly accessible
• SSP Address Register (SSPADD)
The SSPCON1 register allows control of the I 2C operation. Four mode selection bits (SSPCON1) allow
one of the following I 2C modes to be selected:
• I 2C Slave mode (7-bit address)
• I 2C Slave mode (10-bit address)
• I 2C Master mode, clock = OSC/4 (SSPADD +1)
Before selecting any I 2C mode, the SCL and SDA pins
must be programmed to inputs by setting the appropriate DDR bits. Selecting an I 2C mode, by setting the
SSPEN bit, enables the SCL and SDA pins to be used
as the clock and data lines in I 2C mode.
1998-2013 Microchip Technology Inc.
DS30289C-page 143
PIC17C7XX
The SSPSTAT register gives the status of the data
transfer. This information includes detection of a START
or STOP bit, specifies if the received byte was data or
address if the next byte is the completion of 10-bit
address and if this will be a read or write data transfer.
The SSPBUF is the register to which transfer data is
written to or read from. The SSPSR register shifts the
data in or out of the device. In receive operations, the
SSPBUF and SSPSR create a doubled buffered
receiver. This allows reception of the next byte to begin
before reading the last byte of received data. When the
complete byte is received, it is transferred to the
SSPBUF register and flag bit SSPIF is set. If another
complete byte is received before the SSPBUF register
is read, a receiver overflow has occurred and bit
SSPOV (SSPCON1) is set and the byte in the
SSPSR is lost.
The SSPADD register holds the slave address. In
10-bit mode, the user needs to write the high byte of the
address (1111 0 A9 A8 0). Following the high byte
address match, the low byte of the address needs to be
loaded (A7:A0).
15.2.1
SLAVE MODE
In Slave mode, the SCL and SDA pins must be configured as inputs. The MSSP module will override the
input state with the output data when required (slavetransmitter).
When an address is matched or the data transfer after
an address match is received, the hardware automatically will generate the acknowledge (ACK) pulse and
then load the SSPBUF register with the received value
currently in the SSPSR register.
There are certain conditions that will cause the MSSP
module not to give this ACK pulse. These are if either
(or both):
a)
b)
The buffer full bit BF (SSPSTAT) was set
before the transfer was received.
The overflow bit SSPOV (SSPCON1) was
set before the transfer was received.
If the BF bit is set, the SSPSR register value is not
loaded into the SSPBUF, but bit SSPIF and SSPOV are
set. Table 15-2 shows what happens when a data
transfer byte is received, given the status of bits BF and
SSPOV. The shaded cells show the condition where
user software did not properly clear the overflow condition. Flag bit BF is cleared by reading the SSPBUF register, while bit SSPOV is cleared through software.
The SCL clock input must have a minimum high and
low time for proper operation. The high and low times
of the I2C specification, as well as the requirement of
the MSSP module, are shown in timing parameter #100
and parameter #101 of the Electrical Specifications.
DS30289C-page 144
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.1.1
Addressing
5.
Once the MSSP module has been enabled, it waits for
a START condition to occur. Following the START condition, the 8-bits are shifted into the SSPSR register. All
incoming bits are sampled with the rising edge of the
clock (SCL) line. The value of register SSPSR is
compared to the value of the SSPADD register. The
address is compared on the falling edge of the eighth
clock (SCL) pulse. If the addresses match and the BF
and SSPOV bits are clear, the following events occur:
a)
b)
c)
d)
The SSPSR register value is loaded into the
SSPBUF register on the falling edge of the 8th
SCL pulse.
The buffer full bit, BF, is set on the falling edge
of the 8th SCL pulse.
An ACK pulse is generated.
SSP interrupt flag bit, SSPIF (PIR2), is set
(interrupt is generated if enabled) - on the falling
edge of the 9th SCL pulse.
In 10-bit address mode, two address bytes need to be
received by the slave. The five Most Significant bits
(MSbs) of the first address byte specify if this is a 10-bit
address. Bit R/W (SSPSTAT) must specify a write so
the slave device will receive the second address byte.
For a 10-bit address, the first byte would equal ‘1111 0
A9 A8 0’, where A9 and A8 are the two MSbs of the
address. The sequence of events for a 10-bit address is
as follows, with steps 7- 9 for slave-transmitter:
1.
2.
3.
4.
Receive first (high) byte of Address (bits SSPIF,
BF and bit UA (SSPSTAT) are set).
Update the SSPADD register with second (low)
byte of Address (clears bit UA and releases the
SCL line).
Read the SSPBUF register (clears bit BF) and
clear flag bit SSPIF.
Receive second (low) byte of Address (bits
SSPIF, BF and UA are set).
TABLE 15-2:
7.
8.
9.
Note:
15.2.1.2
Following the Repeated Start condition
(step 7) in 10-bit mode, the user only
needs to match the first 7-bit address. The
user does not update the SSPADD for the
second half of the address.
Slave Reception
When the R/W bit of the address byte is clear and an
address match occurs, the R/W bit of the SSPSTAT
register is cleared. The received address is loaded into
the SSPBUF register.
When the address byte overflow condition exists, then
no acknowledge (ACK) pulse is given. An overflow condition is defined as either bit BF (SSPSTAT) is set,
or bit SSPOV (SSPCON1) is set.
An SSP interrupt is generated for each data transfer
byte. Flag bit SSPIF (PIR2) must be cleared in software. The SSPSTAT register is used to determine the
status of the received byte.
Note:
The SSPBUF will be loaded if the SSPOV
bit is set and the BF flag is cleared. If a
read of the SSPBUF was performed, but
the user did not clear the state of the
SSPOV bit before the next receive
occurred, the ACK is not sent and the SSPBUF is updated.
DATA TRANSFER RECEIVED BYTE ACTIONS
Status Bits as Data
Transfer is Received
BF
6.
Update the SSPADD register with the first (high)
byte of Address. This will clear bit UA and
release the SCL line.
Read the SSPBUF register (clears bit BF) and
clear flag bit SSPIF.
Receive Repeated Start condition.
Receive first (high) byte of Address (bits SSPIF
and BF are set).
Read the SSPBUF register (clears bit BF) and
clear flag bit SSPIF.
SSPSR SSPBUF
SSPOV
Generate ACK
Pulse
Set bit SSPIF
(SSP Interrupt occurs
if enabled)
0
0
Yes
Yes
Yes
1
0
No
No
Yes
1
1
No
No
Yes
0
1
Yes
No
Yes
Note 1: Shaded cells show the conditions where the user software did not properly clear the overflow condition.
1998-2013 Microchip Technology Inc.
DS30289C-page 145
PIC17C7XX
15.2.1.3
Slave Transmission
An SSP interrupt is generated for each data transfer
byte. The SSPIF flag bit must be cleared in software,
and the SSPSTAT register is used to determine the status of the byte transfer. The SSPIF flag bit is set on the
falling edge of the ninth clock pulse.
When the R/W bit of the incoming address byte is set
and an address match occurs, the R/W bit of the
SSPSTAT register is set. The received address is
loaded into the SSPBUF register. The ACK pulse will
be sent on the ninth bit, and the SCL pin is held low.
The transmit data must be loaded into the SSPBUF
register, which also loads the SSPSR register. Then
SCL pin should be enabled by setting bit CKP
(SSPCON1). The master must monitor the SCL pin
prior to asserting another clock pulse. The slave
devices may be holding off the master by stretching the
clock. The eight data bits are shifted out on the falling
edge of the SCL input. This ensures that the SDA signal is valid during the SCL high time (Figure 15-13).
I 2C WAVEFORMS FOR RECEPTION (7-BIT ADDRESS)
FIGURE 15-12:
R/W = 0
ACK
Receiving Address
A7 A6 A5 A4 A3 A2 A1
SDA
SCL
1
S
2
As a slave-transmitter, the ACK pulse from the masterreceiver is latched on the rising edge of the ninth SCL
input pulse. If the SDA line was high (not ACK), then
the data transfer is complete. When the not ACK is
latched by the slave, the slave logic is reset and the
slave then monitors for another occurrence of the
START bit. If the SDA line was low (ACK), the transmit
data must be loaded into the SSPBUF register, which
also loads the SSPSR register. Then, the SCL pin
should be enabled by setting the CKP bit.
3
4
5
6
7
Not
Receiving Data
Receiving Data
ACK
ACK
D7 D6 D5 D4 D3 D2 D1 D0
D7 D6 D5 D4 D3 D2 D1 D0
1
9
8
2
3
4
5
6
7
8
9
1
2
3
4
5
8
7
6
9
SSPIF
P
Bus Master
Terminates
Transfer
BF (SSPSTAT)
Cleared in software
SSPBUF register is read
SSPOV (SSPCON1)
Bit SSPOV is set because the SSPBUF register is still full.
ACK is not sent.
FIGURE 15-13:
I 2C WAVEFORMS FOR TRANSMISSION (7-BIT ADDRESS)
SDA
SCL
A7
S
A6
1
2
Data in
sampled
R/W = 0
R/W = 1
ACK
Receiving Address
A5
A4
A3
A2
A1
3
4
5
6
7
Transmitting Data
D7
8
9
1
SCL held low
while CPU
responds to SSPIF
Not ACK
D6
D5
D4
D3
D2
D1
D0
2
3
4
5
6
7
8
9
P
SSPIF
BF (SSPSTAT)
Cleared in software
SSPBUF is written in software
From SSP Interrupt
Service Routine
CKP (SSPCON1)
Set bit after writing to SSPBUF
(the SSPBUF must be written to
before the CKP bit can be set)
DS30289C-page 146
1998-2013 Microchip Technology Inc.
1998-2013 Microchip Technology Inc.
2
UA (SSPSTAT)
BF (SSPSTAT)
(PIR1)
SSPIF
1
S
SCL
1
4
1
5
0
6
7
A9 A8
UA is set indicating that
the SSPADD needs to be
updated
SSPBUF is written with
contents of SSPSR
3
1
8
9
ACK
Receive First Byte of Address R/W = 0
1
1
3
4
5
Cleared in software
2
7
UA is set indicating that
SSPADD needs to be
updated
Cleared by hardware when
SSPADD is updated.
6
A6 A5 A4 A3 A2 A1
8
A0
Receive Second Byte of Address
Dummy read of SSPBUF
to clear BF flag
A7
9
ACK
2
3
1
4
1
Cleared in software
1
1
Cleared by hardware when
SSPADD is updated.
Dummy read of SSPBUF
to clear BF flag
Sr
1
5
0
6
7
A9 A8
Receive First Byte of Address
8
9
R/W=1
ACK
1
3
4
5
6
7
8
9
ACK
P
Write of SSPBUF
initiates transmit
Cleared in software
Bus Master
terminates
transfer
CKP has to be set for clock to be released
2
D4 D3 D2 D1 D0
Transmitting Data Byte
D7 D6 D5
Master sends NACK
Transmit is complete
FIGURE 15-14:
SDA
Clock is held low until
update of SSPADD has
taken place
PIC17C7XX
I2C SLAVE-TRANSMITTER (10-BIT ADDRESS)
DS30289C-page 147
DS30289C-page 148
UA (SSPSTAT)
BF (SSPSTAT)
(PIR1)
SSPIF
1
SCL
S
1
2
1
3
1
5
0
6
A9
7
A8
8
UA is set indicating that
the SSPADD needs to be
updated
SSPBUF is written with
contents of SSPSR
4
1
9
ACK
R/W = 0
1
2
3
A5
4
A4
Cleared in software
A6
5
A3
6
A2
7
A1
8
A0
UA is set indicating that
SSPADD needs to be
updated
Cleared by hardware when
SSPADD is updated with low
byte of address.
Dummy read of SSPBUF
to clear BF flag
A7
Receive Second Byte of Address
9
ACK
3
D5
4
D4
5
D3
Cleared in software
2
D6
Cleared by hardware when
SSPADD is updated with high
byte of address.
Dummy read of SSPBUF
to clear BF flag
1
D7
Receive Data Byte
6
D2
7
D1
8
D0
9
ACK
R/W = 1
Read of SSPBUF
clears BF flag
P
Bus Master
terminates
transfer
FIGURE 15-15:
SDA
Receive First Byte of Address
Clock is held low until
update of SSPADD has
taken place
PIC17C7XX
I2C SLAVE-RECEIVER (10-BIT ADDRESS)
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.2
GENERAL CALL ADDRESS
SUPPORT
If the general call address matches, the SSPSR is
transferred to the SSPBUF, the BF flag is set (eighth
bit) and on the falling edge of the ninth bit (ACK bit), the
SSPIF flag is set.
The addressing procedure for the I2C bus is such that
the first byte after the START condition usually determines which device will be the slave addressed by the
master. The exception is the general call address,
which can address all devices. When this address is
used, all devices should, in theory, respond with an
acknowledge.
When the interrupt is serviced, the source for the interrupt can be checked by reading the contents of the
SSPBUF to determine if the address was device specific, or a general call address.
In 10-bit mode, the SSPADD is required to be updated
for the second half of the address to match and the UA
bit is set (SSPSTAT). If the general call address is
sampled when GCEN is set, while the slave is configured in 10-bit address mode, then the second half of
the address is not necessary, the UA bit will not be set
and the slave will begin receiving data after the
acknowledge (Figure 15-16).
The general call address is one of eight addresses
reserved for specific purposes by the I2C protocol. It
consists of all 0’s with R/W = 0.
The general call address is recognized when the General Call Enable bit (GCEN) is enabled (SSPCON2
is set). Following a START bit detect, 8-bits are shifted
into SSPSR and the address is compared against
SSPADD and is also compared to the general call
address, fixed in hardware.
FIGURE 15-16:
SLAVE MODE GENERAL CALL ADDRESS SEQUENCE (7 OR 10-BIT MODE)
Address is compared to General Call Address
after ACK, set Interrupt
R/W = 0
ACK D7
General Call Address
SDA
Receiving Data
ACK
D6
D5
D4
D3
D2
D1
D0
2
3
4
5
6
7
8
SCL
S
1
2
3
4
5
6
7
8
9
1
9
SSPIF
BF (SSPSTAT)
Cleared in Software
SSPBUF is Read
SSPOV (SSPCON1)
'0'
GCEN (SSPCON2)
'1'
1998-2013 Microchip Technology Inc.
DS30289C-page 149
PIC17C7XX
15.2.3
SLEEP OPERATION
15.2.4
While in SLEEP mode, the I2C module can receive
addresses or data and when an address match or complete byte transfer occurs, wake the processor from
SLEEP (if the SSP interrupt is enabled).
TABLE 15-3:
Address
EFFECTS OF A RESET
A RESET disables the SSP module and terminates the
current transfer.
REGISTERS ASSOCIATED WITH I2C OPERATION
Name
07h, Unbanked INTSTA
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
POR, BOR
MCLR, WDT
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
0000 0000
0000 0000
10h, Bank 4
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0000
000- 0000
11h, Bank 4
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
10h. Bank 6
SSPADD
Synchronous Serial Port (I2C mode) Address Register
0000 0000
0000 0000
14h, Bank 6
SSPBUF
Synchronous Serial Port Receive Buffer/Transmit Register
xxxx xxxx
uuuu uuuu
11h, Bank 6
SSPCON1
WCOL
SSPOV
SSPEN
CKP
SSPM3
SSPM2
SSPM1
SSPM0
0000 0000
0000 0000
12h, Bank 6
SSPCON2
GCEN
ACKSTAT
ACKDT
ACKEN
RCEN
PEN
RSEN
SEN
0000 0000
0000 0000
13h, Bank 6
SSPSTAT
SMP
CKE
D/A
P
S
R/W
UA
BF
0000 0000
0000 0000
Legend:
x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the SSP in I2C mode.
DS30289C-page 150
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.5
MASTER MODE
The following events will cause SSP Interrupt Flag bit,
SSPIF, to be set (SSP Interrupt if enabled):
Master mode of operation is supported by interrupt
generation on the detection of the START and STOP
conditions. The STOP (P) and START (S) bits are
cleared from a RESET, or when the MSSP module is
disabled. Control of the I 2C bus may be taken when the
P bit is set, or the bus is idle, with both the S and P bits
clear.
•
•
•
•
•
START condition
STOP condition
Data transfer byte transmitted/received
Acknowledge transmit
Repeated Start
In Master mode, the SCL and SDA lines are manipulated by the MSSP hardware.
SSP BLOCK DIAGRAM (I2C MASTER MODE)
SSPM3:SSPM0
SSPADD
Internal
Data Bus
Read
Write
SSPBUF
Baud
Rate
Generator
Shift
Clock
SDA
SDA In
SCL In
Bus Collision
1998-2013 Microchip Technology Inc.
MSb
LSb
START bit, STOP bit,
Acknowledge
Generate
START bit Detect,
STOP bit Detect
Write Collision Detect
Clock Arbitration
State Counter for
end of XMIT/RCV
Clock Cntl
SCL
Receive Enable
SSPSR
Clock Arbitrate/WCOL Detect
(hold off clock source)
FIGURE 15-17:
Set/Reset, S, P, WCOL (SSPSTAT)
Set SSPIF, BCLIF
Reset ACKSTAT, PEN (SSPCON2)
DS30289C-page 151
PIC17C7XX
15.2.6
MULTI-MASTER MODE
In Multi-Master mode, the interrupt generation on the
detection of the START and STOP conditions allows
the determination of when the bus is free. The STOP
(P) and START (S) bits are cleared from a RESET, or
when the MSSP module is disabled. Control of the I 2C
bus may be taken when bit P (SSPSTAT) is set, or
the bus is idle, with both the S and P bits clear. When
the bus is busy, enabling the SSP interrupt will generate the interrupt when the STOP condition occurs.
In Multi-Master operation, the SDA line must be monitored for arbitration, to see if the signal level is the
expected output level. This check is performed in hardware, with the result placed in the BCLIF bit.
The states where arbitration can be lost are:
•
•
•
•
•
Address Transfer
Data Transfer
A START Condition
A Repeated Start Condition
An Acknowledge Condition
15.2.7
I2C MASTER MODE SUPPORT
Master mode is enabled by setting and clearing the
appropriate SSPM bits in SSPCON1 and by setting the
SSPEN bit. Once Master mode is enabled, the user
has six options.
• Assert a START condition on SDA and SCL.
• Assert a Repeated Start condition on SDA and
SCL.
• Write to the SSPBUF register initiating
transmission of data/address.
• Generate a STOP condition on SDA and SCL.
• Configure the I2C port to receive data.
• Generate an Acknowledge condition at the end of
a received byte of data.
Note:
15.2.7.1
I2C Master Mode Operation
The master device generates all of the serial clock
pulses and the START and STOP conditions. A transfer
is ended with a STOP condition or with a Repeated
Start condition. Since the Repeated Start condition is
also the beginning of the next serial transfer, the I2C
bus will not be released.
In Master Transmitter mode, serial data is output
through SDA, while SCL outputs the serial clock. The
first byte transmitted contains the slave address of the
receiving device (7 bits) and the Read/Write (R/W) bit.
In this case, the R/W bit will be logic '0'. Serial data is
transmitted 8 bits at a time. After each byte is transmitted, an acknowledge bit is received. START and STOP
conditions are output to indicate the beginning and the
end of a serial transfer.
In Master Receive mode, the first byte transmitted contains the slave address of the transmitting device
(7 bits) and the R/W bit. In this case, the R/W bit will be
logic '1'. Thus, the first byte transmitted is a 7-bit slave
address, followed by a '1' to indicate receive bit. Serial
data is received via SDA, while SCL outputs the serial
clock. Serial data is received 8 bits at a time. After each
byte is received, an acknowledge bit is transmitted.
START and STOP conditions indicate the beginning
and end of transmission.
The baud rate generator used for SPI mode operation
is now used to set the SCL clock frequency for either
100 kHz, 400 kHz, or 1 MHz I2C operation. The baud
rate generator reload value is contained in the lower 7
bits of the SSPADD register. The baud rate generator
will automatically begin counting on a write to the SSPBUF. Once the given operation is complete (i.e., transmission of the last data bit is followed by ACK), the
internal clock will automatically stop counting and the
SCL pin will remain in its last state
The MSSP Module, when configured in I2C
Master mode, does not allow queueing of
events. For instance: The user is not
allowed to initiate a START condition and
immediately write the SSPBUF register to
initiate transmission before the START
condition is complete. In this case, the
SSPBUF will not be written to and the
WCOL bit will be set, indicating that a write
to the SSPBUF did not occur.
DS30289C-page 152
1998-2013 Microchip Technology Inc.
PIC17C7XX
A typical transmit sequence would go as follows:
15.2.8
a)
In I2C Master mode, the reload value for the BRG is
located in the lower 7 bits of the SSPADD register
(Figure 15-18). When the BRG is loaded with this
value, the BRG counts down to 0 and stops until
another reload has taken place. The BRG count is decremented twice per instruction cycle (TCY), on the Q2
and Q4 clock.
b)
c)
d)
e)
f)
g)
h)
i)
j)
k)
l)
The user generates a START Condition by setting the START enable bit (SEN) in SSPCON2.
SSPIF is set. The module will wait the required
START time before any other operation takes
place.
The user loads the SSPBUF with address to
transmit.
Address is shifted out the SDA pin until all 8 bits
are transmitted.
The MSSP Module shifts in the ACK bit from the
slave device and writes its value into the
SSPCON2 register (SSPCON2).
The module generates an interrupt at the end of
the ninth clock cycle by setting SSPIF.
The user loads the SSPBUF with eight bits of data.
DATA is shifted out the SDA pin until all 8 bits are
transmitted.
The MSSP Module shifts in the ACK bit from the
slave device, and writes its value into the
SSPCON2 register (SSPCON2).
The MSSP module generates an interrupt at the
end of the ninth clock cycle by setting the SSPIF
bit.
The user generates a STOP condition by setting
the STOP enable bit PEN in SSPCON2.
Interrupt is generated once the STOP condition
is complete.
FIGURE 15-19:
BAUD RATE GENERATOR
In I2C Master mode, the BRG is reloaded automatically.
If Clock Arbitration is taking place, for instance, the
BRG will be reloaded when the SCL pin is sampled
high (Figure 15-19).
FIGURE 15-18:
BAUD RATE GENERATOR
BLOCK DIAGRAM
SSPM3:SSPM0
SSPADD
SSPM3:SSPM0
Reload
SCL
Control
CLKOUT
Reload
BRG Down Counter
FOSC/4
BAUD RATE GENERATOR TIMING WITH CLOCK ARBITRATION
SDA
DX
DX-1
SCL de-asserted but slave holds
SCL low (clock arbitration).
SCL allowed to transition high.
SCL
BRG decrements
(on Q2 and Q4 cycles).
BRG
Value
03h
02h
01h
00h (hold off)
03h
02h
SCL is sampled high, reload takes
place and BRG starts its count.
BRG
Reload
1998-2013 Microchip Technology Inc.
DS30289C-page 153
PIC17C7XX
15.2.9
I2C MASTER MODE START
CONDITION TIMING
15.2.9.1
If the user writes the SSPBUF when a START
sequence is in progress, then WCOL is set and the
contents of the buffer are unchanged (the write doesn’t
occur).
To initiate a START condition, the user sets the START
condition enable bit, SEN (SSPCON2). If the SDA
and SCL pins are sampled high, the baud rate generator is reloaded with the contents of SSPADD and
starts its count. If SCL and SDA are both sampled high
when the baud rate generator times out (TBRG), the
SDA pin is driven low. The action of the SDA being
driven low while SCL is high is the START condition
and causes the S bit (SSPSTAT) to be set. Following this, the baud rate generator is reloaded with the
contents of SSPADD and resumes its count.
When the baud rate generator times out (TBRG), the
SEN bit (SSPCON2) will be automatically cleared
by hardware, the baud rate generator is suspended,
leaving the SDA line held low and the START condition
is complete.
Note:
WCOL Status Flag
Note:
Because queueing of events is not
allowed, writing to the lower 5 bits of
SSPCON2 is disabled until the START
condition is complete.
If at the beginning of START condition, the
SDA and SCL pins are already sampled
low, or if during the START condition, the
SCL line is sampled low before the SDA
line is driven low, a bus collision occurs.
The Bus Collision Interrupt Flag (BCLIF) is
set, the START condition is aborted and
the I2C module is reset into its IDLE state.
FIGURE 15-20:
FIRST START BIT TIMING
Set S bit (SSPSTAT)
Write to SEN bit occurs here.
SDA = 1,
SCL = 1
TBRG
At completion of START bit,
Hardware clears SEN bit
and sets SSPIF bit.
TBRG
Write to SSPBUF occurs here.
2nd Bit
1st Bit
SDA
TBRG
SCL
TBRG
S
DS30289C-page 154
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 15-21:
START CONDITION FLOW CHART
SSPEN = 1,
SSPCON1 = 1000
Idle Mode
SEN (SSPCON2 = 1)
Bus Collision Detected,
Set BCLIF,
Release SCL,
Clear SEN
No
SDA = 1?
SCL = 1?
Yes
Load BRG with
SSPADD
No
Yes
No
No
SCL= 0?
SDA = 0?
Yes
BRG
Rollover?
Yes
Reset BRG
Force SDA = 0,
Load BRG with
SSPADD,
Set S bit.
No
SCL = 0?
Yes
No
BRG
Rollover?
Yes
Reset BRG
Force SCL = 0,
START Condition Done,
Clear SEN
and set SSPIF
1998-2013 Microchip Technology Inc.
DS30289C-page 155
PIC17C7XX
15.2.10
I2C MASTER MODE REPEATED
START CONDITION TIMING
Immediately following the SSPIF bit getting set, the
user may write the SSPBUF with the 7-bit address in 7bit mode, or the default first address in 10-bit mode.
After the first eight bits are transmitted and an ACK is
received, the user may then transmit an additional eight
bits of address (10-bit mode), or eight bits of data (7-bit
mode).
A Repeated Start condition occurs when the RSEN bit
(SSPCON2) is programmed high and the I2C module is in the idle state. When the RSEN bit is set, the
SCL pin is asserted low. When the SCL pin is sampled
low, the baud rate generator is loaded with the contents
of SSPADD and begins counting. The SDA pin is
released (brought high) for one baud rate generator
count (TBRG). When the baud rate generator times out,
if SDA is sampled high, the SCL pin will be de-asserted
(brought high). When SCL is sampled high the baud
rate generator is reloaded with the contents of
SSPADD and begins counting. SDA and SCL
must be sampled high for one TBRG. This action is then
followed by assertion of the SDA pin (SDA is low) for
one TBRG while SCL is high. Following this, the RSEN
bit in the SSPCON2 register will be automatically
cleared and the baud rate generator is not reloaded,
leaving the SDA pin held low. As soon as a START condition is detected on the SDA and SCL pins, the S bit
(SSPSTAT) will be set. The SSPIF bit will not be set
until the baud rate generator has timed out.
15.2.10.1
WCOL status flag
If the user writes the SSPBUF when a Repeated Start
sequence is in progress, then WCOL is set and the
contents of the buffer are unchanged (the write doesn’t
occur).
Note:
Because queueing of events is not
allowed, writing of the lower 5 bits of
SSPCON2 is disabled until the Repeated
Start condition is complete.
Note 1: If the RSEN is programmed while any
other event is in progress, it will not take
effect.
2: A bus collision during the Repeated Start
condition occurs if:
• SDA is sampled low when SCL goes
from low to high.
• SCL goes low before SDA is
asserted low. This may indicate that
another master is attempting to
transmit a data “1”.
FIGURE 15-22:
REPEAT START CONDITION WAVEFORM
Set S (SSPSTAT)
Write to SSPCON2
occurs here.
SDA = 1,
SCL (no change)
SDA = 1,
SCL = 1
TBRG
TBRG
At completion of START bit,
hardware clear RSEN bit
and set SSPIF
TBRG
1st Bit
SDA
Falling edge of ninth clock
End of Xmit
SCL
Write to SSPBUF occurs here
TBRG
TBRG
Sr = Repeated Start
DS30289C-page 156
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 15-23:
REPEATED START CONDITION FLOW CHART (PAGE 1)
Start
Idle Mode,
SSPEN = 1,
SSPCON1 = 1000
B
RSEN = 1
Force SCL = 0
No
SCL = 0?
Yes
Release SDA,
Load BRG with
SSPADD
BRG
Rollover?
No
Yes
Release SCL
(Clock Arbitration)
SCL = 1?
No
Yes
Bus Collision,
Set BCLIF,
Release SDA,
Clear RSEN
No
SDA = 1?
Yes
Load BRG with
SSPADD
C
1998-2013 Microchip Technology Inc.
A
DS30289C-page 157
PIC17C7XX
FIGURE 15-24:
REPEATED START CONDITION FLOW CHART (PAGE 2)
B
C
A
Yes
No
No
No
SDA = 0?
SCL = 1?
Yes
BRG
Rollover?
Yes
Reset BRG
Force SDA = 0,
Load BRG with
SSPADD
Set S
No
SCL = '0'?
Yes
Reset BRG
DS30289C-page 158
No
BRG
Rollover?
Yes
Force SCL = 0,
Repeated Start
condition done,
Clear RSEN,
Set SSPIF.
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.11
I2C MASTER MODE
TRANSMISSION
Transmission of a data byte, a 7-bit address, or either
half of a 10-bit address, is accomplished by simply writing a value to SSPBUF register. This action will set the
buffer full flag (BF) and allow the baud rate generator to
begin counting and start the next transmission. Each bit
of address/data will be shifted out onto the SDA pin
after the falling edge of SCL is asserted (see data hold
time spec). SCL is held low for one baud rate generator
roll over count (TBRG). Data should be valid before SCL
is released high (see Data setup time spec). When the
SCL pin is released high, it is held that way for TBRG,
the data on the SDA pin must remain stable for that
duration and some hold time after the next falling edge
of SCL. After the eighth bit is shifted out (the falling
edge of the eighth clock), the BF flag is cleared and the
master releases SDA, allowing the slave device being
addressed to respond with an ACK bit during the ninth
bit time, if an address match occurs or if data was
received properly. The status of ACK is read into the
ACKDT on the falling edge of the ninth clock. If the
master receives an acknowledge, the acknowledge
status bit (AKSTAT) is cleared. If not, the bit is set. After
the ninth clock, the SSPIF is set and the master clock
(baud rate generator) is suspended until the next data
byte is loaded into the SSPBUF, leaving SCL low and
SDA unchanged (Figure 15-26).
15.2.11.1
BF Status Flag
In Transmit mode, the BF bit (SSPSTAT) is set
when the CPU writes to SSPBUF and is cleared when
all 8 bits are shifted out.
15.2.11.2
WCOL Status Flag
If the user writes the SSPBUF when a transmit is
already in progress (i.e., SSPSR is still shifting out a
data byte), then WCOL is set and the contents of the
buffer are unchanged (the write doesn’t occur).
WCOL must be cleared in software.
15.2.11.3
AKSTAT Status Flag
In Transmit mode, the AKSTAT bit (SSPCON2) is
cleared when the slave has sent an acknowledge (ACK
= 0) and is set when the slave does not acknowledge
(ACK = 1). A slave sends an acknowledge when it has
recognized its address (including a general call), or
when the slave has properly received its data.
After the write to the SSPBUF, each bit of address will
be shifted out on the falling edge of SCL until all seven
address bits and the R/W bit are completed. On the falling edge of the eighth clock, the master will de-assert
the SDA pin, allowing the slave to respond with an
acknowledge. On the falling edge of the ninth clock, the
master will sample the SDA pin to see if the address
was recognized by a slave. The status of the ACK bit is
loaded into the ACKSTAT status bit (SSPCON2).
Following the falling edge of the ninth clock transmission of the address, the SSPIF is set, the BF flag is
cleared and the baud rate generator is turned off until
another write to the SSPBUF takes place, holding SCL
low and allowing SDA to float.
1998-2013 Microchip Technology Inc.
DS30289C-page 159
PIC17C7XX
FIGURE 15-25:
MASTER TRANSMIT FLOW CHART
Idle Mode
Write SSPBUF
Num_Clocks = 0,
BF = 1
Force SCL = 0
Release SDA so
Slave can drive ACK,
Force BF = 0
Yes
Num_Clocks
= 8?
No
Load BRG with
SSPADD,
start BRG count
Load BRG with
SSPADD,
Start BRG Count,
SDA = Current Data bit
BRG
Rollover?
No
BRG
Rollover?
No
Yes
Yes
Force SCL = 1,
Stop BRG
Stop BRG,
Force SCL = 1
(Clock Arbitration)
SCL = 1?
(Clock Arbitration)
No
SCL = 1?
No
Yes
Yes
SDA =
Data bit?
Read SDA and place into
ACKSTAT bit (SSPCON2)
No
Bus Collision Detected
Set BCLIF, Hold Prescale Off,
Clear XMIT Enable
Yes
Load BRG with
SSPADD,
Count High Time
Load BRG with
SSPADD,
Count SCL High Time
No
Rollover?
Yes
BRG
Rollover?
No
No
SCL = 0?
Yes
Yes
SDA =
Data bit?
No
Yes
Force SCL = 0,
Set SSPIF
Reset BRG
Num_Clocks
= Num_Clocks + 1
DS30289C-page 160
1998-2013 Microchip Technology Inc.
1998-2013 Microchip Technology Inc.
S
R/W
PEN
SEN
BF (SSPSTAT)
SSPIF
SCL
SDA
A6
A5
A4
A3
A2
A1
3
4
5
Cleared in Software
2
6
7
8
9
D7
1
SCL held low
while CPU
Responds to SSPIF
After START Condition SEN Cleared by Hardware.
SSPBUF Written
1
ACK = 0
R/W = 0
SSPBUF Written with 7-bit Address and R/W
Start Transmit
A7
Transmit Address to Slave
3
D5
4
D4
5
D3
6
D2
7
D1
8
D0
SSPBUF is Written in Software
Cleared in Software Service Routine
From SSP interrupt
2
D6
Transmitting Data or Second Half
of 10-bit Address
From Slave Clear ACKSTAT bit SSPCON2
P
Cleared in Software
9
ACK
ACKSTAT in
SSPCON2 = 1
FIGURE 15-26:
SEN = 0
Write SSPCON2 SEN = 1
START Condition Begins
PIC17C7XX
I 2C MASTER MODE TIMING (TRANSMISSION, 7 OR 10-BIT ADDRESS)
DS30289C-page 161
PIC17C7XX
15.2.12
I2C MASTER MODE RECEPTION
Master mode reception is enabled by programming the
receive enable bit, RCEN (SSPCON2).
Note:
The SSP Module must be in an IDLE
STATE before the RCEN bit is set, or the
RCEN bit will be disregarded.
The baud rate generator begins counting and on each
rollover, the state of the SCL pin changes (high to low/
low to high) and data is shifted into the SSPSR. After
the falling edge of the eighth clock, the receive enable
flag is automatically cleared, the contents of the
SSPSR are loaded into the SSPBUF, the BF flag is set,
the SSPIF is set and the baud rate generator is suspended from counting, holding SCL low. The SSP is
now in IDLE state, awaiting the next command. When
the buffer is read by the CPU, the BF flag is automatically cleared. The user can then send an acknowledge
bit at the end of reception, by setting the acknowledge
sequence enable bit, ACKEN (SSPCON2).
DS30289C-page 162
15.2.12.1
BF Status Flag
In receive operation, BF is set when an address or data
byte is loaded into SSPBUF from SSPSR. It is cleared
when SSPBUF is read.
15.2.12.2
SSPOV Status Flag
In receive operation, SSPOV is set when 8 bits are
received into the SSPSR, and the BF flag is already set
from a previous reception.
15.2.12.3
WCOL Status Flag
If the user writes the SSPBUF when a receive is
already in progress (i.e., SSPSR is still shifting in a data
byte), then WCOL is set and the contents of the buffer
are unchanged (the write doesn’t occur).
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 15-27:
MASTER RECEIVER FLOW CHART
Idle Mode
RCEN = 1
Num_Clocks = 0,
Release SDA
Force SCL=0,
Load BRG w/
SSPADD,
Start Count
BRG
Rollover?
No
Yes
Release SCL
(Clock Arbitration)
SCL = 1?
No
Yes
Sample SDA,
Shift Data into SSPSR
Load BRG with
SSPADD,
Start Count.
BRG
Rollover?
No
Yes
SCL = 0?
No
Yes
Num_Clocks
= Num_Clocks + 1
No
Num_Clocks
= 8?
Yes
Force SCL = 0,
Set SSPIF,
Set BF.
Move Contents of SSPSR
into SSPBUF,
Clear RCEN.
1998-2013 Microchip Technology Inc.
DS30289C-page 163
DS30289C-page 164
S
ACKEN
SSPOV
BF
(SSPSTAT)
SDA = 0, SCL = 1
while CPU
Responds to SSPIF
SSPIF
SCL
SDA
2
1
A4
4
A5
3
5
A3
A2
6
Cleared in Software
A6
Transmit Address to Slave
A7
7
A1
8
9
R/W = 1
ACK
ACK from Slave
2
D6
3
D5
5
D3
6
D2
7
D1
8
D0
9
ACK
2
D6
3
D5
4
D4
5
D3
6
D2
Receiving Data from Slave
7
D1
Cleared in Software
Set SSPIF Interrupt
at End of Acknowledge
Sequence
Cleared in
Software
Set SSPIF at End
of Receive
9
ACK is Not Sent
ACK
P
Bus Master
Terminates
Transfer
Set P bit
(SSPSTAT)
and SSPIF
Set SSPIF Interrupt
at End of Acknowledge sequence
PEN bit = 1
Written Here
SSPOV is Set Because
SSPBUF is Still Full
8
D0
RCEN Cleared
Automatically
Set ACKEN, Start Acknowledge Sequence
SDA = ACKDT = 1
Data Shifted in on Falling Edge of CLK
1
D7
RCEN = 1 Start
Next Receive
ACK from Master
SDA = ACKDT = 0
Last bit is shifted into SSPSR and
contents are unloaded into SSPBUF
Cleared in software
Set SSPIF interrupt
at end of receive
4
D4
Receiving Data from Slave
Cleared in software
1
D7
RCEN cleared
automatically
Master Configured as a Receiver
by Programming SSPCON2, (RCEN = 1)
FIGURE 15-28:
SEN = 0
Write to SSPBUF Occurs Here
Start XMIT
Write to SSPCON2 (SEN = 1)
Begin START Condition
Write to SSPCON2
to Start Acknowledge Sequence
SDA = ACKDT (SSPCON2) = 0
PIC17C7XX
I 2C MASTER MODE TIMING (RECEPTION 7-BIT ADDRESS)
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.13
ACKNOWLEDGE SEQUENCE
TIMING
15.2.13.1
If the user writes the SSPBUF when an acknowledge
sequence is in progress, then WCOL is set and the
contents of the buffer are unchanged (the write doesn’t
occur).
An acknowledge sequence is enabled by setting the
acknowledge
sequence
enable
bit,
ACKEN
(SSPCON2). When this bit is set, the SCL pin is
pulled low and the contents of the acknowledge data bit
is presented on the SDA pin. If the user wishes to generate an acknowledge, then the ACKDT bit should be
cleared. If not, the user should set the ACKDT bit
before starting an acknowledge sequence. The baud
rate generator then counts for one rollover period
(TBRG), and the SCL pin is de-asserted (pulled high).
When the SCL pin is sampled high (clock arbitration),
the baud rate generator counts for TBRG. The SCL pin
is then pulled low. Following this, the ACKEN bit is
automatically cleared, the baud rate generator is turned
off and the SSP module then goes into IDLE mode
(Figure 15-29).
FIGURE 15-29:
WCOL Status Flag
ACKNOWLEDGE SEQUENCE WAVEFORM
Acknowledge Sequence Starts Here,
Write to SSPCON2
ACKEN = 1, ACKDT = 0
ACKEN Automatically Cleared
TBRG
TBRG
SDA
ACK
D0
SCL
8
9
SSPIF
Set SSPIF at the End
of Receive
Cleared in
Software
Cleared in
Software
Set SSPIF at the End
of Acknowledge Sequence
Note: TBRG = one baud rate generator period.
1998-2013 Microchip Technology Inc.
DS30289C-page 165
PIC17C7XX
FIGURE 15-30:
ACKNOWLEDGE FLOW CHART
Idle Mode
Set ACKEN
Force SCL = 0
BRG
Rollover?
Yes
No
No
SCL = 0?
Yes
Yes
Drive ACKDT bit
(SSPCON2)
onto SDA pin,
Load BRG with
SSPADD,
Start Count.
SCL = 0?
Reset BRG
Force SCL = 0,
Clear ACKEN
Set SSPIF
No
No
ACKDT = 1?
Yes
No
BRG
Rollover?
Yes
Yes
Force SCL = 1
SDA = 1?
No
Bus Collision Detected,
Set BCLIF,
Release SCL,
Clear ACKEN
No
SCL = 1?
(Clock Arbitration)
Yes
Load BRG with
SSPADD ,
Start Count.
DS30289C-page 166
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.14
STOP CONDITION TIMING
15.2.14.1
WCOL Status Flag
If the user writes the SSPBUF when a STOP sequence
is in progress, then WCOL is set and the contents of the
buffer are unchanged (the write doesn’t occur).
A STOP bit is asserted on the SDA pin at the end of a
receive/transmit by setting the Stop Sequence Enable
bit PEN (SSPCON2). At the end of a receive/
transmit the SCL line is held low after the falling edge
of the ninth clock. When the PEN bit is set, the master
will assert the SDA line low. When the SDA line is sampled low, the baud rate generator is reloaded and
counts down to ‘0’. When the baud rate generator times
out, the SCL pin will be brought high and one TBRG
(baud rate generator rollover count) later, the SDA pin
will be de-asserted. When the SDA pin is sampled high
while SCL is high, the P bit (SSPSTAT) is set. A
TBRG later, the PEN bit is cleared and the SSPIF bit is
set (Figure 15-31).
Whenever the firmware decides to take control of the
bus, it will first determine if the bus is busy by checking
the S and P bits in the SSPSTAT register. If the bus is
busy, then the CPU can be interrupted (notified) when
a STOP bit is detected (i.e., bus is free).
FIGURE 15-31:
STOP CONDITION RECEIVE OR TRANSMIT MODE
SCL = 1 for TBRG, followed by SDA = 1 for TBRG
after SDA sampled high. P bit (SSPSTAT) is set.
Write to SSPCON2
Set PEN
PEN bit (SSPCON2) is cleared by
hardware and the SSPIF bit is set.
Falling Edge of
9th Clock
TBRG
SCL
SDA
ACK
P
TBRG
TBRG
TBRG
SCL brought high after TBRG.
SDA asserted low before rising edge of clock
to setup STOP condition.
Note: TBRG = one baud rate generator period.
1998-2013 Microchip Technology Inc.
DS30289C-page 167
PIC17C7XX
FIGURE 15-32:
STOP CONDITION FLOW CHART
Idle Mode,
SSPEN = 1,
SSPCON1 = 1000
PEN = 1
Start BRG
Force SDA = 0
SCL Doesn’t Change
BRG
Rollover?
No
SDA = 0?
No
Yes
Release SDA,
Start BRG
Yes
Start BRG
BRG
Rollover?
BRG
Rollover?
No
No
Yes
No
P bit Set?
Yes
De-assert SCL,
SCL = 1
Yes
(Clock Arbitration)
SCL = 1?
Bus Collision Detected,
Set BCLIF,
Clear PEN
No
SDA going from
0 to 1 while SCL = 1
Set SSPIF,
STOP Condition done,
PEN cleared
Yes
DS30289C-page 168
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.15
CLOCK ARBITRATION
15.2.16
Clock arbitration occurs when the master, during any
receive, transmit, or Repeated Start/Stop condition, deasserts the SCL pin (SCL allowed to float high). When
the SCL pin is allowed to float high, the baud rate generator (BRG) is suspended from counting until the SCL
pin is actually sampled high. When the SCL pin is sampled high, the baud rate generator is reloaded with the
contents of SSPADD and begins counting. This
ensures that the SCL high time will always be at least
one BRG rollover count, in the event that the clock is
held low by an external device (Figure 15-33).
FIGURE 15-33:
SLEEP OPERATION
While in SLEEP mode, the I2C module can receive
addresses or data and when an address match or complete byte transfer occurs, wake the processor from
SLEEP (if the SSP interrupt is enabled).
15.2.17
EFFECTS OF A RESET
A RESET disables the SSP module and terminates the
current transfer.
CLOCK ARBITRATION TIMING IN MASTER TRANSMIT MODE
BRG Overflow,
Release SCL,
If SCL = 1 Load BRG with
SSPADD, and Start Count
to measure high time interval.
BRG overflow occurs,
Release SCL, Slave device holds SCL low.
SCL = 1 BRG starts counting
clock high interval.
SCL
SCL line sampled once every machine cycle (TOSC 4).
Hold off BRG until SCL is sampled high.
SDA
TBRG
1998-2013 Microchip Technology Inc.
TBRG
TBRG
DS30289C-page 169
PIC17C7XX
15.2.18
MULTI -MASTER COMMUNICATION,
BUS COLLISION AND BUS
ARBITRATION
Multi-Master mode support is achieved by bus arbitration. When the master outputs address/data bits onto
the SDA pin, arbitration takes place when the master
outputs a '1' on SDA, by letting SDA float high and
another master asserts a '0'. When the SCL pin floats
high, data should be stable. If the expected data on
SDA is a '1' and the data sampled on the SDA pin = '0',
then a bus collision has taken place. The master will
set the Bus Collision Interrupt Flag, BCLIF and reset
the I2C port to its IDLE state (Figure 15-34).
If a transmit was in progress when the bus collision
occurred, the transmission is halted, the BF flag is
cleared, the SDA and SCL lines are de-asserted and
the SSPBUF can be written to. When the user services the bus collision Interrupt Service Routine and if
the I2C bus is free, the user can resume communication by asserting a START condition.
FIGURE 15-34:
If a START, Repeated Start, STOP, or Acknowledge
condition was in progress when the bus collision
occurred, the condition is aborted, the SDA and SCL
lines are de-asserted and the respective control bits in
the SSPCON2 register are cleared. When the user
services the bus collision Interrupt Service Routine,
and if the I2C bus is free, the user can resume communication by asserting a START condition.
The master will continue to monitor the SDA and SCL
pins and if a STOP condition occurs, the SSPIF bit will
be set.
A write to the SSPBUF will start the transmission of
data at the first data bit, regardless of where the transmitter left off when bus collision occurred.
In Multi-Master mode, the interrupt generation on the
detection of START and STOP conditions allows the
determination of when the bus is free. Control of the
I2C bus can be taken when the P bit is set in the SSPSTAT register, or the bus is idle and the S and P bits
are cleared.
BUS COLLISION TIMING FOR TRANSMIT AND ACKNOWLEDGE
Data changes
while SCL = 0.
SDA line pulled low
by another source.
SDA released
by master.
Sample SDA. While SCL is high
data doesn’t match what is driven
by the master.
Bus collision has occurred.
SDA
SCL
Set bus collision
interrupt.
BCLIF
DS30289C-page 170
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.18.1
Bus Collision During a START
Condition
During a START condition, a bus collision occurs if:
a)
SDA or SCL are sampled low at the beginning of
the START condition (Figure 15-35).
SCL is sampled low before SDA is asserted low
(Figure 15-36).
b)
During a START condition, both the SDA and the SCL
pins are monitored.
If the SDA pin is sampled low during this count, the
BRG is reset and the SDA line is asserted early
(Figure 15-37). If, however, a '1' is sampled on the SDA
pin, the SDA pin is asserted low at the end of the BRG
count. The baud rate generator is then reloaded and
counts down to 0 and during this time, if the SCL pin is
sampled as '0', a bus collision does not occur. At the
end of the BRG count, the SCL pin is asserted low.
Note:
If:
the SDA pin is already low
or the SCL pin is already low,
then:
the START condition is aborted,
and the BCLIF flag is set,
and the SSP module is reset to its IDLE state
(Figure 15-35).
The START condition begins with the SDA and SCL
pins de-asserted. When the SDA pin is sampled high,
the baud rate generator is loaded from SSPADD
and counts down to ‘0’. If the SCL pin is sampled low
while SDA is high, a bus collision occurs, because it is
assumed that another master is attempting to drive a
data '1' during the START condition.
FIGURE 15-35:
The reason that bus collision is not a factor
during a START condition is that no two
bus masters can assert a START condition
at the exact same time. Therefore, one
master will always assert SDA before the
other. This condition does not cause a bus
collision because the two masters must be
allowed to arbitrate the first address following the START condition and if the address
is the same, arbitration must be allowed to
continue into the data portion, Repeated
Start, or Stop conditions.
BUS COLLISION DURING START CONDITION (SDA ONLY)
SDA goes low before the SEN bit is set.
. Set BCLIF,
S bit and SSPIF set because
SDA = 0, SCL = 1.
SDA
SCL
Set SEN, enable START
condition if SDA = 1, SCL=1.
SEN cleared automatically because of bus collision.
SSP module reset into IDLE state.
SEN
BCLIF
SDA sampled low before
START condition. Set BCLIF.
S bit and SSPIF set because
SDA = 0, SCL = 1.
SSPIF and BCLIF are
cleared in software.
S
SSPIF
SSPIF and BCLIF are
cleared in software.
1998-2013 Microchip Technology Inc.
DS30289C-page 171
PIC17C7XX
FIGURE 15-36:
BUS COLLISION DURING START CONDITION (SCL = 0)
SDA = 0, SCL = 1
TBRG
TBRG
SDA
Set SEN, enable START
sequence if SDA = 1, SCL = 1.
SCL
SCL = 0 before SDA = 0,
Bus collision occurs, Set BCLIF.
SEN
SCL = 0 before BRG time-out,
Bus collision occurs, Set BCLIF.
BCLIF
Interrupts cleared
in software.
S
'0'
'0'
SSPIF
'0'
'0'
FIGURE 15-37:
BRG RESET DUE TO SDA COLLISION DURING START CONDITION
SDA = 0, SCL = 1
Set S
Less than TBRG
SDA
TBRG
SDA pulled low by other master.
Reset BRG and assert SDA.
SCL
S
SCL pulled low after BRG
Time-out.
SEN
BCLIF
Set SSPIF
'0'
Set SEN, enable START
sequence if SDA = 1, SCL = 1.
S
SSPIF
SDA = 0, SCL = 1
Set SSPIF.
DS30289C-page 172
Interrupts cleared
in software.
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.2.18.2
Bus Collision During a Repeated
Start Condition
reloaded and begins counting. If SDA goes from high to
low before the BRG times out, no bus collision occurs
because no two masters can assert SDA at exactly the
same time.
During a Repeated Start condition, a bus collision
occurs if:
a)
b)
If, however, SCL goes from high to low before the BRG
times out and SDA has not already been asserted, then
a bus collision occurs. In this case, another master is
attempting to transmit a data ’1’ during the Repeated
Start condition.
A low level is sampled on SDA when SCL goes
from low level to high level.
SCL goes low before SDA is asserted low, indicating that another master is attempting to transmit a data ’1’.
If, at the end of the BRG time-out, both SCL and SDA
are still high, the SDA pin is driven low, the BRG is
reloaded and begins counting. At the end of the count,
regardless of the status of the SCL pin, the SCL pin is
driven low and the Repeated Start condition is complete (Figure 15-38).
When the user de-asserts SDA and the pin is allowed
to float high, the BRG is loaded with SSPADD
and counts down to ‘0’. The SCL pin is then deasserted and when sampled high, the SDA pin is sampled. If SDA is low, a bus collision has occurred (i.e.,
another master is attempting to transmit a data ’0’). If,
however, SDA is sampled high, then the BRG is
FIGURE 15-38:
BUS COLLISION DURING A REPEATED START CONDITION (CASE 1)
SDA
SCL
Sample SDA when SCL goes high.
If SDA = 0, set BCLIF and release SDA and SCL.
RSEN
BCLIF
S
'0'
Cleared in software.
'0'
SSPIF
'0'
'0'
FIGURE 15-39:
BUS COLLISION DURING REPEATED START CONDITION (CASE 2)
TBRG
TBRG
SDA
SCL
SCL goes low before SDA,
Set BCLIF. Release SDA and SCL.
BCLIF
Interrupt cleared
in software.
RSEN
S
'0'
'0'
SSPIF
'0'
'0'
1998-2013 Microchip Technology Inc.
DS30289C-page 173
PIC17C7XX
15.2.18.3
Bus Collision During a STOP
Condition
The STOP condition begins with SDA asserted low.
When SDA is sampled low, the SCL pin is allowed to
float. When the pin is sampled high (clock arbitration),
the baud rate generator is loaded with SSPADD
and counts down to ‘0’. After the BRG times out, SDA
is sampled. If SDA is sampled low, a bus collision has
occurred. This is due to another master attempting to
drive a data '0'. If the SCL pin is sampled low before
SDA is allowed to float high, a bus collision occurs. This
is another case of another master attempting to drive a
data '0' (Figure 15-40).
Bus collision occurs during a STOP condition if:
a)
b)
After the SDA pin has been de-asserted and
allowed to float high, SDA is sampled low after
the BRG has timed out.
After the SCL pin is de-asserted, SCL is sampled low before SDA goes high.
FIGURE 15-40:
BUS COLLISION DURING A STOP CONDITION (CASE 1)
TBRG
TBRG
TBRG
SDA sampled
low after TBRG,
Set BCLIF.
SDA
SDA asserted low.
SCL
PEN
BCLIF
P
'0'
'0'
SSPIF
'0'
'0'
FIGURE 15-41:
BUS COLLISION DURING A STOP CONDITION (CASE 2)
TBRG
TBRG
TBRG
SDA
Assert SDA.
SCL
SCL goes low before SDA goes high.
Set BCLIF.
PEN
BCLIF
P
'0'
SSPIF
'0'
DS30289C-page 174
1998-2013 Microchip Technology Inc.
PIC17C7XX
15.3
Connection Considerations for
I2C Bus
For standard mode I2C bus devices, the values of
resistors Rp Rs in Figure 15-42 depends on the following parameters:
example, with a supply voltage of VDD = 5V +10% and
VOL max = 0.4V at 3 mA, Rp min = (5.5-0.4)/0.003 =
1.7 k VDD as a function of Rp is shown in Figure 1542. The desired noise margin of 0.1 VDD for the low
level, limits the maximum value of Rs. Series resistors
are optional and used to improve ESD susceptibility.
• Supply voltage
• Bus capacitance
• Number of connected devices (input current +
leakage current)
The bus capacitance is the total capacitance of wire,
connections and pins. This capacitance limits the maximum value of Rp due to the specified rise time
(Figure 15-42).
The supply voltage limits the minimum value of resistor
Rp due to the specified minimum sink current of 3 mA
at VOL max = 0.4V for the specified output stages. For
The SMP bit is the slew rate control enabled bit. This bit
is in the SSPSTAT register and controls the slew rate of
the I/O pins when in I2C mode (master or slave).
FIGURE 15-42:
SAMPLE DEVICE CONFIGURATION FOR I2C BUS
VDD + 10%
Rp
DEVICE
Rp
Rs
Rs
SDA
SCL
Cb = 10 - 400 pF
Note: I2C devices with input levels related to VDD must have one common supply line to which the pull-up resistor is
also connected.
1998-2013 Microchip Technology Inc.
DS30289C-page 175
PIC17C7XX
15.4
Example Program
Example 15-2 shows MPLAB® C17 ’C’ code for using
the I2C module in Master mode to communicate with a
24LC01B serial EEPROM. This example uses the PIC®
MCU ‘C’ libraries included with MPLAB C17.
EXAMPLE 15-2:
INTERFACING TO A 24LC01B SERIAL EEPROM (USING MPLAB C17)
// Include necessary header files
#include
// Processor header file
#include
// Delay routines header file
#include
// Standard Library header file
#include
// I2C routines header file
#define CONTROL 0xa0
// Control byte definition for 24LC01B
// Function declarations
void main(void);
void WritePORTD(static unsigned char data);
void ByteWrite(static unsigned char address,static unsigned char data);
unsigned char ByteRead(static unsigned char address);
void ACKPoll(void);
// Main program
void main(void)
{
static unsigned char address;
static unsigned char datao;
static unsigned char datai;
address = 0;
OpenI2C(MASTER,SLEW_ON);
SSPADD = 39;
// I2C address of 24LC01B
// Data written to 24LC01B
// Data read from 24LC01B
// Preset address to 0
// Configure I2C Module Master mode, Slew rate control on
// Configure clock for 100KHz
while(address 25C.
TACQ =
2 s + Tc + [(Temp - 25C)(0.05 s/C)]
TC =
-CHOLD (RIC + RSS + RS) ln(1/2047)
-120 pF (1 k + 7 k + 10 k) ln(0.0004885)
-120 pF (18 k) ln(0.0004885)
-2.16 s (-7.6241)
16.47 s
TACQ =
2 s + 16.47 s + [(50×C - 25C)(0.05 sC)]
18.447 s + 1.25 s
19.72 s
Note 1: The reference voltage (VREF) has no effect on the equation since it cancels itself out.
2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
3: The maximum recommended impedance for analog sources is 10 k. This is required to meet the pin
leakage specification.
4: After a conversion has completed, a 2.0 TAD delay must complete before acquisition can begin again.
During this time, the holding capacitor is not connected to the selected A/D input channel.
1998-2013 Microchip Technology Inc.
DS30289C-page 183
PIC17C7XX
FIGURE 16-3:
ANALOG INPUT MODEL
VDD
RS
ANx
CPIN
5 pF
VA
Sampling
Switch
VT = 0.6V
VT = 0.6V
RIC 1k
SS
RSS
CHOLD
= DAC capacitance
= 120 pF
I leakage
± 500 nA
VSS
Legend CPIN
= input capacitance
= threshold voltage
VT
I leakage = leakage current at the pin due to
various junctions
RIC
SS
CHOLD
DS30289C-page 184
= interconnect resistance
= sampling switch
= sample/hold capacitance (from DAC)
VDD
6V
5V
4V
3V
2V
5 6 7 8 9 10 11
Sampling Switch
( k )
1998-2013 Microchip Technology Inc.
PIC17C7XX
16.2
Selecting the A/D Conversion
Clock
For correct A/D conversions, the A/D conversion clock
(TAD) must be selected to ensure a minimum TAD time
of 1.6 s.
The A/D conversion time per bit is defined as TAD. The
A/D conversion requires a minimum 12TAD per 10-bit
conversion. The source of the A/D conversion clock is
software selected. The four possible options for TAD
are:
•
•
•
•
Table 16-1 and Table 16-2 show the resultant TAD times
derived from the device operating frequencies and the
A/D clock source selected. These times are for standard voltage range devices.
8TOSC
32TOSC
64TOSC
Internal RC oscillator
TABLE 16-1:
TAD vs. DEVICE OPERATING FREQUENCIES (STANDARD DEVICES (C))
AD Clock Source (TAD)
Note:
Operation
ADCS1:ADCS0
Max FOSC
(MHz)
8TOSC
00
5
32TOSC
01
20
64TOSC
10
33
RC
11
—
When the device frequency is greater than 1 MHz, the RC A/D conversion clock source is only
recommended for SLEEP operation.
TABLE 16-2:
TAD vs. DEVICE OPERATING FREQUENCIES (EXTENDED VOLTAGE DEVICES (LC))
AD Clock Source (TAD)
Note:
Operation
ADCS1:ADCS0
Max FOSC
(MHz)
8TOSC
00
2.67
32TOSC
01
10.67
64TOSC
10
21.33
RC
11
—
When the device frequency is greater than 1 MHz, the RC A/D conversion clock source is only
recommended for SLEEP operation.
1998-2013 Microchip Technology Inc.
DS30289C-page 185
PIC17C7XX
16.3
Configuring Analog Port Pins
The ADCON1, and DDR registers control the operation
of the A/D port pins. The port pins that are desired as
analog inputs must have their corresponding DDR bits
set (input). If the DDR bit is cleared (output), the digital
output level (VOH or VOL) will be converted.
The A/D operation is independent of the state of the
CHS2:CHS0 bits and the DDR bits.
Note 1: When reading the port register, any pin
configured as an analog input channel will
read as cleared (a low level). Pins configured as digital inputs, will convert an analog input. Analog levels on a digitally
configured input will not affect the conversion accuracy.
2: Analog levels on any pin that is defined as
a digital input (including the AN15:AN0
pins), may cause the input buffer to consume current that is out of the devices
specification.
16.4
A/D Conversions
Example 16-2 shows how to perform an A/D conversion. The PORTF and lower four PORTG pins are configured as analog inputs. The analog references
(VREF+ and VREF-) are the device AVDD and AVSS. The
A/D interrupt is enabled, and the A/D conversion clock
is FRC. The conversion is performed on the RG3/AN0
pin (channel 0).
Note:
The GO/DONE bit should NOT be set in
the same instruction that turns on the A/D.
Clearing the GO/DONE bit during a conversion will
abort the current conversion. The A/D result register
pair will NOT be updated with the partially completed A/
D conversion sample. That is, the ADRESH:ADRESL
registers will continue to contain the value of the last
completed conversion (or the last value written to the
ADRESH:ADRESL registers). After the A/D conversion
is aborted, a 2TAD wait is required before the next
acquisition is started. After this 2TAD wait, acquisition
on the selected channel is automatically started.
In Figure 16-4, after the GO bit is set, the first time segment has a minimum of TCY and a maximum of TAD.
EXAMPLE 16-2:
MOVLB
CLRF
MOVLW
MOVWF
MOVLB
BCF
BSF
BSF
BCF
;
;
;
;
A/D CONVERSION
5
ADCON1, F
0x01
ADCON0
4
PIR2, ADIF
PIE2, ADIE
INTSTA, PEIE
CPUSTA, GLINTD
;
;
;
;
;
;
;
;
;
Bank 5
Configure A/D inputs, All analog, TAD = Fosc/8, left just.
A/D is on, Channel 0 is selected
Bank 4
Clear A/D interrupt flag bit
Enable A/D interrupts
Enable peripheral interrupts
Enable all interrupts
Ensure that the required sampling time for the selected input channel has elapsed.
Then the conversion may be started.
MOVLB
BSF
:
:
5
ADCON0, GO
FIGURE 16-4:
; Bank 5
; Start A/D Conversion
;
The ADIF bit will be set and the GO/DONE bit
;
is cleared upon completion of the A/D Conversion
A/D CONVERSION TAD CYCLES
TCY to TAD TAD1 TAD2 TAD3 TAD4 TAD5 TAD6 TAD7 TAD8 TAD9 TAD10 TAD11
b1
b3
b0
b4
b2
b5
b7
b6
b8
b9
Conversion starts.
Holding capacitor is disconnected from analog input (typically 100 ns).
Set GO bit
Next Q4: ADRES is loaded,
GO bit is cleared,
ADIF bit is set,
holding capacitor is connected to analog input.
DS30289C-page 186
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 16-5:
FLOW CHART OF A/D OPERATION
ADON = 0
Yes
ADON = 0?
No
Acquire
Selected Channel
Yes
GO = 0?
No
A/D Clock
= RC?
Yes
Start of A/D
Conversion Delayed
1 Instruction Cycle
Finish Conversion
GO = 0,
ADIF = 1
No
No
Device in
SLEEP?
Yes
SLEEP
Instruction?
Yes
Abort Conversion
GO = 0,
ADIF = 0
Finish Conversion
GO = 0,
ADIF = 1
Wait 2TAD
No
No
Finish Conversion
GO = 0,
ADIF = 1
Wake-up Yes
From SLEEP?
SLEEP
Power-down A/D
Wait 2TAD
Stay in SLEEP
Power-down A/D
Wait 2TAD
1998-2013 Microchip Technology Inc.
DS30289C-page 187
PIC17C7XX
16.4.1
A/D RESULT REGISTERS
The ADRESH:ADRESL register pair is the location
where the 10-bit A/D result is loaded at the completion
of the A/D conversion. This register pair is 16-bits wide.
The A/D module gives the flexibility to left or right justify
the 10-bit result in the 16-bit result register. The A/D
Format Select bit (ADFM) controls this justification.
Figure 16-6 shows the operation of the A/D result justification. The extra bits are loaded with ’0’s’. When an A/
D result will not overwrite these locations (A/D disable),
these registers may be used as two general purpose 8bit registers.
16.5
SLEEP. If the A/D interrupt is not enabled, the A/D module will then be turned off, although the ADON bit will
remain set.
When the A/D clock source is another clock option (not
RC), a SLEEP instruction will cause the present conversion to be aborted and the A/D module to be turned off,
though the ADON bit will remain set.
Turning off the A/D places the A/D module in its lowest
current consumption state.
Note:
A/D Operation During SLEEP
The A/D module can operate during SLEEP mode. This
requires that the A/D clock source be set to RC
(ADCS1:ADCS0 = 11). When the RC clock source is
selected, the A/D module waits one instruction cycle
before starting the conversion. This allows the SLEEP
instruction to be executed, which eliminates all digital
switching noise from the conversion. When the conversion is completed, the GO/DONE bit will be cleared,
and the result loaded into the ADRES register. If the A/
D interrupt is enabled, the device will wake-up from
FIGURE 16-6:
16.6
For the A/D module to operate in SLEEP,
the A/D clock source must be set to RC
(ADCS1:ADCS0 = 11). To allow the conversion to occur during SLEEP, ensure the
SLEEP instruction immediately follows the
instruction that sets the GO/DONE bit.
Effects of a RESET
A device RESET forces all registers to their RESET
state. This forces the A/D module to be turned off, and
any conversion is aborted.
The value that is in the ADRESH:ADRESL registers is
not modified for a Power-on Reset. The
ADRESH:ADRESL registers will contain unknown data
after a Power-on Reset.
A/D RESULT JUSTIFICATION
10-Bit Result
ADFM = 0
ADFM = 1
7
0
2107
0000 00
ADRESH
RESULT
ADRESL
10-bits
Right Justified
DS30289C-page 188
7
0765
RESULT
ADRESH
0
0000 00
ADRESL
10-bits
Left Justified
1998-2013 Microchip Technology Inc.
PIC17C7XX
The maximum pin leakage current is specified in the
Device Data Sheet electrical specification (Table 20-2,
parameter #D060).
Transfer Function
The transfer function of the A/D converter is as follows:
the first transition occurs when the analog input voltage
(VAIN) equals Analog VREF / 1024 (Figure 16-7).
FIGURE 16-7:
A/D TRANSFER
FUNCTION
3FFh
3FEh
003h
002h
1023 LSb
000h
1023.5 LSb
001h
1022.5 LSb
Differential non-linearity measures the maximum actual
code width versus the ideal code width. This measure
is unadjusted.
16.9
1022 LSb
Linearity error refers to the uniformity of the code
changes. Linearity errors cannot be calibrated out of
the system. Integral non-linearity error measures the
actual code transition versus the ideal code transition,
adjusted by the gain error for each code.
An external RC filter is sometimes added for antialiasing of the input signal. The R component should be
selected to ensure that the total source impedance is
kept under the 10 k recommended specification. Any
external components connected (via hi-impedance) to
an analog input pin (capacitor, zener diode, etc.) should
have very little leakage current at the pin.
3 LSb
Gain error measures the maximum deviation of the last
actual transition and the last ideal transition adjusted
for offset error. This error appears as a change in slope
of the transfer function. The difference in gain error to
full scale error is that full scale does not take offset error
into account. Gain error can be calibrated out in software.
If the input voltage exceeds the rail values (VSS or VDD)
by greater than 0.3V, then the accuracy of the conversion is out of specification.
2 LSb
Offset error measures the first actual transition of a
code versus the first ideal transition of a code. Offset
error shifts the entire transfer function. Offset error can
be calibrated out of a system or introduced into a system through the interaction of the total leakage current
and source impedance at the analog input.
Connection Considerations
2.5 LSb
For a given range of analog inputs, the output digital
code will be the same. This is due to the quantization of
the analog input to a digital code. Quantization error is
typically ± 1/2 LSb and is inherent in the analog to digital conversion process. The only way to reduce quantization error is to increase the resolution of the A/D
converter or oversample.
16.8
1.5 LSb
The absolute accuracy specified for the A/D converter
includes the sum of all contributions for quantization
error, integral error, differential error, full scale error, offset error, and monotonicity. It is defined as the maximum deviation from an actual transition versus an ideal
transition for any code. The absolute error of the A/D
converter is specified at < ±1 LSb for VDD = VREF (over
the device’s specified operating range). However, the
accuracy of the A/D converter will degrade as VREF
diverges from VDD.
1 LSb
In systems where the device frequency is low, use of
the A/D RC clock is preferred. At moderate to high frequencies, TAD should be derived from the device oscillator.
In systems where the device will enter SLEEP mode
after the start of the A/D conversion, the RC clock
source selection is required. In this mode, the digital
noise from the modules in SLEEP are stopped. This
method gives high accuracy.
0.5 LSb
A/D Accuracy/Error
Digital Code Output
16.7
Analog Input Voltage
In systems where the device frequency is low, use of
the A/D RC clock is preferred. At moderate to high frequencies, TAD should be derived from the device oscillator. TAD must not violate the minimum and should be
minimized to reduce inaccuracies due to noise and
sampling capacitor bleed off.
1998-2013 Microchip Technology Inc.
DS30289C-page 189
PIC17C7XX
16.10 References
A good reference for understanding A/D converter is the
"Analog-Digital Conversion Handbook" third edition,
published by Prentice Hall (ISBN 0-13-03-2848-0).
TABLE 16-3:
Address
REGISTERS/BITS ASSOCIATED WITH A/D
Name
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
POR,
BOR
MCLR, WDT
--11 1100
--11 qq11
06h, unbanked CPUSTA
—
—
STAKAV
GLINTD
TO
PD
POR
BOR
07h, unbanked INTSTA
PEIF
T0CKIF
T0IF
INTF
PEIE
T0CKIE
T0IE
INTE
0000 0000
0000 0000
10h, Bank 4
PIR2
SSPIF
BCLIF
ADIF
—
CA4IF
CA3IF
TX2IF
RC2IF
000- 0010
000- 0010
11h, Bank 4
PIE2
SSPIE
BCLIE
ADIE
—
CA4IE
CA3IE
TX2IE
RC2IE
000- 0000
000- 0000
10h, Bank 5
DDRF
1111 1111
1111 1111
0000 0000
0000 0000
Data Direction Register for PORTF
RF7/
AN11
RF6/
AN10
RF5/
AN9
11h, Bank 5
PORTF
12h, Bank 5
DDRG
Data Direction register for PORTG
PORTG
RG7/
RG6/
TX2/CK2 RX2/DT2
13h, Bank 5
RF4/
AN8
RG5/
PWM3
RG4/
CAP3
RF3/
AN7
RF2/
AN6
RG3/
RG2/
AN0/VREF+ AN1/VREF-
RF1/
AN5
RF0/
AN4
1111 1111
1111 1111
RG1/
AN2
RG0/
AN3
xxxx 0000
uuuu 0000
14h, Bank 5
ADCON0
CHS3
CHS2
CHS1
CHS0
—
GO/DONE
—
ADON
0000 -0-0
0000 -0-0
15h, Bank 5
ADCON1
ADCS1
ADCS0
ADFM
—
PCFG3
PCFG2
PCFG1
PCFG0
000- 0000
000- 0000
16h, Bank 5
ADRESL
A/D Result Low Register
xxxx xxxx
uuuu uuuu
17h, Bank 5
ADRESH
A/D Result High Register
xxxx xxxx
uuuu uuuu
Legend:
x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used for A/D conversion.
Note:
Other (non power-up) RESETS include: external RESET through MCLR and Watchdog Timer Reset.
DS30289C-page 190
1998-2013 Microchip Technology Inc.
PIC17C7XX
17.0
SPECIAL FEATURES OF THE
CPU
What sets a microcontroller apart from other processors are special circuits to deal with the needs of realtime applications. The PIC17CXXX family has a host of
such features intended to maximize system reliability,
minimize cost through elimination of external components, provide power saving operating modes and offer
code protection. These are:
• Oscillator Selection (Section 4.0)
• RESET (Section 5.0)
- Power-on Reset (POR)
- Power-up Timer (PWRT)
- Oscillator Start-up Timer (OST)
- Brown-out Reset (BOR)
• Interrupts (Section 6.0)
• Watchdog Timer (WDT)
• SLEEP mode
• Code protection
The PIC17CXXX has a Watchdog Timer which can be
shut-off only through EPROM bits. It runs off its own RC
oscillator for added reliability. There are two timers that
offer necessary delays on POR and BOR. One is the
Oscillator Start-up Timer (OST), intended to keep the
chip in RESET until the crystal oscillator is stable. The
other is the Power-up Timer (PWRT), which provides a
fixed delay of 96 ms (nominal) on power-up only,
designed to keep the part in RESET while the power
supply stabilizes. With these two timers on-chip, most
applications need no external RESET circuitry.
The SLEEP mode is designed to offer a very low current power-down mode. The user can wake from
SLEEP through external RESET, Watchdog Timer
Reset, or through an interrupt. Several oscillator
options are also made available to allow the part to fit
the application. The RC oscillator option saves system
cost, while the LF crystal option saves power. Configuration bits are used to select various options. This configuration word has the format shown in Figure 17-1.
REGISTER 17-1: CONFIGURATION WORDS
High (H) Table Read Addr.
FE0Fh - FE08h
U-x
—
bit 15
Low (L) Table Read Addr.
FE07h - FE00h
R/P-1
U-x
U-x
U-x
U-x
U-x
U-x
PM2
BODEN
—
—
—
—
—
—
bit 8 bit 7
U-x
—
bit 15
R/P-1
bit 0
U-x
R/P-1
U-x
R/P-1
—
PM1
—
PM0
R/P-1
R/P-1
R/P-1
WDTPS1 WDTPS0 FOSC1 FOSC0
bit 8 bit 7
bits 7H, 6L, 4L
PM2, PM1, PM0: Processor Mode Select bits
111 = Microprocessor mode
110 = Microcontroller mode
101 = Extended Microcontroller mode
000 = Code Protected Microcontroller mode
bit 6H
BODEN: Brown-out Detect Enable
1 = Brown-out Detect circuitry is enabled
0 = Brown-out Detect circuitry is disabled
bits 3L:2L
WDTPS1:WDTPS0: WDT Postscaler Select bits
11 = WDT enabled, postscaler = 1
10 = WDT enabled, postscaler = 256
01 = WDT enabled, postscaler = 64
00 = WDT disabled, 16-bit overflow timer
bits 1L:0L
FOSC1:FOSC0: Oscillator Select bits
11 = EC oscillator
10 = XT oscillator
01 = RC oscillator
00 = LF oscillator
Shaded bits (—)
Reserved
1998-2013 Microchip Technology Inc.
R/P-1
bit 0
DS30289C-page 191
PIC17C7XX
17.1
Configuration Bits
17.2
The PIC17CXXX has eight configuration locations
(Table 17-1). These locations can be programmed
(read as '0'), or left unprogrammed (read as '1') to
select various device configurations. Any write to a
configuration location, regardless of the data, will program that configuration bit. A TABLWT instruction and
raising the MCLR/VPP pin to the programming voltage
are both required to write to program memory locations. The configuration bits can be read by using the
TABLRD instructions. Reading any configuration location between FE00h and FE07h will read the low byte
of the configuration word (Figure 17-1) into the TABLATL register. The TABLATH register will be FFh.
Reading a configuration location between FE08h and
FE0Fh will read the high byte of the configuration word
into the TABLATL register. The TABLATH register will
be FFh.
17.2.1
Oscillator Configurations
OSCILLATOR TYPES
The PIC17CXXX can be operated in four different oscillator modes. The user can program two configuration
bits (FOSC1:FOSC0) to select one of these four
modes:
•
•
•
•
LF
XT
EC
RC
Low Power Crystal
Crystal/Resonator
External Clock Input
Resistor/Capacitor
For information on the different oscillator types and
how to use them, please refer to Section 4.0.
Addresses FE00h through FE0Fh are only in the program memory space for Microcontroller and Code Protected Microcontroller modes. A device programmer
will be able to read the configuration word in any processor mode. See programming specifications for
more detail.
TABLE 17-1:
Note:
CONFIGURATION
LOCATIONS
Bit
Address
FOSC0
FOSC1
WDTPS0
WDTPS1
PM0
PM1
BODEN
PM2
FE00h
FE01h
FE02h
FE03h
FE04h
FE06h
FE0Eh
FE0Fh
When programming the desired configuration locations, they must be programmed
in ascending order, starting with address
FE00h.
DS30289C-page 192
1998-2013 Microchip Technology Inc.
PIC17C7XX
17.3
17.3.2
Watchdog Timer (WDT)
The Watchdog Timer’s function is to recover from software malfunction, or to reset the device while in SLEEP
mode. The WDT uses an internal free running on-chip
RC oscillator for its clock source. This does not require
any external components. This RC oscillator is separate from the RC oscillator of the OSC1/CLKIN pin.
That means that the WDT will run even if the clock on
the OSC1/CLKIN and OSC2/CLKOUT pins has been
stopped, for example, by execution of a SLEEP instruction. During normal operation, a WDT time-out generates a device RESET. The WDT can be permanently
disabled by programming the configuration bits
WDTPS1:WDTPS0 as '00' (Section 17.1).
The WDT and postscaler are cleared when:
•
•
•
•
The device is in the RESET state
A SLEEP instruction is executed
A CLRWDT instruction is executed
Wake-up from SLEEP by an interrupt
The WDT counter/postscaler will start counting on the
first edge after the device exits the RESET state.
17.3.3
WDT PROGRAMMING
CONSIDERATIONS
It should also be taken in account that under worst case
conditions (VDD = Min., Temperature = Max., Max.
WDT postscaler), it may take several seconds before a
WDT time-out occurs.
Under normal operation, the WDT must be cleared on
a regular interval. This time must be less than the minimum WDT overflow time. Not clearing the WDT in this
time frame will cause the WDT to overflow and reset
the device.
17.3.1
CLEARING THE WDT AND
POSTSCALER
The WDT and postscaler become the Power-up Timer
whenever the PWRT is invoked.
WDT PERIOD
17.3.4
The WDT has a nominal time-out period of 12 ms (with
postscaler = 1). The time-out periods vary with temperature, VDD and process variations from part to part (see
DC specs). If longer time-out periods are desired, configuration bits should be used to enable the WDT with
a greater prescale. Thus, typical time-out periods up to
3.0 seconds can be realized.
WDT AS NORMAL TIMER
When the WDT is selected as a normal timer, the clock
source is the device clock. Neither the WDT nor the
postscaler are directly readable or writable. The overflow time is 65536 TOSC cycles. On overflow, the TO bit
is cleared (device is not RESET). The CLRWDT instruction can be used to set the TO bit. This allows the WDT
to be a simple overflow timer. The simple timer does
not increment when in SLEEP.
The CLRWDT and SLEEP instructions clear the WDT
and its postscale setting and prevent it from timing out,
thus generating a device RESET condition.
The TO bit in the CPUSTA register will be cleared upon
a WDT time-out.
FIGURE 17-1:
WATCHDOG TIMER BLOCK DIAGRAM
On-chip RC
Oscillator(1)
WDT
Postscaler
WDTPS1:WDTPS0
4 - to - 1 MUX
WDT Enable
Note 1: This oscillator is separate from the external
RC oscillator on the OSC1 pin.
TABLE 17-2:
Address
—
WDT Overflow
REGISTERS/BITS ASSOCIATED WITH THE WATCHDOG TIMER
Name
Config
06h, Unbanked CPUSTA
Bit 7
Bit 6
Bit 5
Bit 4
Bit 3
Bit 2
Bit 1
Bit 0
Value on
POR, BOR
(Note 1)
(Note 1)
POR
BOR
--11 11qq
--11 qquu
See Figure 17-1 for location of WDTPSx bits in Configuration Word.
—
—
STKAV
GLINTD
TO
PD
MCLR, WDT
Legend:
- = unimplemented, read as '0', q = value depends on condition. Shaded cells are not used by the WDT.
Note 1: This value will be as the device was programmed, or if unprogrammed, will read as all '1's.
1998-2013 Microchip Technology Inc.
DS30289C-page 193
PIC17C7XX
17.4
Power-down Mode (SLEEP)
Any RESET event will cause a device RESET. Any
interrupt event is considered a continuation of program
execution. The TO and PD bits in the CPUSTA register
can be used to determine the cause of a device
RESET. The PD bit, which is set on power-up, is
cleared when SLEEP is invoked. The TO bit is cleared
if WDT time-out occurred (and caused a RESET).
The Power-down mode is entered by executing a
SLEEP instruction. This clears the Watchdog Timer and
postscaler (if enabled). The PD bit is cleared and the
TO bit is set (in the CPUSTA register). In SLEEP mode,
the oscillator driver is turned off. The I/O ports maintain
their status (driving high,low, or hi-impedance input).
When the SLEEP instruction is being executed, the next
instruction (PC + 1) is pre-fetched. For the device to
wake-up through an interrupt event, the corresponding
interrupt enable bit must be set (enabled). Wake-up is
regardless of the state of the GLINTD bit. If the GLINTD
bit is set (disabled), the device continues execution at
the instruction after the SLEEP instruction. If the
GLINTD bit is clear (enabled), the device executes the
instruction after the SLEEP instruction and then
branches to the interrupt vector address. In cases
where the execution of the instruction following SLEEP
is not desirable, the user should have a NOP after the
SLEEP instruction.
The MCLR/VPP pin must be at a logic high level
(VIHMC). A WDT time-out RESET does not drive the
MCLR/VPP pin low.
17.4.1
WAKE-UP FROM SLEEP
The device can wake-up from SLEEP through one of
the following events:
•
•
•
•
•
Power-on Reset
Brown-out Reset
External RESET input on MCLR/VPP pin
WDT Reset (if WDT was enabled)
Interrupt from RA0/INT pin, RB port change,
T0CKI interrupt, or some peripheral interrupts
Note:
If the global interrupt is disabled (GLINTD
is set), but any interrupt source has both its
interrupt enable bit and the corresponding
interrupt flag bit set, the device will immediately wake-up from SLEEP. The TO bit is
set and the PD bit is cleared.
The following peripheral interrupts can wake the device
from SLEEP:
•
•
•
•
•
•
Capture interrupts
USART synchronous slave transmit interrupts
USART synchronous slave receive interrupts
A/D conversion complete
SPI slave transmit/receive complete
I2C slave receive
The WDT is cleared when the device wakes from
SLEEP, regardless of the source of wake-up.
17.4.1.1
Other peripherals cannot generate interrupts since during SLEEP, no on-chip Q clocks are present.
FIGURE 17-2:
Wake-up Delay
When the oscillator type is configured in XT or LF
mode, the Oscillator Start-up Timer (OST) is activated
on wake-up. The OST will keep the device in RESET
for 1024TOSC. This needs to be taken into account
when considering the interrupt response time when
coming out of SLEEP.
WAKE-UP FROM SLEEP THROUGH INTERRUPT
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
OSC1
TOST(2)
CLKOUT(4)
INT
(RA0/INT pin)
INTF Flag
'0' or '1'
Interrupt Latency(2)
GLINTD bit
Processor
in SLEEP
INSTRUCTION FLOW
PC
Instruction
Fetched
Instruction
Executed
PC
Inst (PC) = SLEEP
Inst (PC-1)
PC+1
PC+2
0004h
Inst (PC+1)
Inst (PC+2)
SLEEP
Inst (PC+1)
0005h
Dummy Cycle
Note 1: XT or LF oscillator mode assumed.
2: TOST = 1024TOSC (drawing not to scale). This delay will not be there for RC osc mode.
3: When GLINTD = 0, processor jumps to interrupt routine after wake-up. If GLINTD = 1, execution will continue in line.
4: CLKOUT is not available in these osc modes, but shown here for timing reference.
DS30289C-page 194
1998-2013 Microchip Technology Inc.
PIC17C7XX
17.4.2
MINIMIZING CURRENT
CONSUMPTION
To minimize current consumption, all I/O pins should be
either at VDD, or VSS, with no external circuitry drawing
current from the I/O pin. I/O pins that are hi-impedance
inputs should be pulled high or low externally to avoid
switching currents caused by floating inputs. The
T0CKI input should be at VDD or VSS. The contributions
from on-chip pull-ups on PORTB should also be considered and disabled, when possible.
17.5
Code Protection
The code in the program memory can be protected by
selecting the microcontroller in Code Protected mode
(PM2:PM0 = '000').
In this mode, instructions that are in the on-chip program memory space, can continue to read or write the
program memory. An instruction that is executed outside of the internal program memory range will be
inhibited from writing to, or reading from, program
memory.
Note:
Microchip does not recommend code protecting windowed devices.
If the code protection bit(s) have not been programmed, the on-chip program memory can be read
out for verification purposes.
1998-2013 Microchip Technology Inc.
DS30289C-page 195
PIC17C7XX
17.6
In-Circuit Serial Programming
The PIC17C7XX group of the high-end family
(PIC17CXXX) has an added feature that allows serial
programming while in the end application circuit. This is
simply done with two lines for clock and data and three
other lines for power, ground, and the programming
voltage. This allows customers to manufacture boards
with unprogrammed devices and then program the
microcontroller just before shipping the product. This
also allows the most recent firmware, or a custom firmware to be programmed.
Devices may be serialized to make the product unique;
“special” variants of the product may be offered and
code updates are possible. This allows for increased
design flexibility.
To place the device into the Serial Programming Test
mode, two pins will need to be placed at VIHH. These
are the TEST pin and the MCLR/VPP pin. Also, a
sequence of events must occur as follows:
1.
2.
The TEST pin is placed at VIHH.
The MCLR/VPP pin is placed at VIHH.
For complete details of serial programming, please
refer to the PIC17C7XX Programming Specification.
(Contact your local Microchip Technology Sales Office
for availability.)
FIGURE 17-3:
External
Connector
Signals
TYPICAL IN-CIRCUIT
SERIAL PROGRAMMING
CONNECTION
To Normal
Connections
PIC17C7XX
+5V
VDD
0V
VSS
VPP
MCLR/VPP
TEST CNTL
TEST
RA1/T0CKI
Dev. CLK
Data I/O
RA4/RX1/DT1
Data CLK
RA5/TX1/CK1
There is a setup time between step 1 and step 2 that
must be met.
After this sequence, the Program Counter is pointing to
program memory address 0xFF60. This location is in
the Boot ROM. The code initializes the USART/SCI so
that it can receive commands. For this, the device must
be clocked. The device clock source in this mode is the
RA1/T0CKI pin. After delaying to allow the USART/SCI
to initialize, commands can be received. The flow is
shown in these 3 steps:
1.
2.
3.
VDD
To Normal
Connections
The device clock source starts.
Wait 80 device clocks for Boot ROM code to
configure the USART/SCI.
Commands may now be sent.
TABLE 17-3:
ICSP INTERFACE PINS
During Programming
Name
RA4/RX1/DT1
RA5/TX1/CK1
RA1/T0CKI
TEST
MCLR/VPP
VDD
VSS
DS30289C-page 196
Function
Type
DT
CK
OSCI
TEST
MCLR/VPP
VDD
VSS
I/O
I
I
I
P
P
P
Description
Serial Data
Serial Clock
Device Clock Source
Test mode selection control input, force to VIHH
Master Clear Reset and Device Programming Voltage
Positive supply for logic and I/O pins
Ground reference for logic and I/O pins
1998-2013 Microchip Technology Inc.
PIC17C7XX
18.0
INSTRUCTION SET SUMMARY
The PIC17CXXX instruction set consists of 58 instructions. Each instruction is a 16-bit word divided into an
OPCODE and one or more operands. The opcode
specifies the instruction type, while the operand(s) further specify the operation of the instruction. The
PIC17CXXX instruction set can be grouped into three
types:
• byte-oriented
• bit-oriented
• literal and control operations
These formats are shown in Figure 18-1.
Table 18-1 shows the field descriptions for the
opcodes. These descriptions are useful for understanding the opcodes in Table 18-2 and in each specific
instruction descriptions.
For byte-oriented instructions, 'f' represents a file
register designator and 'd' represents a destination
designator. The file register designator specifies which
file register is to be used by the instruction.
The destination designator specifies where the result of
the operation is to be placed. If 'd' = '0', the result is
placed in the WREG register. If 'd' = '1', the result is
placed in the file register specified by the instruction.
TABLE 18-1:
OPCODE FIELD
DESCRIPTIONS
Field
Description
f
Register file address (00h to FFh)
p
Peripheral register file address (00h to 1Fh)
i
Table pointer control i = '0' (do not change)
i = '1' (increment after instruction execution)
t
Table byte select t = '0' (perform operation on lower
byte)
t = '1' (perform operation on upper byte literal field,
constant data)
WREG
Working register (accumulator)
b
Bit address within an 8-bit file register
k
Literal field, constant data or label
x
Don't care location (= '0' or '1')
The assembler will generate code with x = '0'. It is
the recommended form of use for compatibility with
all Microchip software tools.
d
Destination select
0 = store result in WREG
1 = store result in file register f
Default is d = '1'
u
Unused, encoded as '0'
s
Destination select
0 = store result in file register f and in the WREG
1 = store result in file register f
Default is s = '1'
For bit-oriented instructions, 'b' represents a bit field
designator which selects the number of the bit affected
by the operation, while 'f' represents the number of the
file in which the bit is located.
label Label name
For literal and control operations, 'k' represents an 8or 13-bit constant or literal value.
GLINTD Global Interrupt Disable bit (CPUSTA)
The instruction set is highly orthogonal and is grouped
into:
• byte-oriented operations
• bit-oriented operations
• literal and control operations
All instructions are executed within one single instruction cycle, unless:
• a conditional test is true
• the program counter is changed as a result of an
instruction
• a table read or a table write instruction is executed
(in this case, the execution takes two instruction
cycles with the second cycle executed as a NOP)
One instruction cycle consists of four oscillator periods.
Thus, for an oscillator frequency of 25 MHz, the normal
instruction execution time is 160 ns. If a conditional test
is true or the program counter is changed as a result of
an instruction, the instruction execution time is 320 ns.
1998-2013 Microchip Technology Inc.
C,DC, ALU status bits Carry, Digit Carry, Zero, Overflow
Z,OV
TBLPTR Table Pointer (16-bit)
TBLAT Table Latch (16-bit) consists of high byte (TBLATH)
and low byte (TBLATL)
TBLATL Table Latch low byte
TBLATH Table Latch high byte
TOS
PC
Top-of-Stack
Program Counter
BSR
Bank Select Register
WDT
Watchdog Timer Counter
TO
Time-out bit
PD
Power-down bit
dest
Destination either the WREG register or the specified register file location
[ ]
Options
( )
Contents
Assigned to
Register bit field
In the set of
italics User defined term (font is courier)
DS30289C-page 197
PIC17C7XX
Table 18-2 lists the instructions recognized by the
MPASM assembler.
Note 1: Any unused opcode is Reserved. Use of
any reserved opcode may cause unexpected operation.
All instruction examples use the following format to represent a hexadecimal number:
The PIC17C7XX’s orthogonal instruction set allows
read and write of all file registers, including special
function registers. There are some special situations
the user should be aware of:
To represent a binary number:
0000 0100b
where b signifies a binary string.
GENERAL FORMAT FOR
INSTRUCTIONS
Byte-oriented file register operations
9
8
d
OPCODE
7
0
f (FILE #)
d = 0 for destination WREG
d = 1 for destination f
f = 8-bit file register address
18.1.2
PCL AS SOURCE OR DESTINATION
Read, write or read-modify-write on PCL may have the
following results:
Read PC:
PCH PCLATH; PCL dest
Write PCL:
PCLATH PCH;
8-bit destination value PCL
Read-Modify-Write:
PCL ALU operand
PCLATH PCH;
8-bit result PCL
Byte to Byte move operations
15
13 12
8 7
OPCODE
p (FILE #)
ALUSTA AS DESTINATION
If an instruction writes to ALUSTA, the Z, C, DC and OV
bits may be set or cleared as a result of the instruction
and overwrite the original data bits written. For example, executing CLRF
ALUSTA will clear register
ALUSTA and then set the Z bit leaving 0000 0100b in
the register.
where h signifies a hexadecimal digit.
15
Special Function Registers as
Source/Destination
18.1.1
0xhh
FIGURE 18-1:
18.1
0
Where PCH = program counter high byte (not an
addressable register), PCLATH = Program counter
high holding latch, dest = destination, WREG or f.
f (FILE #)
p = peripheral register file address
f = 8-bit file register address
18.1.3
BIT MANIPULATION
Bit-oriented file register operations
15
OPCODE
11 10
8 7
b (BIT #)
0
f (FILE #)
b = 3-bit address
f = 8-bit file register address
Note:
Literal and control operations
15
8
7
OPCODE
All bit manipulation instructions are done by first reading the entire register, operating on the selected bit and
writing the result back (read-modify-write (R-M-W)).
The user should keep this in mind when operating on
some special function registers, such as ports.
0
k (literal)
k = 8-bit immediate value
Status bits that are manipulated by the
device (including the interrupt flag bits) are
set or cleared in the Q1 cycle. So, there is
no issue on doing R-M-W instructions on
registers which contain these bits
CALL and GOTO operations
15
13 12
OPCODE
0
k (literal)
k = 13-bit immediate value
DS30289C-page 198
1998-2013 Microchip Technology Inc.
PIC17C7XX
18.2
Q Cycle Activity
The four Q cycles that make up an instruction cycle
(TCY) can be generalized as:
Each instruction cycle (TCY) is comprised of four Q
cycles (Q1-Q4). The Q cycle is the same as the device
oscillator cycle (TOSC). The Q cycles provide the timing/
designation for the Decode, Read, Process Data,
Write, etc., of each instruction cycle. The following diagram shows the relationship of the Q cycles to the
instruction cycle.
Q1: Instruction Decode Cycle or forced No
operation
Q2: Instruction Read Cycle or No operation
Q3: Process the Data
Q4: Instruction Write Cycle or No operation
Each instruction will show the detailed Q cycle operation for the instruction.
FIGURE 18-2:
Q CYCLE ACTIVITY
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
TOSC
TCY1
1998-2013 Microchip Technology Inc.
TCY2
TCY3
DS30289C-page 199
PIC17C7XX
TABLE 18-2:
PIC17CXXX INSTRUCTION SET
16-bit Opcode
Mnemonic,
Operands
Description
Cycles
Status
Affected
MSb
LSb
0000
111d ffff ffff
OV,C,DC,Z
Notes
BYTE-ORIENTED FILE REGISTER OPERATIONS
ADDWF
f,d
ADD WREG to f
1
ADDWFC f,d
ADD WREG and Carry bit to f
1
0001
000d ffff ffff
OV,C,DC,Z
ANDWF
AND WREG with f
1
0000
101d ffff ffff
Z
f,d
CLRF
f,s
Clear f, or Clear f and Clear WREG
1
0010
100s ffff ffff
None
COMF
f,d
Complement f
1
0001
001d ffff ffff
Z
3
CPFSEQ
f
Compare f with WREG, skip if f = WREG
1 (2)
0011
0001 ffff ffff
None
6,8
CPFSGT
f
Compare f with WREG, skip if f > WREG
1 (2)
0011
0010 ffff ffff
None
2,6,8
1 (2)
0011
0000 ffff ffff
None
2,6,8
1
0010
111s ffff ffff
C
3
CPFSLT
f
Compare f with WREG, skip if f < WREG
DAW
f,s
Decimal Adjust WREG Register
DECF
f,d
Decrement f
1
0000
011d ffff ffff
OV,C,DC,Z
DECFSZ
f,d
Decrement f, skip if 0
1 (2)
0001
011d ffff ffff
None
6,8
1 (2)
0010
011d ffff ffff
None
6,8
1
0001
010d ffff ffff
OV,C,DC,Z
DCFSNZ
f,d
Decrement f, skip if not 0
INCF
f,d
Increment f
INCFSZ
f,d
Increment f, skip if 0
1 (2)
0001
111d ffff ffff
None
6,8
INFSNZ
f,d
Increment f, skip if not 0
1 (2)
0010
010d ffff ffff
None
6,8
IORWF
f,d
Inclusive OR WREG with f
1
0000
100d ffff ffff
Z
MOVFP
f,p
Move f to p
1
011p
pppp ffff ffff
None
MOVPF
p,f
Move p to f
1
010p
pppp ffff ffff
Z
MOVWF
f
Move WREG to f
1
0000
0001 ffff ffff
None
MULWF
f
Multiply WREG with f
1
0011
0100 ffff ffff
None
NEGW
f,s
Negate WREG
1
0010
110s ffff ffff
OV,C,DC,Z
NOP
—
No Operation
1
0000
0000 0000 0000
None
RLCF
f,d
Rotate left f through Carry
1
0001
101d ffff ffff
C
RLNCF
f,d
Rotate left f (no carry)
1
0010
001d ffff ffff
None
RRCF
f,d
Rotate right f through Carry
1
0001
100d ffff ffff
C
RRNCF
f,d
Rotate right f (no carry)
1
0010
000d ffff ffff
None
SETF
f,s
Set f
1
0010
101s ffff ffff
None
SUBWF
f,d
SUBWFB f,d
Subtract WREG from f
1
0000
010d ffff ffff
OV,C,DC,Z
1
1
0000
001d ffff ffff
OV,C,DC,Z
1
SWAPF
f,d
Swap f
t,i,f
Table Read
1
0001
110d ffff ffff
None
2 (3)
1010
10ti ffff ffff
None
7
5
TABLWT
t,i,f
Table Write
2
1010
11ti ffff ffff
None
TLRD
t,f
Table Latch Read
1
1010
00tx ffff ffff
None
Table Latch Write
1
1010
01tx ffff ffff
TLWT
t,f
4:
5:
6:
7:
8:
3
Subtract WREG from f with Borrow
TABLRD
Legend:
Note 1:
2:
3:
1,3
None
Refer to Table 18-1 for opcode field descriptions.
2’s Complement method.
Unsigned arithmetic.
If s = '1', only the file is affected: If s = '0', both the WREG register and the file are affected; If only the Working register
(WREG) is required to be affected, then f = WREG must be specified.
During an LCALL, the contents of PCLATH are loaded into the MSB of the PC and kkkk kkkk is loaded into the LSB of the
PC (PCL).
Multiple cycle instruction for EPROM programming when table pointer selects internal EPROM. The instruction is terminated by an interrupt event. When writing to external program memory, it is a two-cycle instruction.
Two-cycle instruction when condition is true, else single cycle instruction.
Two-cycle instruction except for TABLRD to PCL (program counter low byte), in which case it takes 3 cycles.
A “skip” means that instruction fetched during execution of current instruction is not executed, instead a NOP is executed.
DS30289C-page 200
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLE 18-2:
PIC17CXXX INSTRUCTION SET (CONTINUED)
16-bit Opcode
Mnemonic,
Operands
Description
Cycles
MSb
TSTFSZ
f
Test f, skip if 0
XORWF
f,d
Exclusive OR WREG with f
LSb
Status
Affected
1 (2)
0011
0011 ffff ffff
None
1
0000
110d ffff ffff
Z
1
1000
1bbb ffff ffff
None
Notes
6,8
BIT-ORIENTED FILE REGISTER OPERATIONS
BCF
f,b
Bit Clear f
BSF
f,b
Bit Set f
1
1000
0bbb ffff ffff
None
BTFSC
f,b
Bit test, skip if clear
1 (2)
1001
1bbb ffff ffff
None
6,8
1 (2)
1001
0bbb ffff ffff
None
6,8
1
0011
1bbb ffff ffff
None
1
1011
0001 kkkk kkkk
OV,C,DC,Z
BTFSS
f,b
Bit test, skip if set
BTG
f,b
Bit Toggle f
LITERAL AND CONTROL OPERATIONS
ADDLW
k
ADD literal to WREG
ANDLW
k
AND literal with WREG
1
1011
0101 kkkk kkkk
Z
CALL
k
Subroutine Call
2
111k
kkkk kkkk kkkk
None
CLRWDT
—
Clear Watchdog Timer
1
0000
0000 0000 0100
TO, PD
GOTO
k
Unconditional Branch
2
110k
kkkk kkkk kkkk
None
IORLW
k
Inclusive OR literal with WREG
1
1011
0011 kkkk kkkk
Z
LCALL
k
Long Call
2
1011
0111 kkkk kkkk
None
MOVLB
k
Move literal to low nibble in BSR
1
1011
1000 uuuu kkkk
None
MOVLR
k
Move literal to high nibble in BSR
1
1011
101x kkkk uuuu
None
MOVLW
k
Move literal to WREG
1
1011
0000 kkkk kkkk
None
MULLW
k
Multiply literal with WREG
1
1011
1100 kkkk kkkk
None
RETFIE
—
Return from interrupt (and enable interrupts)
2
0000
0000 0000 0101
GLINTD
7
7
4,7
7
RETLW
k
Return literal to WREG
2
1011
0110 kkkk kkkk
None
7
RETURN
—
Return from subroutine
2
0000
0000 0000 0010
None
7
SLEEP
—
Enter SLEEP mode
1
0000
0000 0000 0011
TO, PD
SUBLW
k
Subtract WREG from literal
1
1011
0010 kkkk kkkk
OV,C,DC,Z
XORLW
k
Exclusive OR literal with WREG
1
1011
0100 kkkk kkkk
Z
Legend:
Note 1:
2:
3:
4:
5:
6:
7:
8:
Refer to Table 18-1 for opcode field descriptions.
2’s Complement method.
Unsigned arithmetic.
If s = '1', only the file is affected: If s = '0', both the WREG register and the file are affected; If only the Working register
(WREG) is required to be affected, then f = WREG must be specified.
During an LCALL, the contents of PCLATH are loaded into the MSB of the PC and kkkk kkkk is loaded into the LSB of the
PC (PCL).
Multiple cycle instruction for EPROM programming when table pointer selects internal EPROM. The instruction is terminated by an interrupt event. When writing to external program memory, it is a two-cycle instruction.
Two-cycle instruction when condition is true, else single cycle instruction.
Two-cycle instruction except for TABLRD to PCL (program counter low byte), in which case it takes 3 cycles.
A “skip” means that instruction fetched during execution of current instruction is not executed, instead a NOP is executed.
1998-2013 Microchip Technology Inc.
DS30289C-page 201
PIC17C7XX
ADDLW
ADD Literal to WREG
ADDWF
ADD WREG to f
Syntax:
[ label ] ADDLW
Syntax:
[ label ] ADDWF
Operands:
0 k 255
Operands:
Operation:
(WREG) + k (WREG)
0 f 255
d [0,1]
Status Affected:
OV, C, DC, Z
Operation:
(WREG) + (f) (dest)
Status Affected:
OV, C, DC, Z
Encoding:
Description:
1011
0001
k
kkkk
kkkk
The contents of WREG are added to
the 8-bit literal 'k' and the result is
placed in WREG.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write to
WREG
Example:
ADDLW
Before Instruction
WREG = 0x10
After Instruction
WREG = 0x25
Encoding:
0000
111d
f,d
ffff
ffff
Description:
Add WREG to register 'f'. If 'd' is 0 the
result is stored in WREG. If 'd' is 1 the
result is stored back in register 'f'.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
0x15
Example:
ADDWF
REG, 0
Before Instruction
WREG
REG
=
=
0x17
0xC2
After Instruction
WREG
REG
DS30289C-page 202
=
=
0xD9
0xC2
1998-2013 Microchip Technology Inc.
PIC17C7XX
ADDWFC
ADD WREG and Carry bit to f
ANDLW
And Literal with WREG
Syntax:
[ label ] ADDWFC
Syntax:
[ label ] ANDLW
Operands:
0 f 255
d [0,1]
f,d
Operation:
(WREG) + (f) + C (dest)
Status Affected:
OV, C, DC, Z
Encoding:
0001
Description:
ffff
ffff
Add WREG, the Carry Flag and data
memory location 'f'. If 'd' is 0, the result is
placed in WREG. If 'd' is 1, the result is
placed in data memory location 'f'.
Words:
1
Cycles:
1
Operands:
0 k 255
Operation:
(WREG) .AND. (k) (WREG)
Status Affected:
Z
Encoding:
000d
1011
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
kkkk
kkkk
Description:
Words:
1
Cycles:
1
Q1
Q2
Q3
Q4
Decode
Read literal
'k'
Process
Data
Write to
WREG
Example:
ADDWFC
REG
Before Instruction
Carry bit =
REG
=
WREG =
0101
The contents of WREG are AND’ed with
the 8-bit literal 'k'. The result is placed in
WREG.
Q Cycle Activity:
Q Cycle Activity:
Example:
k
1
0x02
0x4D
0
ANDLW
0x5F
Before Instruction
WREG
=
0xA3
After Instruction
WREG
=
0x03
After Instruction
Carry bit =
REG
=
WREG =
0
0x02
0x50
1998-2013 Microchip Technology Inc.
DS30289C-page 203
PIC17C7XX
ANDWF
AND WREG with f
BCF
Bit Clear f
Syntax:
[ label ] ANDWF
Syntax:
[ label ] BCF
Operands:
0 f 255
d [0,1]
Operands:
0 f 255
0b7
Operation:
(WREG) .AND. (f) (dest)
Operation:
0 (f)
Status Affected:
Z
Status Affected:
None
Encoding:
0000
Description:
101d
f,d
ffff
ffff
Encoding:
1000
f,b
1bbb
ffff
ffff
The contents of WREG are AND’ed with
register 'f'. If 'd' is 0 the result is stored
in WREG. If 'd' is 1 the result is stored
back in register 'f'.
Description:
Bit 'b' in register 'f' is cleared.
Words:
1
Cycles:
1
Words:
1
Q Cycle Activity:
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register 'f'
Example:
BCF
FLAG_REG,
7
Before Instruction
Example:
ANDWF
=
=
FLAG_REG = 0xC7
After Instruction
Before Instruction
WREG
REG
REG, 1
0x17
0xC2
FLAG_REG = 0x47
After Instruction
WREG
REG
=
=
DS30289C-page 204
0x17
0x02
1998-2013 Microchip Technology Inc.
PIC17C7XX
BSF
Bit Set f
BTFSC
Bit Test, skip if Clear
Syntax:
[ label ] BSF
Syntax:
[ label ] BTFSC f,b
Operands:
0 f 255
0b7
Operands:
0 f 255
0b7
Operation:
1 (f)
Operation:
skip if (f) = 0
Status Affected:
None
Status Affected:
None
Encoding:
1000
f,b
0bbb
ffff
Description:
Bit 'b' in register 'f' is set.
Words:
1
Cycles:
1
ffff
Encoding:
Description:
Q1
Q2
Q3
Q4
Read
register 'f'
Process
Data
Write
register 'f'
Example:
1bbb
ffff
ffff
If bit 'b' in register ’f' is 0, then the next
instruction is skipped.
If bit 'b' is 0, then the next instruction
fetched during the current instruction execution is discarded and a NOP is executed
instead, making this a two-cycle
instruction.
Q Cycle Activity:
Decode
1001
Words:
1
Cycles:
1(2)
Q Cycle Activity:
BSF
FLAG_REG, 7
Before Instruction
FLAG_REG
=
0x0A
=
0x8A
After Instruction
FLAG_REG
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
No
operation
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
If skip:
Example:
HERE
FALSE
TRUE
BTFSC
:
:
FLAG,1
Before Instruction
PC
=
address (HERE)
=
=
=
=
0;
address (TRUE)
1;
address (FALSE)
After Instruction
If FLAG
PC
If FLAG
PC
1998-2013 Microchip Technology Inc.
DS30289C-page 205
PIC17C7XX
BTFSS
Bit Test, skip if Set
BTG
Bit Toggle f
Syntax:
[ label ] BTFSS f,b
Syntax:
[ label ] BTG f,b
Operands:
0 f 127
0b WREG
ffff
ffff
Compares the contents of data memory
location 'f' to the contents of WREG by
performing an unsigned subtraction.
Encoding:
Description:
If 'f' = WREG, then the fetched instruction is discarded and a NOP is executed
instead, making this a two-cycle
instruction.
Words:
1
Cycles:
1 (2)
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
No
operation
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
HERE
NEQUAL
EQUAL
CPFSEQ REG
:
:
=
=
=
HERE
?
?
=
=
=
WREG;
Address (EQUAL)
WREG;
Address (NEQUAL)
After Instruction
If REG
PC
If REG
PC
ffff
ffff
Compares the contents of data memory
location 'f' to the contents of the WREG
by performing an unsigned subtraction.
Words:
1
Cycles:
1 (2)
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
No
operation
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
HERE
NGREATER
GREATER
CPFSGT REG
:
:
If skip:
Example:
Before Instruction
PC Address
WREG
REG
0010
If the contents of 'f' are greater than the
contents of WREG, then the fetched
instruction is discarded and a NOP is
executed instead, making this a
two-cycle instruction.
If skip:
Example:
0011
f
Before Instruction
PC
WREG
=
=
Address (HERE)
?
>
=
£
=
WREG;
Address (GREATER)
WREG;
Address (NGREATER)
After Instruction
1998-2013 Microchip Technology Inc.
If REG
PC
If REG
PC
DS30289C-page 209
PIC17C7XX
CPFSLT
Compare f with WREG,
skip if f < WREG
DAW
Syntax:
[ label ] CPFSLT
Syntax:
[label] DAW
Operands:
0 f 255
Operands:
Operation:
(f) –WREG),
skip if (f) < (WREG)
(unsigned comparison)
0 f 255
s [0,1]
Operation:
If [ [WREG > 9].OR.[C = 1] ].AND.
[WREG > 9]
then
WREG + 7 f, s;
Status Affected:
None
Encoding:
Description:
f
Decimal Adjust WREG Register
0011
0000
ffff
ffff
If [WREG > 9].OR.[C = 1]
then
WREG + 6 f, s;
else
WREG f, s;
Compares the contents of data memory
location 'f' to the contents of WREG by
performing an unsigned subtraction.
If the contents of 'f' are less than the
contents of WREG, then the fetched
instruction is discarded and a NOP is
executed instead, making this a
two-cycle instruction.
Words:
1
Cycles:
1 (2)
If [WREG > 9].OR.[DC = 1]
then
WREG + 6 f, s;
else
WREG f, s
Status Affected:
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
No
operation
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
C
Encoding:
0010
Description:
111s
s = 1:
HERE
NLESS
LESS
CPFSLT REG
:
:
Before Instruction
PC
W
ffff
Words:
1
Cycles:
1
Result is placed in Data
memory location 'f'.
Q Cycle Activity:
=
=
Address (HERE)
?
<
=
=
WREG;
Address (LESS)
WREG;
Address (NLESS)
After Instruction
If REG
PC
If REG
PC
ffff
DAW adjusts the eight-bit value in
WREG, resulting from the earlier addition of two variables (each in packed
BCD format) and produces a correct
packed BCD result.
s = 0: Result is placed in Data
memory location 'f' and
WREG.
If skip:
Example:
f,s
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register 'f'
and other
specified
register
Example:
DAW
REG1, 0
Before Instruction
WREG
REG1
C
DC
=
=
=
=
0xA5
??
0
0
After Instruction
WREG
REG1
C
DC
DS30289C-page 210
=
=
=
=
0x05
0x05
1
0
1998-2013 Microchip Technology Inc.
PIC17C7XX
DECF
Decrement f
DECFSZ
Decrement f, skip if 0
Syntax:
[ label ] DECF f,d
Syntax:
[ label ] DECFSZ f,d
Operands:
0 f 255
d [0,1]
Operands:
0 f 255
d [0,1]
Operation:
(f) – 1 (dest)
Operation:
Status Affected:
OV, C, DC, Z
(f) – 1 (dest);
skip if result = 0
Status Affected:
None
Encoding:
0000
Description:
011d
ffff
ffff
Decrement register 'f'. If 'd' is 0, the
result is stored in WREG. If 'd' is 1, the
result is stored back in register 'f'.
Words:
1
Cycles:
1
Encoding:
0001
Description:
Q1
Q2
Q3
Q4
Read
register 'f'
Process
Data
Write to
destination
Example:
DECF
CNT,
1
=
=
Words:
1
Cycles:
1(2)
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
HERE
DECFSZ
GOTO
0x01
0
If skip:
After Instruction
CNT
Z
=
=
ffff
If the result is 0, the next instruction,
which is already fetched is discarded
and a NOP is executed instead, making
it a two-cycle instruction.
Before Instruction
CNT
Z
ffff
The contents of register 'f' are decremented. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is placed
back in register 'f'.
Q Cycle Activity:
Decode
011d
0x00
1
Example:
CNT, 1
HERE
NZERO
ZERO
Before Instruction
PC
=
Address (HERE)
After Instruction
CNT
If CNT
PC
If CNT
PC
1998-2013 Microchip Technology Inc.
=
=
=
=
CNT - 1
0;
Address (HERE)
0;
Address (NZERO)
DS30289C-page 211
PIC17C7XX
DCFSNZ
Decrement f, skip if not 0
GOTO
Unconditional Branch
Syntax:
[label] DCFSNZ f,d
Syntax:
[ label ]
Operands:
0 f 255
d [0,1]
Operands:
0 k 8191
Operation:
k PC;
k PCLATH,
PC:13> PCLATH
Status Affected:
None
Operation:
(f) – 1 (dest);
skip if not 0
Status Affected:
None
Encoding:
Description:
0010
011d
ffff
ffff
The contents of register 'f' are decremented. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is placed
back in register 'f'.
Encoding:
Description:
110k
Words:
1
Words:
1
Cycles:
2
Cycles:
1(2)
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
If skip:
HERE
ZERO
NZERO
DCFSNZ
:
:
kkkk
kkkk
Q1
Q2
Q3
Q4
Decode
Read literal
'k'
Process
Data
Write to PC
No
operation
No
operation
No
operation
No
operation
Example:
GOTO THERE
After Instruction
PC =
Example:
kkkk
GOTO allows an unconditional branch
anywhere within an 8K page boundary.
The thirteen-bit immediate value is
loaded into PC bits . Then the
upper eight bits of PC are loaded into
PCLATH. GOTO is always a two-cycle
instruction.
If the result is not 0, the next instruction, which is already fetched is discarded and a NOP is executed instead,
making it a two-cycle instruction.
Q Cycle Activity:
GOTO k
Address (THERE)
TEMP, 1
Before Instruction
TEMP_VALUE
=
?
=
=
=
=
TEMP_VALUE - 1,
0;
Address (ZERO)
0;
Address (NZERO)
After Instruction
TEMP_VALUE
If TEMP_VALUE
PC
If TEMP_VALUE
PC
DS30289C-page 212
1998-2013 Microchip Technology Inc.
PIC17C7XX
INCF
Increment f
INCFSZ
Increment f, skip if 0
Syntax:
[ label ]
Syntax:
[ label ]
Operands:
0 f 255
d [0,1]
Operands:
0 f 255
d [0,1]
Operation:
(f) + 1 (dest)
Operation:
Status Affected:
OV, C, DC, Z
(f) + 1 (dest)
skip if result = 0
Status Affected:
None
Encoding:
0001
Description:
INCF f,d
010d
ffff
ffff
The contents of register 'f' are incremented. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is placed
back in register 'f'.
Words:
1
Cycles:
1
Encoding:
0001
Description:
Q1
Q2
Q3
Q4
Read
register 'f'
Process
Data
Write to
destination
111d
ffff
ffff
The contents of register 'f' are incremented. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is placed
back in register 'f'.
If the result is 0, the next instruction,
which is already fetched is discarded
and a NOP is executed instead, making
it a two-cycle instruction.
Q Cycle Activity:
Decode
INCFSZ f,d
Words:
1
Cycles:
1(2)
Q Cycle Activity:
Example:
INCF
CNT, 1
Before Instruction
CNT
Z
C
=
=
=
0xFF
0
?
After Instruction
CNT
Z
C
=
=
=
0x00
1
1
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
If skip:
Example:
HERE
NZERO
ZERO
INCFSZ
:
:
CNT, 1
Before Instruction
PC
=
Address (HERE)
After Instruction
CNT
If CNT
PC
If CNT
PC
1998-2013 Microchip Technology Inc.
=
=
=
=
CNT + 1
0;
Address(ZERO)
0;
Address(NZERO)
DS30289C-page 213
PIC17C7XX
INFSNZ
Increment f, skip if not 0
IORLW
Inclusive OR Literal with WREG
Syntax:
[label]
Syntax:
[ label ]
Operands:
0 f 255
d [0,1]
Operands:
0 k 255
Operation:
Operation:
(f) + 1 (dest),
skip if not 0
(WREG) .OR. (k) (WREG)
Status Affected:
Z
Status Affected:
None
Encoding:
0010
Description:
INFSNZ f,d
Encoding:
010d
ffff
ffff
The contents of register 'f' are incremented. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is placed
back in register 'f'.
If the result is not 0, the next instruction,
which is already fetched is discarded
and a NOP is executed instead, making
it a two-cycle instruction.
Words:
1
Cycles:
1(2)
1011
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
0011
kkkk
kkkk
Description:
The contents of WREG are OR’ed with
the eight-bit literal 'k'. The result is
placed in WREG.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write to
WREG
Example:
Q Cycle Activity:
IORLW k
IORLW
0x35
Before Instruction
WREG
=
0x9A
After Instruction
WREG
=
0xBF
If skip:
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
Example:
HERE
ZERO
NZERO
INFSNZ
REG, 1
Before Instruction
REG
=
REG
After Instruction
REG
If REG
PC
If REG
PC
=
=
=
=
=
DS30289C-page 214
REG + 1
1;
Address (ZERO)
0;
Address (NZERO)
1998-2013 Microchip Technology Inc.
PIC17C7XX
IORWF
Inclusive OR WREG with f
LCALL
Long Call
Syntax:
[ label ]
Syntax:
[ label ]
Operands:
0 f 255
d [0,1]
IORWF
f,d
Operation:
(WREG) .OR. (f) (dest)
Status Affected:
Z
Encoding:
0000
100d
ffff
ffff
Description:
Inclusive OR WREG with register 'f'. If
'd' is 0, the result is placed in WREG. If
'd' is 1, the result is placed back in
register 'f'.
Words:
1
Cycles:
1
Q1
Q2
Q3
Q4
Read
register 'f'
Process
Data
Write to
destination
Example:
IORWF
RESULT, 0
Before Instruction
RESULT =
WREG =
0x13
0x91
After Instruction
RESULT =
WREG =
0x13
0x93
k
Operands:
0 k 255
Operation:
PC + 1 TOS;
k PCL, (PCLATH) PCH
Status Affected:
None
Encoding:
Description:
1011
0111
kkkk
kkkk
LCALL allows an unconditional subroutine call to anywhere within the 64K
program memory space.
First, the return address (PC + 1) is
pushed onto the stack. A 16-bit destination address is then loaded into the
program counter. The lower 8-bits of
the destination address are embedded
in the instruction. The upper 8-bits of
PC are loaded from PC high holding
latch, PCLATH.
Q Cycle Activity:
Decode
LCALL
Words:
1
Cycles:
2
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write
register PCL
No
operation
No
operation
No
operation
No
operation
Example:
MOVLW
MOVPF
LCALL
HIGH(SUBROUTINE)
WREG, PCLATH
LOW(SUBROUTINE)
Before Instruction
SUBROUTINE =
PC
=
16-bit Address
?
After Instruction
PC
1998-2013 Microchip Technology Inc.
=
Address (SUBROUTINE)
DS30289C-page 215
PIC17C7XX
MOVFP
Move f to p
MOVLB
Move Literal to low nibble in BSR
Syntax:
[label]
Syntax:
[ label ]
Operands:
0 f 255
0 p 31
Operands:
0 k 15
Operation:
k (BSR)
Status Affected:
None
MOVFP f,p
Operation:
(f) (p)
Status Affected:
None
Encoding:
Description:
Encoding:
011p
pppp
ffff
ffff
Description:
Move data from data memory location 'f'
to data memory location 'p'. Location 'f'
can be anywhere in the 256 byte data
space (00h to FFh), while 'p' can be 00h
to 1Fh.
Either ’p' or 'f' can be WREG (a useful,
special situation).
MOVFP is particularly useful for transferring a data memory location to a peripheral register (such as the transmit buffer
or an I/O port). Both 'f' and 'p' can be
indirectly addressed.
Words:
1
Cycles:
1
Q Cycle Activity:
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register 'p'
1011
1
Cycles:
1
MOVFP
uuuu
kkkk
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write literal
'k' to
BSR
MOVLB
5
Before Instruction
BSR register
=
0x22
=
0x25 (Bank 5)
After Instruction
BSR register
Example:
1000
The four-bit literal 'k' is loaded in the
Bank Select Register (BSR). Only the
low 4-bits of the Bank Select Register
are affected. The upper half of the BSR
is unchanged. The assembler will
encode the “u” fields as '0'.
Words:
Example:
Q1
MOVLB k
REG1, REG2
Before Instruction
REG1
REG2
=
=
0x33,
0x11
=
=
0x33,
0x33
After Instruction
REG1
REG2
DS30289C-page 216
1998-2013 Microchip Technology Inc.
PIC17C7XX
Move Literal to high nibble in
BSR
MOVLW
Syntax:
[ label ]
Syntax:
[ label ]
Operands:
0 k 15
Operands:
0 k 255
Operation:
k (BSR)
Operation:
k (WREG)
Status Affected:
None
Status Affected:
None
MOVLR
Encoding:
Description:
MOVLR k
1011
101x
kkkk
uuuu
The 4-bit literal 'k' is loaded into the
most significant 4-bits of the Bank
Select Register (BSR). Only the high
4-bits of the Bank Select Register
are affected. The lower half of the
BSR is unchanged. The assembler
will encode the “u” fields as 0.
Words:
1
Cycles:
1
Move Literal to WREG
Encoding:
1011
MOVLW k
0000
kkkk
kkkk
Description:
The eight-bit literal 'k' is loaded into
WREG.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write to
WREG
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read literal
'k'
Process
Data
Write
literal 'k' to
BSR
Example:
MOVLR
Example:
MOVLW
0x5A
After Instruction
WREG
=
0x5A
5
Before Instruction
BSR register
=
0x22
=
0x52
After Instruction
BSR register
1998-2013 Microchip Technology Inc.
DS30289C-page 217
PIC17C7XX
MOVPF
Move p to f
MOVWF
Move WREG to f
Syntax:
[label]
Syntax:
[ label ]
Operands:
0 f 255
0 p 31
Operands:
0 f 255
Operation:
(WREG) (f)
Status Affected:
None
MOVPF p,f
Operation:
(p) (f)
Status Affected:
Z
Encoding:
Encoding:
010p
Description:
pppp
ffff
ffff
Move data from data memory location
'p' to data memory location 'f'. Location
'f' can be anywhere in the 256 byte data
space (00h to FFh), while 'p' can be 00h
to 1Fh.
Either 'p' or 'f' can be WREG (a useful,
special situation).
MOVPF is particularly useful for transferring a peripheral register (e.g. the timer
or an I/O port) to a data memory location. Both 'f' and 'p' can be indirectly
addressed.
Words:
1
Cycles:
1
0000
0001
f
ffff
ffff
Description:
Move data from WREG to register 'f'.
Location 'f' can be anywhere in the 256
byte data space.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register 'f'
Example:
MOVWF
REG
Before Instruction
WREG
REG
Q Cycle Activity:
=
=
Q1
Q2
Q3
Q4
After Instruction
Decode
Read
register 'p'
Process
Data
Write
register 'f'
WREG
REG
Example:
MOVWF
MOVPF
=
=
0x4F
0xFF
0x4F
0x4F
REG1, REG2
Before Instruction
REG1
REG2
=
=
0x11
0x33
=
=
0x11
0x11
After Instruction
REG1
REG2
DS30289C-page 218
1998-2013 Microchip Technology Inc.
PIC17C7XX
MULLW
Multiply Literal with WREG
MULWF
Multiply WREG with f
Syntax:
[ label ]
Syntax:
[ label ]
Operands:
0 k 255
Operands:
0 f 255
Operation:
(k x WREG) PRODH:PRODL
Operation:
(WREG x f) PRODH:PRODL
Status Affected:
None
Status Affected:
None
Encoding:
Description:
1011
MULLW
1100
k
kkkk
kkkk
An unsigned multiplication is carried
out between the contents of WREG
and the 8-bit literal 'k'. The 16-bit
result is placed in PRODH:PRODL
register pair. PRODH contains the
high byte.
Encoding:
Description:
0011
MULWF
0100
f
ffff
ffff
An unsigned multiplication is carried
out between the contents of WREG
and the register file location 'f'. The
16-bit result is stored in the
PRODH:PRODL register pair.
PRODH contains the high byte.
WREG is unchanged.
Both WREG and 'f' are unchanged.
None of the status flags are affected.
None of the status flags are affected.
Note that neither overflow, nor carry
is possible in this operation. A zero
result is possible, but not detected.
Note that neither overflow, nor carry
is possible in this operation. A zero
result is possible, but not detected.
Words:
1
Words:
1
Cycles:
1
Cycles:
1
Q Cycle Activity:
Q Cycle Activity:
Q1
Q2
Q3
Q4
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write
registers
PRODH:
PRODL
Decode
Read
register 'f'
Process
Data
Write
registers
PRODH:
PRODL
Example:
MULLW
0xC4
Before Instruction
WREG
PRODH
PRODL
MULWF
REG
Before Instruction
=
=
=
0xE2
?
?
WREG
REG
PRODH
PRODL
=
=
=
0xC4
0xAD
0x08
After Instruction
After Instruction
WREG
PRODH
PRODL
Example:
1998-2013 Microchip Technology Inc.
WREG
REG
PRODH
PRODL
=
=
=
=
0xC4
0xB5
?
?
=
=
=
=
0xC4
0xB5
0x8A
0x94
DS30289C-page 219
PIC17C7XX
NEGW
Negate W
Syntax:
[label]
Operands:
0 f 255
s [0,1]
Operands:
None
Operation:
No operation
Operation:
WREG + 1 (f);
WREG + 1 s
Status Affected:
None
Status Affected:
OV, C, DC, Z
Encoding:
0010
Description:
NEGW
110s
f,s
1
Cycles:
1
ffff
ffff
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register 'f'
and other
specified
register
Example:
NEGW
No Operation
Syntax:
[ label ]
Encoding:
WREG is negated using two’s complement. If 's' is 0, the result is placed in
WREG and data memory location 'f'. If
's' is 1, the result is placed only in data
memory location 'f'.
Words:
NOP
0000
NOP
0000
Description:
No operation.
Words:
1
Cycles:
1
0000
0000
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
No
operation
No
operation
No
operation
Example:
None.
REG,0
Before Instruction
WREG
REG
=
=
0011 1010 [0x3A],
1010 1011 [0xAB]
After Instruction
WREG
REG
=
=
DS30289C-page 220
1100 0110 [0xC6]
1100 0110 [0xC6]
1998-2013 Microchip Technology Inc.
PIC17C7XX
RETFIE
Return from Interrupt
RETLW
Return Literal to WREG
Syntax:
[ label ]
Syntax:
[ label ]
RETFIE
RETLW k
Operands:
None
Operands:
0 k 255
Operation:
TOS (PC);
0 GLINTD;
PCLATH is unchanged.
Operation:
k (WREG); TOS (PC);
PCLATH is unchanged
Status Affected:
None
Status Affected:
GLINTD
Encoding:
0000
Encoding:
0000
0000
0101
1
Cycles:
2
1
Cycles:
2
Q Cycle Activity:
Q3
Q4
Decode
No
operation
Clear
GLINTD
POP PC
from stack
No
operation
No
operation
No
operation
No
operation
Example:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
POP PC
from stack,
Write to
WREG
No
operation
No
operation
No
operation
No
operation
RETFIE
Example:
After Interrupt
PC
=
GLINTD =
kkkk
Words:
Words:
Q2
kkkk
WREG is loaded with the eight-bit literal
'k'. The program counter is loaded from
the top of the stack (the return address).
The high address latch (PCLATH)
remains unchanged.
Return from Interrupt. Stack is POP’ed
and Top-of-Stack (TOS) is loaded in the
PC. Interrupts are enabled by clearing
the GLINTD bit. GLINTD is the global
interrupt disable bit (CPUSTA).
Q1
0110
Description:
Description:
Q Cycle Activity:
1011
CALL TABLE ;
;
;
;
:
TABLE
ADDWF PC
;
RETLW k0
;
RETLW k1
;
:
:
RETLW kn
;
TOS
0
WREG contains table
offset value
WREG now has
table value
WREG = offset
Begin table
End of table
Before Instruction
WREG
=
0x07
After Instruction
WREG
1998-2013 Microchip Technology Inc.
=
value of k7
DS30289C-page 221
PIC17C7XX
RETURN
Return from Subroutine
RLCF
Rotate Left f through Carry
Syntax:
[ label ]
Syntax:
[ label ] RLCF
Operands:
0 f 255
d [0,1]
Operation:
f d;
f C;
C d
Return from subroutine. The stack is
popped and the top of the stack (TOS)
is loaded into the program counter.
Status Affected:
C
Words:
1
Description:
Cycles:
2
RETURN
Operands:
None
Operation:
TOS PC;
Status Affected:
None
Encoding:
Description:
0000
0000
0000
0010
Encoding:
0001
Q1
Q2
Q3
Q4
No
operation
Process
Data
POP PC
from stack
No
operation
No
operation
No
operation
No
operation
101d
ffff
ffff
The contents of register 'f' are rotated
one bit to the left through the Carry
Flag. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is stored
back in register 'f'.
Q Cycle Activity:
Decode
f,d
register f
C
Words:
1
Cycles:
1
Q Cycle Activity:
Example:
RETURN
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
After Interrupt
PC = TOS
Example:
RLCF
REG,0
Before Instruction
REG
C
=
=
1110 0110
0
After Instruction
REG
WREG
C
DS30289C-page 222
=
=
=
1110 0110
1100 1100
1
1998-2013 Microchip Technology Inc.
PIC17C7XX
RLNCF
Rotate Left f (no carry)
RRCF
Rotate Right f through Carry
Syntax:
[ label ] RLNCF
Syntax:
[ label ]
Operands:
0 f 255
d [0,1]
Operands:
0 f 255
d [0,1]
Operation:
f d;
f d
Operation:
Status Affected:
None
f d;
f C;
C d
Status Affected:
C
Encoding:
0010
Description:
001d
f,d
ffff
ffff
The contents of register 'f' are rotated
one bit to the left. If 'd' is 0, the result is
placed in WREG. If 'd' is 1, the result is
stored back in register 'f'.
Encoding:
0001
Description:
1
Cycles:
1
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
RLNCF
=
=
0
1110 1011
=
=
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Example:
1101 0111
=
=
1110 0110
0
After Instruction
REG1
WREG
C
1998-2013 Microchip Technology Inc.
RRCF REG1,0
Before Instruction
REG1
C
After Instruction
C
REG
ffff
REG, 1
Before Instruction
C
REG
ffff
register f
C
Q Cycle Activity:
Example:
100d
The contents of register 'f' are rotated
one bit to the right through the Carry
Flag. If 'd' is 0, the result is placed in
WREG. If 'd' is 1, the result is placed
back in register 'f'.
register f
Words:
RRCF f,d
=
=
=
1110 0110
0111 0011
0
DS30289C-page 223
PIC17C7XX
RRNCF
Rotate Right f (no carry)
SETF
Set f
Syntax:
[ label ]
Syntax:
[ label ]
Operands:
0 f 255
d [0,1]
Operands:
0 f 255
s [0,1]
Operation:
f d;
f d
Operation:
FFh f;
FFh d
Status Affected:
None
Status Affected:
None
Encoding:
0010
Description:
RRNCF f,d
000d
ffff
ffff
The contents of register 'f' are rotated
one bit to the right. If 'd' is 0, the result is
placed in WREG. If 'd' is 1, the result is
placed back in register 'f'.
register f
Words:
1
Cycles:
1
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
RRNCF
REG, 1
Before Instruction
WREG
REG
=
=
?
1101 0111
After Instruction
WREG
REG
=
=
Example 2:
0
1110 1011
RRNCF
REG, 0
=
=
?
1101 0111
After Instruction
WREG
REG
=
=
DS30289C-page 224
101s
ffff
ffff
Description:
If 's' is 0, both the data memory location
'f' and WREG are set to FFh. If 's' is 1,
only the data memory location 'f' is set
to FFh.
Words:
1
Cycles:
1
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register 'f'
and other
specified
register
Example1:
SETF
REG, 0
Before Instruction
REG
WREG
=
=
0xDA
0x05
After Instruction
REG
WREG
Example2:
=
0xFF
=
0xFF
SETF
REG, 1
Before Instruction
Before Instruction
WREG
REG
0010
Q Cycle Activity:
Q Cycle Activity:
Example 1:
Encoding:
SETF f,s
1110 1011
1101 0111
REG
WREG
=
=
0xDA
0x05
After Instruction
REG
WREG
=
=
0xFF
0x05
1998-2013 Microchip Technology Inc.
PIC17C7XX
SLEEP
Enter SLEEP mode
Syntax:
[ label ] SLEEP
SUBLW
Syntax:
Operands:
None
Operands:
0 k 255
Operation:
00h WDT;
0 WDT postscaler;
1 TO;
0 PD
Operation:
k – (WREG) WREG)
Status Affected:
OV, C, DC, Z
TO, PD
Description:
WREG is subtracted from the eight-bit
literal 'k'. The result is placed in
WREG.
Words:
1
Cycles:
1
Status Affected:
Encoding:
0000
Description:
0000
0000
Encoding:
The processor is put into SLEEP
mode with the oscillator stopped.
1
Cycles:
1
1011
0011
The power-down status bit (PD) is
cleared. The time-out status bit (TO) is
set. Watchdog Timer and its postscaler are cleared.
Words:
Subtract WREG from Literal
[ label ] SUBLW k
Q1
Q2
Q3
Q4
Decode
No
operation
Process
Data
Go to
sleep
kkkk
kkkk
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write to
WREG
Example 1:
Q Cycle Activity:
0010
SUBLW
0x02
Before Instruction
WREG
C
=
=
1
?
After Instruction
Example:
SLEEP
Before Instruction
TO =
PD =
?
?
After Instruction
TO =
PD =
1†
0
† If WDT causes wake-up, this bit is cleared
WREG
C
Z
=
=
=
1
1
0
; result is positive
Example 2:
Before Instruction
WREG
C
=
=
2
?
After Instruction
WREG
C
Z
=
=
=
0
1
1
; result is zero
Example 3:
Before Instruction
WREG
C
=
=
3
?
After Instruction
WREG
C
Z
1998-2013 Microchip Technology Inc.
=
=
=
FF ; (2’s complement)
0
; result is negative
0
DS30289C-page 225
PIC17C7XX
Subtract WREG from f with
Borrow
[ label ] SUBWFB f,d
SUBWFB
SUBWF
Syntax:
Subtract WREG from f
[ label ] SUBWF f,d
Operands:
0 f 255
d [0,1]
Operands:
0 f 255
d [0,1]
Operation:
(f) – (W) dest)
Operation:
(f) – (W) – C dest)
Status Affected:
OV, C, DC, Z
Status Affected:
OV, C, DC, Z
Encoding:
0000
Description:
010d
ffff
Syntax:
ffff
Subtract WREG from register 'f' (2’s
complement method). If 'd' is 0, the
result is stored in WREG. If 'd' is 1, the
result is stored back in register 'f'.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Example 1:
SUBWF
REG1, 1
Before Instruction
REG1
WREG
C
=
=
=
=
=
=
=
1
2
1
0
; result is positive
=
=
=
=
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Example 1:
REG1
WREG
C
Z
; result is zero
REG1
WREG
C
Z
Example3:
=
=
=
DS30289C-page 226
FF
2
0
0
REG1, 1
=
=
=
0x19
0x0D
1
(0001 1001)
(0000 1101)
=
=
=
=
0x0C
0x0D
1
0
(0000 1011)
(0000 1101)
; result is positive
SUBWFB
REG1,0
=
=
=
0x1B
0x1A
0
(0001 1011)
(0001 1010)
=
=
=
=
0x1B
0x00
1
1
(0001 1011)
SUBWFB
; result is zero
REG1,1
Before Instruction
1
2
?
REG1
WREG
C
After Instruction
=
=
=
=
SUBWFB
After Instruction
Before Instruction
REG1
WREG
C
Z
1
Q Cycle Activity:
REG1
WREG
C
Example 3:
REG1
WREG
C
Cycles:
Before Instruction
2
2
?
0
2
1
1
ffff
1
Example2:
After Instruction
REG1
WREG
C
Z
ffff
After Instruction
Before Instruction
=
=
=
001d
Words:
REG1
WREG
C
Example 2:
REG1
WREG
C
0000
Subtract WREG and the carry flag
(borrow) from register 'f' (2’s complement method). If 'd' is 0, the result is
stored in WREG. If 'd' is 1, the result is
stored back in register 'f'.
Before Instruction
3
2
?
After Instruction
REG1
WREG
C
Z
Encoding:
Description:
=
=
=
0x03
0x0E
1
(0000 0011)
(0000 1101)
0xF5
0x0E
0
0
(1111 0100) [2’s comp]
(0000 1101)
; result is negative
After Instruction
; result is negative
REG1
WREG
C
Z
=
=
=
=
1998-2013 Microchip Technology Inc.
PIC17C7XX
SWAPF
Swap f
TABLRD
Table Read
Syntax:
[ label ] SWAPF f,d
Syntax:
[ label ] TABLRD t,i,f
Operands:
0 f 255
d [0,1]
Operands:
Operation:
f dest;
f dest
0 f 255
i [0,1]
t [0,1]
Operation:
If t = 1,
TBLATH f;
If t = 0,
TBLATL f;
Prog Mem (TBLPTR) TBLAT;
If i = 1,
TBLPTR + 1 TBLPTR
If i = 0,
TBLPTR is unchanged
Status Affected:
None
Status Affected:
None
Encoding:
0001
110d
ffff
ffff
Description:
The upper and lower nibbles of register
'f' are exchanged. If 'd' is 0, the result is
placed in WREG. If 'd' is 1, the result is
placed in register 'f'.
Words:
1
Cycles:
1
Q Cycle Activity:
Encoding:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
Example:
SWAPF
REG,
1010
Description:
=
REG
=
ffff
A byte of the table latch (TBLAT)
is moved to register file 'f'.
If t = 1: the high byte is moved;
If t = 0: the low byte is moved.
2.
Then, the contents of the program memory location pointed to
by the 16-bit Table Pointer
(TBLPTR) are loaded into the
16-bit Table Latch (TBLAT).
3.
If i = 1: TBLPTR is incremented;
If i = 0: TBLPTR is not
incremented.
0
0x53
After Instruction
ffff
1.
Before Instruction
REG
10ti
0x35
Words:
1
Cycles:
2 (3-cycle if f = PCL)
Q Cycle Activity:
1998-2013 Microchip Technology Inc.
Q1
Q2
Q3
Q4
Decode
Read
register
TBLATH or
TBLATL
Process
Data
Write
register 'f'
No
operation
No
operation
(Table Pointer
on Address
bus)
No
operation
No
operation
(OE goes low)
DS30289C-page 227
PIC17C7XX
TABLRD
Table Read
TABLWT
Table Write
Example1:
TABLRD
Syntax:
[ label ] TABLWT t,i,f
Operands:
0 f 255
i [0,1]
t [0,1]
Operation:
If t = 0,
f TBLATL;
If t = 1,
f TBLATH;
TBLAT Prog Mem (TBLPTR);
If i = 1,
TBLPTR + 1 TBLPTR
If i = 0,
TBLPTR is unchanged
Status Affected:
None
1, 1, REG ;
Before Instruction
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
=
=
=
=
=
0x53
0xAA
0x55
0xA356
0x1234
After Instruction (table write completion)
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
Example2:
TABLRD
=
=
=
=
=
0xAA
0x12
0x34
0xA357
0x5678
0, 0, REG ;
Before Instruction
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
=
=
=
=
=
0x53
0xAA
0x55
0xA356
0x1234
Encoding:
1010
Description:
After Instruction (table write completion)
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
=
=
=
=
=
ffff
ffff
1.
Load value in ’f’ into 16-bit table
latch (TBLAT)
If t = 1: load into high byte;
If t = 0: load into low byte
2.
The contents of TBLAT are written to the program memory
location pointed to by TBLPTR.
If TBLPTR points to external
program memory location, then
the instruction takes two-cycle.
If TBLPTR points to an internal
EPROM location, then the
instruction is terminated when
an interrupt is received.
0x55
0x12
0x34
0xA356
0x1234
Note:
11ti
The MCLR/VPP pin must be at the programming
voltage for successful programming of internal
memory.
If MCLR/VPP = VDD
the programming sequence of internal memory
will be interrupted. A short write will occur (2
TCY). The internal memory location will not be
affected.
3.
The TBLPTR can be automatically incremented
If i = 1; TBLPTR is not
incremented
If i = 0; TBLPTR is incremented
Words:
1
Cycles:
2 (many if write is to on-chip
EPROM program memory)
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register
TBLATH or
TBLATL
No
operation
DS30289C-page 228
No
No
No
operation
operation
operation
(Table Pointer
(Table Latch on
on Address
Address bus,
bus)
WR goes low)
1998-2013 Microchip Technology Inc.
PIC17C7XX
TABLWT
Table Write
TLRD
Table Latch Read
Example1:
TABLWT
Syntax:
[ label ] TLRD t,f
Operands:
0 f 255
t [0,1]
Operation:
If t = 0,
TBLATL f;
If t = 1,
TBLATH f
Status Affected:
None
1, 1, REG
Before Instruction
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
=
=
=
=
=
0x53
0xAA
0x55
0xA356
0xFFFF
After Instruction (table write completion)
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR - 1)
Example 2:
TABLWT
=
=
=
=
=
0x53
0x53
0x55
0xA357
0x5355
Encoding:
1010
Description:
0, 0, REG
ffff
If t = 0; low byte is read
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
=
=
=
=
=
0x53
0xAA
0x55
0xA356
0xFFFF
This instruction is used in conjunction
with TABLRD to transfer data from program memory to data memory.
After Instruction (table write completion)
REG
TBLATH
TBLATL
TBLPTR
MEMORY(TBLPTR)
=
=
=
=
=
15
0x53
0xAA
0x53
0xA356
0xAA53
0
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register
TBLATH or
TBLATL
Process
Data
Write
register 'f'
Data
Memory
Example:
TBLPTR
15
16 bits
ffff
If t = 1; high byte is read
Before Instruction
Program
Memory
00tx
Read data from 16-bit table latch
(TBLAT) into file register 'f'. Table Latch
is unaffected.
8
7
TBLAT
TLRD
t, RAM
Before Instruction
0
t
RAM
TBLAT
=
=
=
0
?
0x00AF
8 bits
(TBLATH = 0x00)
(TBLATL = 0xAF)
After Instruction
RAM
TBLAT
=
=
0xAF
0x00AF
(TBLATH = 0x00)
(TBLATL = 0xAF)
Before Instruction
t
RAM
TBLAT
=
=
=
1
?
0x00AF
(TBLATH = 0x00)
(TBLATL = 0xAF)
After Instruction
RAM
TBLAT
Program
Memory
=
=
0x00
0x00AF
(TBLATH = 0x00)
(TBLATL = 0xAF)
15
0
Data
Memory
TBLPTR
15
16 bits
1998-2013 Microchip Technology Inc.
8
7
TBLAT
0
8 bits
DS30289C-page 229
PIC17C7XX
TLWT
Table Latch Write
TSTFSZ
Test f, skip if 0
Syntax:
[ label ] TLWT t,f
Syntax:
[ label ] TSTFSZ f
Operands:
0 f 255
t [0,1]
Operands:
0 f 255
Operation:
skip if f = 0
If t = 0,
f TBLATL;
If t = 1,
f TBLATH
Status Affected:
None
Operation:
Status Affected:
Encoding:
Encoding:
1010
01tx
ffff
If t = 1; high byte is written
1
Cycles:
1 (2)
This instruction is used in conjunction
with TABLWT to transfer data from data
memory to program memory.
1
Cycles:
1
ffff
Q Cycle Activity:
If t = 0; low byte is written
Words:
ffff
Words:
ffff
Data from file register 'f' is written into
the 16-bit table latch (TBLAT).
0011
Description:
None
Description:
0011
If 'f' = 0, the next instruction, fetched
during the current instruction execution,
is discarded and a NOP is executed,
making this a two-cycle instruction.
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
No
operation
Q1
Q2
Q3
Q4
No
operation
No
operation
No
operation
No
operation
If skip:
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write
register
TBLATH or
TBLATL
Example:
HERE
NZERO
ZERO
TSTFSZ
:
:
CNT
Before Instruction
Example:
TLWT
t, RAM
After Instruction
Before Instruction
t
RAM
TBLAT
=
=
=
PC = Address (HERE)
0
0xB7
0x0000
(TBLATH = 0x00)
(TBLATL = 0x00)
If CNT
PC
If CNT
PC
=
=
¼
=
0x00,
Address (ZERO)
0x00,
Address (NZERO)
After Instruction
RAM
TBLAT
=
=
0xB7
0x00B7
(TBLATH = 0x00)
(TBLATL = 0xB7)
Before Instruction
t
RAM
TBLAT
=
=
=
1
0xB7
0x0000
(TBLATH = 0x00)
(TBLATL = 0x00)
After Instruction
RAM
TBLAT
=
=
DS30289C-page 230
0xB7
0xB700
(TBLATH = 0xB7)
(TBLATL = 0x00)
1998-2013 Microchip Technology Inc.
PIC17C7XX
Exclusive OR Literal with
WREG
XORWF
Syntax:
[ label ] XORLW k
Syntax:
[ label ] XORWF
Operands:
0 k 255
Operands:
Operation:
(WREG) .XOR. k WREG)
0 f 255
d [0,1]
Status Affected:
Z
Operation:
(WREG) .XOR. (f) dest)
Status Affected:
Z
XORLW
Encoding:
1011
Description:
0100
kkkk
kkkk
The contents of WREG are XOR’ed
with the 8-bit literal 'k'. The result is
placed in WREG.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
literal 'k'
Process
Data
Write to
WREG
Example:
XORLW
Exclusive OR WREG with f
Encoding:
0000
110d
f,d
ffff
ffff
Description:
Exclusive OR the contents of WREG
with register 'f'. If 'd' is 0, the result is
stored in WREG. If 'd' is 1, the result is
stored back in the register 'f'.
Words:
1
Cycles:
1
Q Cycle Activity:
Q1
Q2
Q3
Q4
Decode
Read
register 'f'
Process
Data
Write to
destination
0xAF
Before Instruction
WREG
=
0xB5
After Instruction
WREG
=
0x1A
Example:
XORWF
REG, 1
Before Instruction
REG
WREG
=
=
0xAF
0xB5
1010 1111
1011 0101
0x1A
0xB5
0001 1010
After Instruction
REG
WREG
1998-2013 Microchip Technology Inc.
=
=
DS30289C-page 231
PIC17C7XX
NOTES:
DS30289C-page 232
1998-2013 Microchip Technology Inc.
PIC17C7XX
19.0
DEVELOPMENT SUPPORT
The PIC® microcontrollers are supported with a full
range of hardware and software development tools:
• Integrated Development Environment
- MPLAB® IDE Software
• Assemblers/Compilers/Linkers
- MPASMTM Assembler
- MPLAB C17 and MPLAB C18 C Compilers
- MPLINKTM Object Linker/
MPLIBTM Object Librarian
• Simulators
- MPLAB SIM Software Simulator
• Emulators
- MPLAB ICE 2000 In-Circuit Emulator
- ICEPIC™ In-Circuit Emulator
• In-Circuit Debugger
- MPLAB ICD for PIC16F87X
• Device Programmers
- PRO MATE® II Universal Device Programmer
- PICSTART® Plus Entry-Level Development
Programmer
• Low Cost Demonstration Boards
- PICDEMTM 1 Demonstration Board
- PICDEM 2 Demonstration Board
- PICDEM 3 Demonstration Board
- PICDEM 17 Demonstration Board
- KEELOQ® Demonstration Board
19.1
MPLAB Integrated Development
Environment Software
The MPLAB IDE software brings an ease of software
development previously unseen in the 8-bit microcontroller market. The MPLAB IDE is a Windows®-based
application that contains:
• An interface to debugging tools
- simulator
- programmer (sold separately)
- emulator (sold separately)
- in-circuit debugger (sold separately)
• A full-featured editor
• A project manager
• Customizable toolbar and key mapping
• A status bar
• On-line help
1998-2013 Microchip Technology Inc.
The MPLAB IDE allows you to:
• Edit your source files (either assembly or ‘C’)
• One touch assemble (or compile) and download
to PIC MCU emulator and simulator tools (automatically updates all project information)
• Debug using:
- source files
- absolute listing file
- machine code
The ability to use MPLAB IDE with multiple debugging
tools allows users to easily switch from the costeffective simulator to a full-featured emulator with
minimal retraining.
19.2
MPASM Assembler
The MPASM assembler is a full-featured universal
macro assembler for all PIC MCU’s.
The MPASM assembler has a command line interface
and a Windows shell. It can be used as a stand-alone
application on a Windows 3.x or greater system, or it
can be used through MPLAB IDE. The MPASM assembler generates relocatable object files for the MPLINK
object linker, Intel® standard HEX files, MAP files to
detail memory usage and symbol reference, an absolute LST file that contains source lines and generated
machine code, and a COD file for debugging.
The MPASM assembler features include:
• Integration into MPLAB IDE projects.
• User-defined macros to streamline assembly
code.
• Conditional assembly for multi-purpose source
files.
• Directives that allow complete control over the
assembly process.
19.3
MPLAB C17 and MPLAB C18
C Compilers
The MPLAB C17 and MPLAB C18 Code Development
Systems are complete ANSI ‘C’ compilers for
Microchip’s PIC17CXXX and PIC18CXXX family of
microcontrollers, respectively. These compilers provide
powerful integration capabilities and ease of use not
found with other compilers.
For easier source level debugging, the compilers provide symbol information that is compatible with the
MPLAB IDE memory display.
DS30289C-page 233
PIC17C7XX
19.4
MPLINK Object Linker/
MPLIB Object Librarian
The MPLINK object linker combines relocatable
objects created by the MPASM assembler and the
MPLAB C17 and MPLAB C18 C compilers. It can also
link relocatable objects from pre-compiled libraries,
using directives from a linker script.
The MPLIB object librarian is a librarian for precompiled code to be used with the MPLINK object
linker. When a routine from a library is called from
another source file, only the modules that contain that
routine will be linked in with the application. This allows
large libraries to be used efficiently in many different
applications. The MPLIB object librarian manages the
creation and modification of library files.
The MPLINK object linker features include:
• Integration with MPASM assembler and MPLAB
C17 and MPLAB C18 C compilers.
• Allows all memory areas to be defined as sections
to provide link-time flexibility.
The MPLIB object librarian features include:
• Easier linking because single libraries can be
included instead of many smaller files.
• Helps keep code maintainable by grouping
related modules together.
• Allows libraries to be created and modules to be
added, listed, replaced, deleted or extracted.
19.5
MPLAB SIM Software Simulator
The MPLAB SIM software simulator allows code development in a PC-hosted environment by simulating the
PIC series microcontrollers on an instruction level. On
any given instruction, the data areas can be examined
or modified and stimuli can be applied from a file, or
user-defined key press, to any of the pins. The execution can be performed in single step, execute until
break, or trace mode.
19.6
MPLAB ICE High Performance
Universal In-Circuit Emulator with
MPLAB IDE
The MPLAB ICE universal in-circuit emulator is intended
to provide the product development engineer with a
complete microcontroller design tool set for PIC microcontrollers (MCUs). Software control of the MPLAB ICE
in-circuit emulator is provided by the MPLAB Integrated
Development Environment (IDE), which allows editing,
building, downloading and source debugging from a
single environment.
The MPLAB ICE 2000 is a full-featured emulator system with enhanced trace, trigger and data monitoring
features. Interchangeable processor modules allow the
system to be easily reconfigured for emulation of different processors. The universal architecture of the
MPLAB ICE in-circuit emulator allows expansion to
support new PIC microcontrollers.
The MPLAB ICE in-circuit emulator system has been
designed as a real-time emulation system, with
advanced features that are generally found on more
expensive development tools. The PC platform and
Microsoft® Windows environment were chosen to best
make these features available to you, the end user.
19.7
ICEPIC In-Circuit Emulator
The ICEPIC low cost, in-circuit emulator is a solution
for the Microchip Technology PIC16C5X, PIC16C6X,
PIC16C7X and PIC16CXXX families of 8-bit OneTime-Programmable (OTP) microcontrollers. The modular system can support different subsets of PIC16C5X
or PIC16CXXX products through the use of interchangeable personality modules, or daughter boards.
The emulator is capable of emulating without target
application circuitry being present.
The MPLAB SIM simulator fully supports symbolic debugging using the MPLAB C17 and the MPLAB C18 C compilers and the MPASM assembler. The software simulator
offers the flexibility to develop and debug code outside of
the laboratory environment, making it an excellent multiproject software development tool.
DS30289C-page 234
1998-2013 Microchip Technology Inc.
PIC17C7XX
19.8
MPLAB ICD In-Circuit Debugger
Microchip's In-Circuit Debugger, MPLAB ICD, is a powerful, low cost, run-time development tool. This tool is
based on the FLASH PIC16F87X and can be used to
develop for this and other PIC microcontrollers from the
PIC16CXXX family. The MPLAB ICD utilizes the in-circuit debugging capability built into the PIC16F87X. This
feature, along with Microchip's In-Circuit Serial
ProgrammingTM protocol, offers cost-effective in-circuit
FLASH debugging from the graphical user interface of
the MPLAB Integrated Development Environment. This
enables a designer to develop and debug source code
by watching variables, single-stepping and setting
break points. Running at full speed enables testing
hardware in real-time.
19.9
PRO MATE II Universal Device
Programmer
The PRO MATE II universal device programmer is a
full-featured programmer, capable of operating in
stand-alone mode, as well as PC-hosted mode. The
PRO MATE II device programmer is CE compliant.
The PRO MATE II device programmer has programmable VDD and VPP supplies, which allow it to verify
programmed memory at VDD min and VDD max for maximum reliability. It has an LCD display for instructions
and error messages, keys to enter commands and a
modular detachable socket assembly to support various
package types. In stand-alone mode, the PRO MATE II
device programmer can read, verify, or program PIC
MCU devices. It can also set code protection in this
mode.
19.10 PICSTART Plus Entry Level
Development Programmer
The PICSTART Plus development programmer is an
easy-to-use, low cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB
Integrated Development Environment software makes
using the programmer simple and efficient.
The PICSTART Plus development programmer supports all PIC devices with up to 40 pins. Larger pin
count devices, such as the PIC16C92X and
PIC17C76X, may be supported with an adapter socket.
The PICSTART Plus development programmer is CE
compliant.
1998-2013 Microchip Technology Inc.
19.11 PICDEM 1 Low Cost PIC MCU
Demonstration Board
The PICDEM 1 demonstration board is a simple board
which demonstrates the capabilities of several of
Microchip’s microcontrollers. The microcontrollers supported are: PIC16C5X (PIC16C54 to PIC16C58A),
PIC16C61, PIC16C62X, PIC16C71, PIC16C8X,
PIC17C42, PIC17C43 and PIC17C44. All necessary
hardware and software is included to run basic demo
programs. The user can program the sample microcontrollers provided with the PICDEM 1 demonstration
board on a PRO MATE II device programmer, or a
PICSTART Plus development programmer, and easily
test firmware. The user can also connect the
PICDEM 1 demonstration board to the MPLAB ICE incircuit emulator and download the firmware to the emulator for testing. A prototype area is available for the
user to build some additional hardware and connect it
to the microcontroller socket(s). Some of the features
include an RS-232 interface, a potentiometer for simulated analog input, push button switches and eight
LEDs connected to PORTB.
19.12 PICDEM 2 Low Cost PIC16CXX
Demonstration Board
The PICDEM 2 demonstration board is a simple demonstration board that supports the PIC16C62,
PIC16C64, PIC16C65, PIC16C73 and PIC16C74
microcontrollers. All the necessary hardware and software is included to run the basic demonstration programs. The user can program the sample
microcontrollers provided with the PICDEM 2 demonstration board on a PRO MATE II device programmer,
or a PICSTART Plus development programmer, and
easily test firmware. The MPLAB ICE in-circuit emulator may also be used with the PICDEM 2 demonstration
board to test firmware. A prototype area has been provided to the user for adding additional hardware and
connecting it to the microcontroller socket(s). Some of
the features include a RS-232 interface, push button
switches, a potentiometer for simulated analog input, a
serial EEPROM to demonstrate usage of the I2CTM bus
and separate headers for connection to an LCD
module and a keypad.
DS30289C-page 235
PIC17C7XX
19.13 PICDEM 3 Low Cost PIC16CXXX
Demonstration Board
The PICDEM 3 demonstration board is a simple demonstration board that supports the PIC16C923 and
PIC16C924 in the PLCC package. It will also support
future 44-pin PLCC microcontrollers with an LCD Module. All the necessary hardware and software is
included to run the basic demonstration programs. The
user can program the sample microcontrollers provided with the PICDEM 3 demonstration board on a
PRO MATE II device programmer, or a PICSTART Plus
development programmer with an adapter socket, and
easily test firmware. The MPLAB ICE in-circuit emulator may also be used with the PICDEM 3 demonstration
board to test firmware. A prototype area has been provided to the user for adding hardware and connecting it
to the microcontroller socket(s). Some of the features
include a RS-232 interface, push button switches, a
potentiometer for simulated analog input, a thermistor
and separate headers for connection to an external
LCD module and a keypad. Also provided on the
PICDEM 3 demonstration board is a LCD panel, with 4
commons and 12 segments, that is capable of displaying time, temperature and day of the week. The
PICDEM 3 demonstration board provides an additional
RS-232 interface and Windows software for showing
the demultiplexed LCD signals on a PC. A simple serial
interface allows the user to construct a hardware
demultiplexer for the LCD signals.
DS30289C-page 236
19.14 PICDEM 17 Demonstration Board
The PICDEM 17 demonstration board is an evaluation
board that demonstrates the capabilities of several
Microchip microcontrollers, including PIC17C752,
PIC17C756A, PIC17C762 and PIC17C766. All necessary hardware is included to run basic demo programs,
which are supplied on a 3.5-inch disk. A programmed
sample is included and the user may erase it and
program it with the other sample programs using the
PRO MATE II device programmer, or the PICSTART
Plus development programmer, and easily debug and
test the sample code. In addition, the PICDEM 17 demonstration board supports downloading of programs to
and executing out of external FLASH memory on board.
The PICDEM 17 demonstration board is also usable
with the MPLAB ICE in-circuit emulator, or the
PICMASTER emulator and all of the sample programs
can be run and modified using either emulator. Additionally, a generous prototype area is available for user
hardware.
19.15 KEELOQ Evaluation and
Programming Tools
KEELOQ evaluation and programming tools support
Microchip’s HCS Secure Data Products. The HCS evaluation kit includes a LCD display to show changing
codes, a decoder to decode transmissions and a programming interface to program test transmitters.
1998-2013 Microchip Technology Inc.
Software Tools
Programmers Debugger Emulators
PIC12CXXX
PIC14000
PIC16C5X
PIC16C6X
PIC16CXXX
PIC16F62X
PIC16C7X
1998-2013 Microchip Technology Inc.
†
†
* Contact the Microchip Technology Inc. web site at www.microchip.com for information on how to use the MPLAB® ICD In-Circuit Debugger (DV164001) with PIC16C62, 63, 64, 65, 72, 73, 74, 76, 77.
** Contact Microchip Technology Inc. for availability date.
† Development tool is available on select devices.
MCP2510 CAN Developer’s Kit
13.56 MHz Anticollision
microIDTM Developer’s Kit
125 kHz Anticollision microIDTM
Developer’s Kit
125 kHz microIDTM
Developer’s Kit
MCRFXXX
microIDTM Programmer’s Kit
†
**
*
**
**
24CXX/
25CXX/
93CXX
KEELOQ® Transponder Kit
HCSXXX
KEELOQ® Evaluation Kit
PICDEMTM 17 Demonstration
Board
PICDEMTM 14A Demonstration
Board
PICDEMTM 3 Demonstration
Board
PICDEMTM 2 Demonstration
Board
PICDEMTM 1 Demonstration
Board
PRO MATE® II
Universal Device Programmer
PICSTART® Plus Entry Level
Development Programmer
*
MPLAB® ICD In-Circuit
Debugger
ICEPICTM In-Circuit Emulator
PIC16C7XX
PIC16C8X
PIC16F8XX
PIC16C9XX
MPLAB® ICE In-Circuit Emulator
PIC17C4X
PIC17C7XX
MPASMTM Assembler/
MPLINKTM Object Linker
PIC18CXX2
MPLAB® C18 C Compiler
MPLAB® C17 C Compiler
MCP2510
TABLE 19-1:
Demo Boards and Eval Kits
MPLAB® Integrated
Development Environment
PIC17C7XX
DEVELOPMENT TOOLS FROM MICROCHIP
DS30289C-page 237
PIC17C7XX
NOTES:
DS30289C-page 238
1998-2013 Microchip Technology Inc.
PIC17C7XX
20.0
PIC17C7XX ELECTRICAL CHARACTERISTICS
Absolute Maximum Ratings †
Ambient temperature under bias.............................................................................................................-55°C to +125°C
Storage temperature .............................................................................................................................. -65°C to +150°C
Voltage on VDD with respect to VSS ........................................................................................................... 0 V to +7.5 V
Voltage on MCLR with respect to VSS (Note 2) ....................................................................................... -0.3 V to +14 V
Voltage on RA2 and RA3 with respect to VSS .......................................................................................... -0.3 V to +8.5 V
Voltage on all other pins with respect to VSS ...................................................................................-0.3 V to VDD + 0.3 V
Total power dissipation (Note 1) ..............................................................................................................................1.0 W
Maximum current out of VSS pin(s) - total (@ 70°C) ............................................................................................500 mA
Maximum current into VDD pin(s) - total (@ 70°C) ...............................................................................................500 mA
Input clamp current, IIK (VI < 0 or VI > VDD) .......................................................................................................... ±20 mA
Output clamp current, IOK (VO < 0 or VO > VDD) ...................................................................................................±20 mA
Maximum output current sunk by any I/O pin (except RA2 and RA3).....................................................................35 mA
Maximum output current sunk by RA2 or RA3 pins ................................................................................................60 mA
Maximum output current sourced by any I/O pin ....................................................................................................20 mA
Maximum current sunk by PORTA and PORTB (combined).................................................................................150 mA
Maximum current sourced by PORTA and PORTB (combined) ...........................................................................100 mA
Maximum current sunk by PORTC, PORTD and PORTE (combined)..................................................................150 mA
Maximum current sourced by PORTC, PORTD and PORTE (combined) ............................................................100 mA
Maximum current sunk by PORTF and PORTG (combined) ................................................................................150 mA
Maximum current sourced by PORTF and PORTG (combined)...........................................................................100 mA
Maximum current sunk by PORTH and PORTJ (combined).................................................................................150 mA
Maximum current sourced by PORTH and PORTJ (combined) ...........................................................................100 mA
Note 1: Power dissipation is calculated as follows: Pdis = VDD x {IDD - IOH} + {(VDD-VOH) x IOH} + (VOL x IOL)
2: Voltage spikes below VSS at the MCLR pin, inducing currents greater than 80 mA, may cause latch-up.
Thus, a series resistor of 50-100 should be used when applying a "low" level to the MCLR pin, rather than
pulling this pin directly to VSS.
† NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other
conditions above those indicated in the operation listings of this specification is not implied. Exposure to
maximum rating conditions for extended periods may affect device reliability.
1998-2013 Microchip Technology Inc.
DS30289C-page 239
PIC17C7XX
FIGURE 20-1:
PIC17C7XX-33 VOLTAGE-FREQUENCY GRAPH
6.0 V
5.5 V
Voltage
5.0 V
PIC17C7XX-33
4.5 V
4.0 V
3.5 V
3.0 V
2.5 V
2.0 V
33 MHz
Frequency
FIGURE 20-2:
PIC17C7XX-16 VOLTAGE-FREQUENCY GRAPH
6.0 V
5.5 V
Voltage
5.0 V
PIC17C7XX-16
4.5 V
4.0 V
3.5 V
3.0 V
2.5 V
2.0 V
16 MHz
Frequency
DS30289C-page 240
1998-2013 Microchip Technology Inc.
PIC17C7XX
FIGURE 20-3:
PIC17LC7XX-08 VOLTAGE-FREQUENCY GRAPH
6.0 V
5.5 V
Voltage
5.0 V
4.5 V
4.0 V
PIC17LC7XX-08
3.5 V
3.0 V
2.5 V
2.0 V
8 MHz
Frequency
FIGURE 20-4:
PIC17C7XX/CL VOLTAGE-FREQUENCY GRAPH
6.0 V
5.5 V
Voltage
5.0 V
PIC17C7XX/CL
4.5 V
4.0 V
3.5 V
3.0 V
2.5 V
2.0 V
8 MHz
33 MHz
Frequency
1998-2013 Microchip Technology Inc.
DS30289C-page 241
PIC17C7XX
20.1
DC Characteristics
PIC17LC7XX-08
(Commercial, Industrial)
PIC17C7XX-16
(Commercial, Industrial, Extended)
PIC17C7XX-33
(Commercial, Industrial, Extended)
Param.
No.
D001
Sym
VDD
Characteristic
Supply Voltage
PIC17LC7XX
D001
D002
VDR
D003
VPOR
D004
SVDD
D004
D005
Standard Operating Conditions (unless otherwise stated)
Operating temperature
-40°C TA +85°C for industrial and
0°C TA +70°C for commercial
Standard Operating Conditions (unless otherwise stated)
Operating temperature
-40°C TA +125°C for extended
-40°C TA +85°C for industrial
0°C TA +70°C for commercial
Min
Typ†
Max
Units
Conditions
3.0
—
PIC17C7XX-33
4.5
—
PIC17C7XX-16
VBOR
—
RAM Data Retention
1.5
—
Voltage (Note 1)
VDD Start Voltage to
—
Vss
ensure internal
Power-on Reset signal
VDD Rise Rate to ensure proper operation
PIC17LCXX
0.010
—
PIC17CXX
0.085
—
5.5
V
5.5
5.5
—
V
V
V
—
V
See section on Power-on
Reset for details
—
V/ms
—
V/ms
See section on Power-on
Reset for details
See section on Power-on
Reset for details
(BOR enabled) (Note 5)
Device in SLEEP mode
VBOR
Brown-out Reset
3.65
—
4.35
V
voltage trip point
Power-on Reset trip
—
2.2
—
V
VDD = VPORTP
D006
VPORTP
point
† Data in "Typ" column is at 5V, 25°C unless otherwise stated.
Note 1: This is the limit to which VDD can be lowered in SLEEP mode 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 tri-stated, pulled to VDD or VSS, T0CKI = VDD,
MCLR = VDD; WDT disabled.
Current consumed from the oscillator and I/O’s driving external capacitive or resistive loads needs to be
considered.
For the RC oscillator, the current through the external pull-up resistor (R) can be estimated as:
VDD/(2 R).
For capacitive loads, the current can be estimated (for an individual I/O pin) as (C LVDD) f
CL = Total capacitive load on the I/O pin; f = average frequency the I/O pin switches.
The capacitive currents are most significant when the device is configured for external execution (includes
Extended Microcontroller mode).
3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is
measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSS.
4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula IR = VDD/2REXT (mA) with REXT in kOhm.
5: This is the voltage where the device enters the Brown-out Reset. When BOR is enabled, the device (-16)
will operate correctly to this trip point.
DS30289C-page 242
1998-2013 Microchip Technology Inc.
PIC17C7XX
PIC17LC7XX-08
(Commercial, Industrial)
PIC17C7XX-16
(Commercial, Industrial, Extended)
PIC17C7XX-33
(Commercial, Industrial, Extended)
Param.
No.
D010
Sym
IDD
D010
D011
D011
D012
D014
D015
D021
Characteristic
Supply Current (Note 2)
PIC17LC7XX
PIC17C7XX
PIC17LC7XX
PIC17C7XX
—
—
—
—
—
—
3
3
5
5
9
85
6
6
10
10
18
150
mA
mA
mA
mA
mA
A
PIC17C7XX
—
Power-down Current (Note 3)
PIC17LC7XX
—
PIC17C7XX
—
15
30
mA
FOSC = 4 MHz (Note 4)
FOSC = 4 MHz (Note 4)
FOSC = 8 MHz
FOSC = 8 MHz
FOSC = 16 MHz
FOSC = 32 kHz,
(EC osc configuration)
FOSC = 33 MHz