Blame view

RIOT/drivers/include/periph/i2c.h 9.12 KB
a752c7ab   elopes   add first test an...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
  /*
   * Copyright (C) 2014-2015 Freie Universitรคt Berlin
   *
   * This file is subject to the terms and conditions of the GNU Lesser
   * General Public License v2.1. See the file LICENSE in the top level
   * directory for more details.
   */
  
  /**
   * @defgroup    drivers_periph_i2c I2C
   * @ingroup     drivers_periph
   * @brief       Low-level I2C peripheral driver
   *
   * This is a simple I2C interface to allow platform independent access to a
   * MCU's I2C bus and peripherals. This interface is intentionally designed as
   * simple as possible, to allow for easy implementation and maximal portability.
   *
   * @note        The current version of this interface only supports the
   *              7-bit addressing mode.
   *
   * @note        This interface is due for remodeling, hence API changes are to
   *              be expected for upcoming releases.
   *
   * ## A note on pull-up resistors for SDA/SCL
   *
   * The I2C signal lines SDA/SCL need external pull-up resistors which connect
   * the lines to the positive voltage supply VCC. The I2C driver implementation
   * should enable the pin's internal pull-up resistors. There are however some
   * use cases for which the internal pull resistors are not strong enough and the
   * I2C bus will show faulty behavior. This can for example happen when
   * connecting a logic analyzer which will raise the capacitance of the bus. In
   * this case you should make sure you connect external pull-up resistors to both
   * I2C bus lines.
   *
   * The minimum and maximum resistances are computed by:
   * \f{eqnarray*}{
   * R_{min} &=& \frac{V_{DD} - V_{OL(max)}} {I_{OL}}\\
   * R_{max} &=& \frac{t_r} {(0.8473 \cdot C_b)}
   * \f}<br>
   * where:<br>
   * \f$ V_{DD} =\f$ Supply voltage,
   * \f$ V_{OL(max)} =\f$ Low level voltage,
   * \f$ I_{OL} =\f$ Low level output current,
   * \f$ t_r =\f$ Signal rise time,
   * \f$ C_b =\f$ Bus capacitance <br>
   * <br>The pull-up resistors depend on the bus speed.
   * Some typical values are:<br>
   * Normal mode:       10k&Omega;<br>
   * Fast mode:          2k&Omega;<br>
   * Fast plus mode:     2k&Omega;
   *
   * For more details refer to section 7.1 in:<br>
   * http://www.nxp.com/documents/user_manual/UM10204.pdf
   *
   * @{
   * @file
   * @brief       Low-level I2C peripheral driver interface definition
   *
   * @author      Hauke Petersen <hauke.petersen@fu-berlin.de>
   * @author      Thomas Eichinger <thomas.eichinger@fu-berlin.de>
   */
  
  #ifndef PERIPH_I2C_H
  #define PERIPH_I2C_H
  
  #include <stdint.h>
  #include <limits.h>
  
  #include "periph_cpu.h"
  /**
   * @todo    Remove dev_enums.h include once all platforms are ported to the
   *          updated periph interface
   */
  #include "periph/dev_enums.h"
  
  #ifdef __cplusplus
  extern "C" {
  #endif
  
  /**
   * @brief   Flag signaling a write operation on the bus
   */
  #define I2C_FLAG_WRITE      0
  
  /**
   * @brief   Flag signaling a read operation on the bus
   */
  #define I2C_FLAG_READ       1
  
  /**
   * @brief   Default I2C device access macro
   */
  #ifndef I2C_DEV
  #define I2C_DEV(x)          (x)
  #endif
  
  /**
   * @brief   Default I2C undefined value
   */
  #ifndef I2C_UNDEF
  #define I2C_UNDEF           (UINT_MAX)
  #endif
  
  /**
   * @brief   Default i2c_t type definition
   */
  #ifndef HAVE_I2C_T
  typedef unsigned int i2c_t;
  #endif
  
  /**
   * @brief   Default mapping of I2C bus speed values
   */
  #ifndef HAVE_I2C_SPEED_T
  typedef enum {
      I2C_SPEED_LOW = 0,      /**< low speed mode:    ~10kbit/s */
      I2C_SPEED_NORMAL,       /**< normal mode:       ~100kbit/s */
      I2C_SPEED_FAST,         /**< fast mode:         ~400kbit/sj */
      I2C_SPEED_FAST_PLUS,    /**< fast plus mode:    ~1Mbit/s */
      I2C_SPEED_HIGH,         /**< high speed mode:   ~3.4Mbit/s */
  } i2c_speed_t;
  #endif
  
  /**
   * @brief   Initialize an I2C device to run as bus master
   *
   * @param[in] dev           the device to initialize
   * @param[in] speed         the selected bus speed
   *
   * @return                  0 on successful initialization
   * @return                  -1 on undefined device given
   * @return                  -2 on unsupported speed value
   */
  int i2c_init_master(i2c_t dev, i2c_speed_t speed);
  
  /**
   * @brief   Get mutually exclusive access to the given I2C bus
   *
   * In case the I2C device is busy, this function will block until the bus is
   * free again.
   *
   * @param[in] dev       I2C device to access
   *
   * @return              0 on success
   * @return              -1 on error
   */
  int i2c_acquire(i2c_t dev);
  
  /**
   * @brief   Release the given I2C device to be used by others
   *
   * @param[in] dev       I2C device to release
   *
   * @return              0 on success
   * @return              -1 on error
   */
  int i2c_release(i2c_t dev);
  
  /**
   * @brief   Read one byte from an I2C device with the given address
   *
   * @param[in]  dev          I2C peripheral device
   * @param[in]  address      bus address of the target device
   * @param[out] data         the result that was read
   *
   * @return                  the number of bytes that were read
   * @return                  -1 on undefined device given
   * @return                  -2 on invalid address
   */
  int i2c_read_byte(i2c_t dev, uint8_t address, void *data);
  
  /**
   * @brief   Read multiple bytes from an I2C device with the given address
   *
   * @param[in]  dev          I2C peripheral device
   * @param[in]  address      bus address of the target device
   * @param[out] data         array holding the received bytes
   * @param[in]  length       the number of bytes to read into `data`
   *
   * @return                  the number of bytes that were read
   * @return                  -1 on undefined device given
   */
  int i2c_read_bytes(i2c_t dev, uint8_t address, void *data, int length);
  
  /**
   * @brief   Read one byte from a register at the I2C slave with the given
   *          address
   *
   * @param[in]  dev          I2C peripheral device
   * @param[in]  address      bus address of the target device
   * @param[in]  reg          the register address on the targeted I2C device
   * @param[out] data         the result that was read
   *
   * @return                  the number of bytes that were read
   * @return                  -1 on undefined device given
   */
  int i2c_read_reg(i2c_t dev, uint8_t address, uint8_t reg, void *data);
  
  /**
   * @brief   Read multiple bytes from a register at the I2C slave with the given
   *          address
   *
   * @param[in]  dev          I2C peripheral device
   * @param[in]  address      bus address of the target device
   * @param[in]  reg          the register address on the targeted I2C device
   * @param[out] data         array holding the received bytes
   * @param[in]  length       the number of bytes to read into `data`
   *
   * @return                  the number of bytes that were read
   * @return                  -1 on undefined device given
   */
  int i2c_read_regs(i2c_t dev, uint8_t address, uint8_t reg,
                    void *data, int length);
  
  /**
   * @brief   Write one byte to an I2C device with the given address
   *
   * @param[in] dev           I2C peripheral device
   * @param[in] address       bus address of the target device
   * @param[in] data          byte to write to the device
   *
   * @return                  the number of bytes that were written
   * @return                  -1 on undefined device given
   */
  int i2c_write_byte(i2c_t dev, uint8_t address, uint8_t data);
  
  /**
   * @brief   Write multiple bytes to an I2C device with the given address
   *
   * @param[in] dev           I2C peripheral device
   * @param[in] address       bus address of the target device
   * @param[in] data          array with bytes to write to the target device
   * @param[in] length        number of bytes to write to the target device
   *
   * @return                  the number of bytes that were written
   * @return                  -1 on undefined device given
   */
  int i2c_write_bytes(i2c_t dev, uint8_t address, const void *data, int length);
  
  /**
   * @brief   Write one byte to a register at the I2C slave with the given address
   *
   * @param[in] dev           I2C peripheral device
   * @param[in] address       bus address of the target device
   * @param[in] reg           the register address on the targeted I2C device
   * @param[in] data          byte to write to the device
   *
   * @return                  the number of bytes that were written
   * @return                  -1 on undefined device given
   */
  int i2c_write_reg(i2c_t dev, uint8_t address, uint8_t reg, uint8_t data);
  
  /**
   * @brief   Write multiple bytes to a register at the I2C slave with the given
   *          address
   *
   * @param[in] dev           I2C peripheral device
   * @param[in] address       bus address of the target device
   * @param[in] reg           the register address on the targeted I2C device
   * @param[in] data          array with bytes to write to the target device
   * @param[in] length        number of bytes to write to the target device
   *
   * @return                  the number of bytes that were written
   * @return                  -1 on undefined device given
   */
  int i2c_write_regs(i2c_t dev, uint8_t address, uint8_t reg,
                     const void *data, int length);
  
  /**
   * @brief   Power on the given I2C peripheral
   *
   * @param[in] dev           the I2C device to power on
   */
  void i2c_poweron(i2c_t dev);
  
  /**
   * @brief   Power off the given I2C peripheral
   *
   * @param[in] dev           the I2C device to power off
   */
  void i2c_poweroff(i2c_t dev);
  
  #ifdef __cplusplus
  }
  #endif
  
  #endif /* PERIPH_I2C_H */
  /** @} */