2013-08-07 16:54:10 +02:00
|
|
|
/*
|
2013-08-27 15:52:20 +02:00
|
|
|
* i2c.h - Definitions for the I2C interface and the functions
|
|
|
|
* for the LPC2387 chip.
|
|
|
|
*
|
2013-08-07 16:54:10 +02:00
|
|
|
* Copyright (C) 2013 Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* This source code is licensed under the LGPLv2 license,
|
|
|
|
* See the file LICENSE for more details.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @internal
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief The I2C interface driver definitions for the LPC2387 chip.
|
|
|
|
* The driver is full abstracted supporting all the i2c-interfaces
|
|
|
|
* of the LPC2387 chip. The user need only to give the requested
|
|
|
|
* i2c-interface and the transmission baudrate. The user can
|
|
|
|
* optionally give its own master interrupt handler. If the user
|
|
|
|
* does not declare a handler, an appropriate interrupt is
|
|
|
|
* automatically registered for the specific i2c-interface.
|
|
|
|
*
|
|
|
|
* @author Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
|
|
|
* @author Marco Ziegert <ziegert@inf.fu-berlin.de>
|
|
|
|
* @author Benjamin Aschenbrenner
|
|
|
|
* @version $Revision: 3857 $
|
|
|
|
*
|
|
|
|
* @note $Id: i2c.h 3857 2013-09-02 18:11:27 kasmi $
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
|
2013-08-27 15:52:20 +02:00
|
|
|
#ifndef __I2C_H
|
2013-08-07 16:54:10 +02:00
|
|
|
#define __I2C_H
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2013-08-27 15:52:20 +02:00
|
|
|
#define I2C_BUFSIZE 0x23
|
|
|
|
#define MAX_TIMEOUT 0x00FFFFFF
|
2013-08-07 16:54:10 +02:00
|
|
|
|
2013-08-27 15:52:20 +02:00
|
|
|
#define I2CMASTER 0x01
|
|
|
|
#define I2CSLAVE 0x02
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
//define slave addresses and data registers
|
|
|
|
|
2013-08-27 15:52:20 +02:00
|
|
|
#define RD_BIT 0x01
|
|
|
|
#define AUTO_INC_BIT 0x80
|
|
|
|
#define WRITE_ENABLE_BIT_MASK 0XFE
|
|
|
|
#define READ_ENABLE_BIT_MASK 0x1
|
|
|
|
|
|
|
|
#define I2C_IDLE 0
|
|
|
|
#define I2C_STARTED 1
|
|
|
|
#define I2C_RESTARTED 2
|
|
|
|
#define I2C_REPEATED_START 3
|
|
|
|
#define DATA_ACK 4
|
|
|
|
#define DATA_NACK 5
|
|
|
|
|
|
|
|
#define I2CONSET_I2EN 0x00000040 /* I2C Control Set Register */
|
|
|
|
#define I2CONSET_AA 0x00000004
|
|
|
|
#define I2CONSET_SI 0x00000008
|
|
|
|
#define I2CONSET_STO 0x00000010
|
|
|
|
#define I2CONSET_STA 0x00000020
|
|
|
|
|
|
|
|
#define I2CONCLR_AAC 0x00000004 /* I2C Control clear Register */
|
|
|
|
#define I2CONCLR_SIC 0x00000008
|
|
|
|
#define I2CONCLR_STAC 0x00000020
|
|
|
|
#define I2CONCLR_I2ENC 0x00000040
|
|
|
|
|
|
|
|
#define I2DAT_I2C 0x00000000 /* I2C Data Reg */
|
|
|
|
#define I2ADR_I2C 0x00000000 /* I2C Slave Address Reg */
|
|
|
|
#define I2SCLH_SCLH 45 /* I2C SCL Duty Cycle High Reg */
|
|
|
|
#define I2SCLL_SCLL 45 /* I2C SCL Duty Cycle Low Reg */
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
//I2C interfaces
|
2013-08-27 15:52:20 +02:00
|
|
|
#define I2C0 0 // P0.27 SDA0, P0.28 SCL0
|
|
|
|
#define I2C1_0 1 // P0.0 SDA1, P0.1 SCL1
|
|
|
|
#define I2C1_1 2 // P0.19 SDA1, P0.20 SCL1
|
|
|
|
#define I2C2 3 // P0.10 SDA2, P0.11 SCL2
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/* Functions definitions */
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Initialize the I2C-Interface with the appropriate operation
|
|
|
|
* mode, baud rate and other parameter.
|
|
|
|
* The user can optionally give a master interrupt handler. If the
|
|
|
|
* user does not declare a handler, an appropriate interrupt is
|
|
|
|
* automatically registered for the specific i2c interface.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] i2c_mode the operating mode.
|
|
|
|
* @param[in] slave_addr the slave address.
|
|
|
|
* @param[in] baud_rate the baud rate.
|
|
|
|
* @param[in] handler the I2C2 Interrupt handler (optional); by giving
|
|
|
|
* a NULL as parameter, an appropriate interrupt is
|
|
|
|
* automatically selected.
|
|
|
|
*
|
|
|
|
* @return true if the I2C interrupt handler was installed correctly, otherwise
|
|
|
|
* false.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
bool i2c_initialize(uint8_t i2c_interface, uint32_t i2c_mode,
|
2013-08-27 15:52:20 +02:00
|
|
|
uint8_t slave_addr, uint32_t baud_rate, void *handler);
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Read from an appropriate slave device over the I2C-Interface.
|
|
|
|
* The read values are stored in a buffer, which it is handed to
|
|
|
|
* the function.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] slave_addr the slave address
|
|
|
|
* @param[in] reg_addr a register address, which is residing in the
|
|
|
|
* slave device.
|
|
|
|
* @param[out] rx_buff a pointer to a receive buffer.
|
|
|
|
* @param[in] rx_buff_length the number of receiving bytes resp.
|
|
|
|
* the receive-buffer length.
|
|
|
|
*
|
|
|
|
* @return true if the read transaction is successfully completed, otherwise
|
|
|
|
* false.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
bool i2c_read(uint8_t i2c_interface, uint8_t slave_addr, uint8_t reg_addr,
|
2013-08-27 15:52:20 +02:00
|
|
|
uint8_t *rx_buff, uint8_t rx_buff_length);
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Write to an appropriate slave device over the I2C-Interface.
|
|
|
|
* The values are stored in a buffer, which it is handed to the
|
|
|
|
* function.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] slave_addr the slave address
|
|
|
|
* @param[in] reg_addr a register address, which is residing in the
|
|
|
|
* slave device.
|
|
|
|
* @param[in] tx_buff pointer to a transmitting buffer.
|
|
|
|
* @param[in] tx_buff_length the number of transmitting bytes resp.
|
|
|
|
* the transmit-buffer length.
|
|
|
|
*
|
|
|
|
* @return true if the write transaction is successfully completed, otherwise
|
|
|
|
* false.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
bool i2c_write(uint8_t i2c_interface, uint8_t slave_addr, uint8_t reg_addr,
|
2013-08-27 15:52:20 +02:00
|
|
|
uint8_t *tx_buff, uint8_t tx_buff_length);
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Simultaneous sending and receiving to/from the I2C-Interface.
|
|
|
|
* The sending/receiving bytes are stored in two buffers, which are
|
|
|
|
* handed to the function.
|
|
|
|
*
|
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] slave_addr slave address
|
|
|
|
* @param[in] tx_buff pointer to a sending buffer.
|
|
|
|
* @param[in] tx_buff_length the number of sending bytes resp.
|
|
|
|
* the send-buffer length.
|
|
|
|
* @param[out] rx_buff pointer to a receive buffer.
|
|
|
|
* @param[in] rx_buff_length the number of receiving bytes resp.
|
|
|
|
* the receive-buffer length.
|
|
|
|
*
|
|
|
|
* @return true if the write/receive transaction are successfully completed,
|
|
|
|
* otherwise false.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
bool i2c_trans_receive(uint8_t i2c_interface, uint8_t slave_addr,
|
2013-08-27 15:52:20 +02:00
|
|
|
uint8_t *tx_buff, uint8_t tx_buff_length,
|
|
|
|
uint8_t *rx_buff, uint8_t rx_buff_length);
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Enable the appropriate I2C interface.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void i2c_active_power(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Select the appropriate pins for the I2C interface.
|
|
|
|
* It selects the respective Serial Data Line (SDAx) and Serial
|
|
|
|
* Clock (SCLx).
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void i2c_pin_select(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Clear the I2C control register.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void i2c_clear_control_register(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Set the I2C baud rate.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] baud_rate the baud rate.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void i2c_set_baud_rate(uint8_t i2c_interface, uint32_t baud_rate);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Register an interrupt handler for the I2C interface.
|
|
|
|
* The user can register his own irq-handler.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] handler the i2c irq-handler.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @return true if the the interrupt handler is successfully registered,
|
|
|
|
* otherwise false.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
2013-08-27 15:52:20 +02:00
|
|
|
bool i2c_irq_handler_register(uint8_t i2c_interface, void *handler);
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief This routine complete a I2C transaction from start to stop
|
|
|
|
* conditions.
|
|
|
|
* All the intermitten steps are handled in the interrupt handler.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @return false if the start condition can never be generated and timed out,
|
|
|
|
* otherwise true.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
bool i2c_transaction(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Enable master transmitter mode for the appropriate
|
|
|
|
* i2c-interface.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void i2c_initial_master_transmitter_mode(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Set slave mode for the appropriate i2c-interface.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
|
|
|
* @param[in] slave_addr the slave address.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
void i2c_set_slave_mode(uint8_t i2c_interface, uint8_t slave_addr);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Clear a number of bytes in a buffer.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] ptr pointer to a buffer
|
|
|
|
* @param[in] size the number of bytes, that must be cleared.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*/
|
2013-08-27 15:52:20 +02:00
|
|
|
void i2c_clear_buffer(void *ptr, uint32_t size);
|
2013-08-07 16:54:10 +02:00
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Create a I2C start condition.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
* @return false if the start condition is timed out, otherwise true.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
bool i2c_start(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Set a I2C stop condition.
|
|
|
|
* If the function never exit, it's a fatal bus error
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
*
|
2013-08-27 15:52:20 +02:00
|
|
|
* @param[in] i2c_interface the i2c interface, several interfaces can be
|
|
|
|
* selected: i2c0, i2c1 and i2c2.
|
2013-08-07 16:54:10 +02:00
|
|
|
*
|
|
|
|
* @return true if the stop condition is issued, otherwise it never returns.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
bool i2c_stop(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Enable the on-chip pull-up resistor for the appropriate
|
|
|
|
* i2c-interface.
|
|
|
|
*
|
|
|
|
* @param[in] i2c_interface the i2c interface, only the i2c1 and the
|
|
|
|
* i2c2-interfaces are supported. The pin mode
|
|
|
|
* cannot be selected for pins P0[27] to P0[31].
|
|
|
|
* Pins P0[27] and P0[28] are dedicated I2C
|
|
|
|
* open-drain pins without pull-up/down.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
void i2c_enable_pull_up_resistor(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-08-27 15:52:20 +02:00
|
|
|
* @brief Disable the on-chip pull-up resistor for the appropriate
|
|
|
|
* i2c-interface.
|
|
|
|
*
|
|
|
|
* @param[in] i2c_interface the i2c interface, only the i2c1 and the
|
|
|
|
* i2c2-interfaces are supported. The pin mode
|
|
|
|
* cannot be selected for pins P0[27] to P0[31].
|
|
|
|
* Pins P0[27] and P0[28] are dedicated I2C
|
|
|
|
* open-drain pins without pull-up/down.
|
2013-08-07 16:54:10 +02:00
|
|
|
*/
|
|
|
|
void i2c_disable_pull_up_resistor(uint8_t i2c_interface);
|
|
|
|
|
|
|
|
#endif /* end __I2C_H */
|