Datasheet
PIC16F818/819
DS39598C-page 78 Preliminary 2002 Microchip Technology Inc.
TABLE 10-2: DATA TRANSFER RECEIVED BYTE ACTIONS
FIGURE 10-6: I
2
C WAVEFORMS FOR RECEPTION (7-BIT ADDRESS)
FIGURE 10-7: I
2
C WAVEFORMS FOR TRANSMISSION (7-BIT ADDRESS)
Status Bits as Data
Transfer is Received
SSPSR → SSPBUF Generate ACK Pulse
Set bit SSPIF
(SSP Interrupt Occurs if Enabled)
BF SSPOV
00 Ye s Yes Yes
10 No No Yes
11 No No Yes
0 1 No No Yes
Note 1: Shaded cells show the conditions where the user software did not properly clear the overflow condition.
P
9
8
7
6
5
D0
D1
D2
D3D4
D5
D6D7
S
A7 A6 A5 A4
A3 A2 A1SDA
SCL
12
3
4
5
6
7
8
9
12
3
4
56
7
89
123
4
Bus Master
terminates
transfer.
Bit SSPOV is set because the SSPBUF register is still full.
Cleared in Software
SSPBUF Register is Read
ACK
Receiving Data
Receiving Data
D0
D1
D2
D3D4
D5
D6D7
ACK
R/W=0
Receiving Address
SSPIF (PIR1<3>)
BF (SSPSTAT<0>)
SSPOV (SSPCON<6>)
ACK
ACK is not sent.
SDA
SCL
SSPIF (PIR1<3>)
BF (SSPSTAT<0>)
CKP (SSPCON<4>)
A7 A6 A5 A4 A3 A2 A1 ACK
D7 D6 D5 D4 D3 D2 D1 D0
ACK
Transmitting DataR/W = 1Receiving Address
123456789 123456789
P
Cleared in Software
SSPBUF is Written in Software
From SSP Interrupt
Service Routine
Set bit after writing to SSPBUF
S
Data is
Sampled
SCL held low
while CPU
responds to SSPIF
(the SSPBUF must be written to
before the CKP bit can be set).