i2c interface

Upload: ahmed-abd-el-shakour

Post on 14-Jan-2016

54 views

Category:

Documents


2 download

DESCRIPTION

I2C interface in PIC16f877a

TRANSCRIPT

  • MINISTY OF HIGHER EDUCATION AINSHAMS UNIVERSITY

    FACULTY OF ENGINEERING

    Assignment 3 I2C Interface/ SSP Module

    Supervised By: Prof. Dr. Ayman Wahba

    By:-

    Ahmed Abd-Elshakour Allam

  • 2

    1 Contents 2 I2C Overview .......................................................................................................................................... 3

    2.1 Initiating and Terminating Data Transfer ...................................................................................... 4

    2.2 Addressing I2C Devices .................................................................................................................. 4

    2.3 Transfer Acknowledge .................................................................................................................. 5

    2.4 Multi-master ................................................................................................................................. 6

    3 Overview of the SSP Module ................................................................................................................ 6

    3.1 SSP Bits that Indicate Module Status ............................................................................................ 7

    3.2 SSP Bits for Module Control .......................................................................................................... 9

    4 SPP I2C Operation ................................................................................................................................ 10

    4.1 Slave Mode .................................................................................................................................. 11

    4.2 Addressing ................................................................................................................................... 12

    4.3 Reception .................................................................................................................................... 12

    4.4 Transmission ............................................................................................................................... 13

    4.5 Clock Arbitration ......................................................................................................................... 14

    4.6 Master Mode (Firmware) ............................................................................................................ 14

    4.7 Multi-Master Mode (Firmware) .................................................................................................. 15

    5 References .......................................................................................................................................... 15

    List of Figures:

    Figure 1: Start and Stop Conditions ................................................................................................ 4

    Figure 2: 7-bit Address Format ....................................................................................................... 5

    Figure 3: 10-bit Address Format ..................................................................................................... 5

    Figure 4: Slave-Receiver Acknowledge ........................................................................................... 6

    Figure 5: Data Transfer Wait State ................................................................................................. 6

    Figure 6: SSP Block Diagram (I2C Mode) ....................................................................................... 10

    Figure 7: I2C Waveforms for Reception (7-bit Address)................................................................ 13

    Figure 8: I2C Waveforms for Transmission (7-bit Address) ........................................................... 14

  • 3

    2 I2C Overview

    The I2C bus is a two-wire serial interface. The original specification, or standard mode, is for

    data transfers of up to 100 Kbps. An enhanced specification or fast mode (400 Kbps) is

    supported by the PIC midrange family.

    Standard and Fast mode devices will operate when attached to the same bus, if the bus

    operates at the speed of the slower device.

    The I2C interface employs a comprehensive protocol to ensure reliable transmission and

    reception of data. When transmitting data, one device is the master which initiates transfer

    on the bus and generates the clock signals to permit that transfer, while the other device(s) acts

    as the slave. All portions of the slave protocol are implemented in the SSP modules

    hardware, except general call support, while portions of the master protocol need to be

    addressed in the PIC16CXX software. The MSSP module supports the full implementation of the

    I2C master protocol, the general call address, and data transfers up to 1 Mbps. The 1 Mbps data

    transfers are supported by some of the available Serial EEPROMs. In the I2C interface protocol

    each device has an address. When a master wishes to initiate a data transfer, it first transmits

    the address of the device that it wishes to talk to. All devices listen to see if this is their

    address. Within this address, a bit specifies if the master wishes to read-from/write-to the slave

    device. The master and slave are always in opposite modes (transmitter/receiver) of operation

    during a data transfer. That is they can be thought of as operating in either of these two

    relations:

    Master-transmitter and Slave-receiver

    Slave-transmitter and Master-receiver

    In both cases the master generates the clock signal.

    I2C is a Serial Interface and uses only the following two signals to serially exchange data with

    another device:

    SDA - This signal is known as Serial Data. Any data sent from one device to another goes

    on this line.

    SCL - This is the Serial Clock signal. It is generated by the master device and controls

    when data is sent and when it is read.

    I2C lines can have only two possible electrical states. These states are known as float high and

    drive low. I2C works by having a pull-up resistor on the line and only devices pull the line low.

    If no device is pulling on the line, it will float high. This is why pull-up resistors are important

    in I2C. If no pull-up resistor were used, the line would float to an unknown state. If one tried to

  • 4

    drive the line high, it might cause contention with a device trying to drive the line low. This

    contention could damage the either or both devices driving the line. To prevent this, the pull-

    up-drive low system controls when one device has control of the bus. If another device tried to

    use the bus when it was busy, it would find the bus to be driven low already and know it was

    busy. Even if it tried to use the bus accidentally, it would only drive it low and not damage other

    devices. The diagrams shown are symbolic. In each case, the solid diagram represents the

    ACTIVE part of the bus. In the case of driving low, the buffer is actively pulling the line low. In

    the case of floating high, the resistor pulls the line high, while the buffer is turned off. A buffer

    turned off has very high impedance and behaves as if it were disconnected. Only the output

    buffers are shown for simplicity.

    The number of devices that may be attached to the I2C bus is limited only by the maximum bus

    loading specification of 400 pF and addressing capability.

    2.1 Initiating and Terminating Data Transfer

    During times of no data transfer (idle time), both the clock line (SCL) and the data line (SDA) are

    pulled high through the external pull-up resistors. The START and STOP conditions determine

    the start and stop of data transmission. The START condition is defined as a high to low

    transition of the SDA when the SCL is high. The STOP condition is defined as a low to high

    transition of the SDA when the SCL is high. Figure 1 shows the START and STOP conditions. The

    master generates these conditions for starting and terminating data transfer. Due to the

    definition of the START and STOP conditions, when data is being transmitted, the SDA line can

    only change state when the SCL line is low.

    Figure 1: Start and Stop Conditions

    2.2 Addressing I2C Devices

    There are two address formats. The simplest is the 7-bit address format with a R/W bit (Figure

    2). The more complex is the 10-bit address with a R/W bit (Figure 3). For 10-bit address format,

    two bytes must be transmitted. The first five bits specify this to be a 10-bit address format. The

  • 5

    1st transmitted byte has 5-bits which specify a 10-bit address, the two MSbs of the address, and

    the R/W bit. The second byte is the remaining 8-bits of the address.

    Figure 2: 7-bit Address Format

    Figure 3: 10-bit Address Format

    2.3 Transfer Acknowledge

    All data must be transmitted per byte, with no limit to the number of bytes transmitted per

    data transfer. After each byte, the slave-receiver generates an acknowledge bit (ACK) (Figure 4).

    When a slave-receiver doesnt acknowledge the slave address or received data, the master

    must abort the transfer. The slave must leave SDA high so that the master can generate the

    STOP condition (Figure 1). If the master is receiving the data (master-receiver), it generates an

    acknowledge signal for each received byte of data, except for the last byte. To signal the end of

    data to the slave-transmitter, the master does not generate an acknowledge (not

    acknowledge). The slave then releases the SDA line so the master can generate the STOP

    condition. The master can also generate the STOP condition during the acknowledge pulse for

    valid termination of data transfer.

    If the slave needs to delay the transmission of the next byte, holding the SCL line low will force

    the master into a wait state. Data transfer continues when the slave releases the SCL line. This

    allows the slave to move the received data or fetch the data it needs to transfer before allowing

    the clock to start. This wait state technique can also be implemented at the bit level, Figure 5.

  • 6

    Figure 4: Slave-Receiver Acknowledge

    Figure 5: Data Transfer Wait State

    2.4 Multi-master

    The I2C protocol allows a system to have more than one master. This is called multi-master.

    When two or more masters try to transfer data at the same time, arbitration and

    synchronization occur.

    3 Overview of the SSP Module

    The Synchronous Serial Port (SSP) module is a serial interface useful for communicating with

    other peripherals or microcontroller devices. These peripheral devices may be serial EEPROMs,

    shift registers, display drivers, A/D converters, etc. The SSP module can operate in one of two

    modes:

    Serial Peripheral Interface (SPI)

    Inter-Integrated Circuit (I2C)

    - Slave mode

    - I/O slope control, and Start and Stop bit detection to ease software

    implementation of Master and Multi-master modes

  • 7

    A block diagram of the SSP module for I2C Slave mode is shown in Figure 6. Key control and

    status bits required for I2C slave communication are provided in the following Special Function

    Registers:

    SSPSTAT

    SSPCON

    PIR1 (interrupt flag bits)

    PIE1 (interrupt enable bits)

    Some of the bit functions in these registers vary, depending on whether the SSP module is used

    for I2C or SPI communications.

    3.1 SSP Bits that Indicate Module Status

    BF (SSPSTAT)

    The BF (Buffer Full) bit tells the user whether a byte of data is currently in the SSP Buffer

    register, SSPBUF. This bit is cleared automatically when the SSPBUF register is read, or when a

    byte to be transmitted is completely shifted out of the register. The BF bit will become set

    under the following circumstances:

    When an address byte is received with the LSB cleared. This will be the first byte sent by

    the master device during an I2C write operation.

    Each time a data byte is received during an I2C write to the slave device.

    Each time a byte of data is written to SSPBUF to be transmitted to the master device.

    The BF bit will be cleared automatically when all bits have been shifted from SSPBUF to

    the master device.

    There are certain cases where the BF flag will set when an address is received with the LSB set

    (read operation).

    UA (SSPSTAT)

    The UA (Update Address) bit is used only in the 10-Bit Addressing modes. In the 10-Bit

    Addressing mode, an I2C slave address must be sent in two bytes. The upper half of the 10-bit

    address (1111 0 A9 A8 0) is first loaded into SSPADD for initial match detection. This particular

    address code is reserved in the I2C protocol for designating the upper half of a 10-bit address.

    When an address match occurs, the SSP module will set the UA bit to indicate that the lower

    half of the address should be loaded into SSPADD for match detection.

    R/W (SSPSTAT)

  • 8

    The R/W (Read/Write) bit tells the user whether the master device is reading from, or writing

    to, the slave device. This bit reflects the state of the LSB in the address byte that is sent by the

    master. The state of the R/W bit is only valid for the duration of a particular I2C message and

    will be reset by a Stop condition, Start condition or a NACK from the master device.

    S (SSPSTAT)

    The S (Start) bit is set if a Start condition occurred last on the bus. The state of this bit will be

    the inverse of the P (Stop) bit, except when the module is first initialized and both bits are

    cleared.

    P (SSPSTAT)

    The P (Stop) bit is set if a Stop condition occurred last on the bus. The state of this bit will be the

    inverse of the S (Start) bit, except when the module is first initialized and both bits are cleared.

    The P bit can be used to determine when the bus is Idle.

    D/A (SSPSTAT)

    The D/A (Data/Address) bit indicates whether the last byte of data received by the SSP module

    was a data byte or an address byte. For read operations, the last byte sent to the master device

    was a data byte when the D/A bit is set.

    WCOL (SSPCON)

    The WCOL (Write Collision) bit indicates that SSPBUF was written while the previously written

    word is still transmitting. The previous contents of SSPBUF are not changed when the write

    collision occurs. The WCOL bit must be cleared in software.

    SSPOV (SSPCON)

    The SSPOV (SSP Overflow) bit indicates that a new byte was received while SSPBUF was still

    holding the previous data. In this case, the SSP module will not generate an ACK pulse and

    SSPBUF will not be updated with the new data. Regardless of whether the data is to be used,

    the user must read SSPBUF whenever the BF bit becomes set, to avoid an SSP overflow

    condition. The user must read SSPBUF and clear the SSPOV bit to properly clear an overflow

    condition. If the user reads SSPBUF to clear the BF bit, but does not clear the SSPOV bit, the

    next byte of data received will be loaded into SSPBUF but the module will not generate an ACK

    pulse.

  • 9

    SSPIF (PIR1)

    The SSPIF (SSP Interrupt Flag) bit indicates that an I2C event has completed. The user must poll

    the status bits described here to determine what event occurred and the next action to be

    taken. The SSPIF bit must be cleared by the user.

    3.2 SSP Bits for Module Control

    SSPEN (SSPCON)

    The SSPEN (SSP Enable) bit enables the SSP module and configures the appropriate I/O pins as

    serial port pins.

    CKE (SSPSTAT)

    The CKE (Clock Edge) bit has no function when the SSP module is configured for I2C mode and

    should be cleared.

    SMP (SSPSTAT)

    The SMP (Sample Phase) bit has no function when the SSP module is configured for I2C mode

    and should be cleared.

    CKP (SSPCON)

    The CKP (Clock Polarity) bit is used for clock stretching in the I2C protocol. When the CKP bit is

    cleared, the slave device holds the SCL pin low so that the master device on the bus is unable to

    send clock pulses.

    During clock stretching, the master device will attempt to send clock pulses until the clock line

    is released by the slave device. Clock stretching is useful when the slave device cannot process

    incoming bytes quickly enough, or when SSPBUF needs to be loaded with data to be

    transmitted to the master device. The SSP module performs clock stretching automatically

    when data is read by the master device. SSPM3:SSPM0 (SSPCON)

    The SSPM3:SSPM0 (SSP mode) bits are used to configure the SSP module for the SPI or I2C

    protocols. For specific values, refer to the appropriate device data sheet.

    SSPIE (PIE1)

    The SSPIE (SSP Interrupt Enable) bit enables SSP interrupts. The appropriate global and

    peripheral interrupt enable bits must be set in conjunction with this bit to allow interrupts to

    occur.

  • 10

    4 SPP I2C Operation

    The SSP module in I2C mode fully implements all slave functions, except general call support,

    and provides interrupts on start and stop bits in hardware to facilitate software

    implementations of the master functions. The SSP module implements the standard mode

    specifications as well as 7-bit and 10-bit addressing.

    The user must configure the SCL and the SDA pins as inputs through the TRIS bits. The SSP

    module functions are enabled by setting SSP Enable bit, SSPEN (SSPCON).

    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.

    Figure 6: SSP Block Diagram (I2C Mode)

    The SSP module has five registers for I2C operation. They are:

    SSP Control Register (SSPCON)

    SSP Status Register (SSPSTAT)

    Serial Receive/Transmit Buffer (SSPBUF)

    SSP Shift Register (SSPSR) - Not directly accessible

    SSP Address Register (SSPADD)

    The SSPCON register allows control of the I2C operation. Four mode selection bits,

    (SSPCON) allow one of the following I2C modes to be selected:

  • 11

    I2C Slave mode (7-bit address)

    I2C Slave mode (10-bit address)

    I2C Firmware controlled Multi-Master mode (start and stop bit interrupts enabled)

    I2C Firmware controlled Multi-Master mode (start and stop bit interrupts enabled)

    I2C Firmware controlled Master mode, slave is idle

    Before selecting any I2C mode, the SCL and SDA pins must be programmed to inputs by setting

    the appropriate TRIS bits. Selecting an I2C 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.

    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 the SSPOV bit (SSPCON) 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).

    4.1 Slave Mode

    The SSP module will override the input state with the output data when required (slave-

    transmitter). 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 SSP module not to give this ACK pulse. These

    are if either (or both):

    a. The buffer full bit, BF (SSPSTAT), was set before the message completed.

    b. The overflow bit, SSPOV (SSPCON), was set before the message completed.

    In this case, the SSPSR register value is not loaded into the SSPBUF, but the SSPIF and SSPOV

    bits are set. 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 SSP module is

    shown in Device Data Sheet electrical specifications parameters 100 and 101.

  • 12

    4.2 Addressing

    Once the SSP 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. The SSPSR register value is loaded into the SSPBUF register on the falling edge of the

    eight SCL pulse.

    b. The buffer full bit, BF, is set on the falling edge of the eighth SCL pulse.

    c. An ACK pulse is generated.

    d. SSP interrupt flag bit, SSPIF, is set (interrupt is generated if enabled) - on the falling edge

    of the ninth 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. The R/W bit

    (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. Receive first (high) byte of Address (the SSPIF, BF, and UA (SSPSTAT) bits are set).

    2. Update the SSPADD register with second (low) byte of Address (clears the UA bit and

    releases the SCL line).

    3. Read the SSPBUF register (clears the BF bit) and clear the SSPIF flag bit.

    4. Receive second (low) byte of Address (the SSPIF, BF, and UA bits are set).

    5. Update the SSPADD register with the high byte of Address. This will clear the UA bit and

    releases SCL line.

    6. Read the SSPBUF register (clears the BF bit) and clear the SSPIF flag bit.

    7. Receive repeated START condition.

    8. Receive first (high) byte of Address (the SSPIF and BF bits are set).

    9. Read the SSPBUF register (clears the BF bit) and clear the SSPIF flag bit.

    4.3 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.

  • 13

    When the address byte overflow condition exists,then no acknowledge (ACK) pulse is given. An

    overflow condition is defined as either the BF bit (SSPSTAT) is set or the SSPOV bit

    (SSPCON) is set. So when a byte is received, with these conditions, and attempts to move

    from the SSPSR register to the SSPBUF register, no acknowledge pulse is given.

    An SSP interrupt is generated for each data transfer byte. The SSPIF flag bit must be cleared in

    software. The SSPSTAT register is used to determine the status of the receive byte.

    Figure 7: I2C Waveforms for Reception (7-bit Address)

    4.4 Transmission

    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 the SCL pin should

    be enabled by setting the CKP bit (SSPCON). 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 8). 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.

    As a slave-transmitter, the ACK pulse from the master-receiver 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

  • 14

    be loaded into the SSPBUF register, which also loads the SSPSR register. Then the SCL pin

    should be enabled by setting the CKP bit.

    Figure 8: I2C Waveforms for Transmission (7-bit Address)

    4.5 Clock Arbitration

    Clock arbitration has the SCL pin to inhibit the master device from sending the next clock pulse.

    The SSP module in I2C slave mode will hold the SCL pin low when the CPU needs to respond to

    the SSP interrupt (SSPIF bit is set and the CKP bit is cleared). The data that needs to be

    transmitted will need to be written to the SSPBUF register, and then the CKP bit will need to be

    set to allow the master to generate the required clocks.

    4.6 Master Mode (Firmware)

    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 SSP

    module is disabled. Control of the I2C bus may be taken when the P bit is set, or the bus is idle

    with both the S and P bits clear. In master mode the SCL and SDA lines are manipulated by

    clearing the corresponding TRIS bit(s). The output level is always low, irrespective of the

    value(s) in the PORT register. So when transmitting data, a '1' data bit must have its TRIS bit set

    (input) and a '0' data bit must have its TRIS bit cleared (output). The same scenario is true for

    the SCL line with the TRIS bit.

    The following events will cause SSP Interrupt Flag bit, SSPIF, to be set (SSP Interrupt if enabled):

    START condition

    STOP condition

    Data transfer byte transmitted/received

  • 15

    Master mode of operation can be done with either the slave mode idle (SSPM3:SSPM0 = 1011)

    or with the slave active (SSPM3:SSP0 = 1110 or 1111). When the slave modes are enabled, the

    software needs to differentiate the source(s) of the interrupt.

    4.7 Multi-Master Mode (Firmware)

    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 SSP module is disabled. Control of the I 2C bus may be taken

    when the P bit (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 to see if the signal level is the

    expected output level. This check only needs to be done when a high level is output. If a high

    level is expected and a low level is present, the device needs to release the SDA and SCL lines

    (set the TRIS bits). There are two stages where this arbitration can be lost, they are:

    Address transfer

    Data transfer

    When the slave logic is enabled, the slave continues to receive. If arbitration was lost during the

    address transfer stage, communication to the device may be in progress. If addressed an ACK

    pulse will be generated. If arbitration was lost during the data transfer stage, the device will

    need to retransfer the data at a later time.

    5 References

    PICmicro Mid-Range MCU Family Reference Manual, Microchip.

    Overview and Use of the PICmicro MSSP I2C Interface with a 24xx01x EEPROM,

    Microchip

    AN734, Using the PIC Devices SSP and MSSP Modules Slave I2C Communication,

    Stephen Bowling and Naveen Raj, Microchip.th a 24xx01x EEPROM