PIC16F87XA
TABLE 8-5: REGISTERS ASSOCIATED WITH PWM AND TIMER2
Value on
Value on:
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 all other
POR, BOR
Resets
0Bh,8Bh, INTCON GIE PEIE TMR0IE INTE RBIE TMR0IF INTF RBIF 0000 000x 0000 000u
10Bh, 18Bh
0Ch PIR1 PSPIF(1) ADIF RCIF TXIF SSPIF CCP1IF TMR2IF TMR1IF 0000 0000 0000 0000
0Dh PIR2 — — — — — — — CCP2IF ---- ---0 ---- ---0
8Ch PIE1 PSPIE(1) ADIE RCIE TXIE SSPIE CCP1IE TMR2IE TMR1IE 0000 0000 0000 0000
8Dh PIE2 — — — — — — — CCP2IE ---- ---0 ---- ---0
87h TRISC PORTC Data Direction Register 1111 1111 1111 1111
11h TMR2 Timer2 Module’s Register 0000 0000 0000 0000
92h PR2 Timer2 Module’s Period Register 1111 1111 1111 1111
12h T2CON — TOUTPS3 TOUTPS2 TOUTPS1 TOUTPS0 TMR2ON T2CKPS1 T2CKPS0 -000 0000 -000 0000
15h CCPR1L Capture/Compare/PWM Register 1 (LSB) xxxx xxxx uuuu uuuu
16h CCPR1H Capture/Compare/PWM Register 1 (MSB) xxxx xxxx uuuu uuuu
17h CCP1CON — — CCP1X CCP1Y CCP1M3 CCP1M2 CCP1M1 CCP1M0 --00 0000 --00 0000
1Bh CCPR2L Capture/Compare/PWM Register 2 (LSB) xxxx xxxx uuuu uuuu
1Ch CCPR2H Capture/Compare/PWM Register 2 (MSB) xxxx xxxx uuuu uuuu
1Dh CCP2CON — — CCP2X CCP2Y CCP2M3 CCP2M2 CCP2M1 CCP2M0 --00 0000 --00 0000
Legend: x = unknown, u = unchanged, - = unimplemented, read as ‘0’. Shaded cells are not used by PWM and Timer2.
Note 1: Bits PSPIE and PSPIF are reserved on 28-pin devices; always maintain these bits clear.
2003 Microchip Technology Inc. DS39582B-page 69
PIC16F87XA
NOTES:
DS39582B-page 70 2003 Microchip Technology Inc.
PIC16F87XA
9.0 MASTER SYNCHRONOUS FIGURE 9-1: MSSP BLOCK DIAGRAM
SERIAL PORT (MSSP) (SPI MODE)
MODULE Internal
Data Bus
Read Write
9.1 Master SSP (MSSP) Module
Overview
SSPBUF reg
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, SSPSR reg
display drivers, A/D converters, etc. The MSSP module RC4/SDI/SDA bit0 Shift
can operate in one of two modes: Clock
• Serial Peripheral Interface (SPI) RC5/SDO Peripheral OE
• Inter-Integrated Circuit (I2C)
- Full Master mode
SS Control
- Slave mode (with general address call) Enable
The I2C interface supports the following modes in RA5/AN4/
hardware: SS/C2OUT Edge
Select
• Master mode
• Multi-Master mode 2
• Slave mode Clock Select
SSPM3:SSPM0
9.2 Control Registers
( )
SMP:CKE 4
TMR2 Output
2 2
The MSSP module has three associated registers. Edge
These include a status register (SSPSTAT) and two Select Prescaler TOSC
control registers (SSPCON and SSPCON2). The use RC3/SCK/SCL 4, 16, 64
of these registers and their individual configuration bits
differ significantly, depending on whether the MSSP Data to TX/RX in SSPSR
TRIS bit
module is operated in SPI or I2C mode.
Additional details are provided under the individual
sections.
Note: When the SPI is in Slave mode with SS pin
9.3 SPI Mode control enabled (SSPCON<3:0> = 0100),
the state of the SS pin can affect the state
The SPI mode allows 8 bits of data to be synchronously read back from the TRISC<5> bit. The
transmitted and received simultaneously. All four Peripheral OE signal from the SSP mod-
modes of SPI are supported. To accomplish ule in PORTC controls the state that is
communication, typically three pins are used: read back from the TRISC<5> bit (see
• Serial Data Out (SDO) – RC5/SDO Section 4.3 “PORTC and the TRISC
• Serial Data In (SDI) – RC4/SDI/SDA Register” for information on PORTC). If
Read-Modify-Write instructions, such as
• Serial Clock (SCK) – RC3/SCK/SCL
BSF, are performed on the TRISC register
Additionally, a fourth pin may be used when in a Slave while the SS pin is high, this will cause the
mode of operation: TRISC<5> bit to be set, thus disabling the
• Slave Select (SS) – RA5/AN4/SS/C2OUT SDO output.
Figure 9-1 shows the block diagram of the MSSP
module when operating in SPI mode.
2003 Microchip Technology Inc. DS39582B-page 71
PIC16F87XA
9.3.1 REGISTERS SSPSR is the shift register used for shifting data in or
out. SSPBUF is the buffer register to which data bytes
The MSSP module has four registers for SPI mode
are written to or read from.
operation. These are:
In receive operations, SSPSR and SSPBUF together
• MSSP Control Register (SSPCON)
create a double-buffered receiver. When SSPSR
• MSSP Status Register (SSPSTAT) receives a complete byte, it is transferred to SSPBUF
• Serial Receive/Transmit Buffer Register and the SSPIF interrupt is set.
(SSPBUF)
During transmission, the SSPBUF is not double-
• MSSP Shift Register (SSPSR) – Not directly buffered. A write to SSPBUF will write to both SSPBUF
accessible and SSPSR.
SSPCON and SSPSTAT are the control and status
registers in SPI mode operation. The SSPCON regis-
ter is readable and writable. The lower six bits of the
SSPSTAT are read-only. The upper two bits of the
SSPSTAT are read/write.
REGISTER 9-1: SSPSTAT: MSSP STATUS REGISTER (SPI MODE) (ADDRESS 94h)
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 0
bit 7 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.
bit 6 CKE: SPI Clock Select bit
1 = Transmit occurs on transition from active to Idle clock state
0 = Transmit occurs on transition from Idle to active clock state
Note: Polarity of clock state is set by the CKP bit (SSPCON1<4>).
bit 5 D/A: Data/Address bit
Used in I2C mode only.
bit 4 P: Stop bit
Used in I2C mode only. This bit is cleared when the MSSP module is disabled, SSPEN is cleared.
bit 3 S: Start bit
Used in I2C mode only.
bit 2 R/W: Read/Write bit information
Used in I2C mode only.
bit 1 UA: Update Address bit
Used in I2C mode only.
bit 0 BF: Buffer Full Status bit (Receive mode only)
1 = Receive complete, SSPBUF is full
0 = Receive not complete, SSPBUF is empty
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
- n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
DS39582B-page 72 2003 Microchip Technology Inc.
PIC16F87XA
REGISTER 9-2: SSPCON1: MSSP CONTROL REGISTER 1 (SPI MODE) (ADDRESS 14h)
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 (Transmit mode only)
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
SPI Slave 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. The user
must read the SSPBUF, even if only transmitting data, to avoid setting overflow. (Must be
cleared in software.)
0 = No overflow
Note: In Master mode, the overflow bit is not set, since each new reception (and
transmission) is initiated by writing to the SSPBUF register.
bit 5 SSPEN: Synchronous Serial Port Enable bit
1 = Enables serial port and configures SCK, SDO, SDI, and SS as serial port pins
0 = Disables serial port and configures these pins as I/O port pins
Note: When enabled, these pins must be properly configured as input or output.
bit 4 CKP: Clock Polarity Select bit
1 = Idle state for clock is a high level
0 = Idle state for clock is a low level
bit 3-0 SSPM3:SSPM0: Synchronous Serial Port Mode Select bits
0101 = SPI Slave mode, clock = SCK pin. SS pin control disabled. SS can be used as I/O pin.
0100 = SPI Slave mode, clock = SCK pin. SS pin control enabled.
0011 = SPI Master mode, clock = TMR2 output/2
0010 = SPI Master mode, clock = FOSC/64
0001 = SPI Master mode, clock = FOSC/16
0000 = SPI Master mode, clock = FOSC/4
Note: Bit combinations not specifically listed here are either reserved or implemented in
I2C mode only.
Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as ‘0’
- n = Value at POR ‘1’ = Bit is set ‘0’ = Bit is cleared x = Bit is unknown
2003 Microchip Technology Inc. DS39582B-page 73