xref: /nrf52832-nimble/nordic/nrfx/drivers/include/nrfx_twim.h (revision 150812a83cab50279bd772ef6db1bfaf255f2c5b)
1*150812a8SEvalZero /*
2*150812a8SEvalZero  * Copyright (c) 2015 - 2018, Nordic Semiconductor ASA
3*150812a8SEvalZero  * All rights reserved.
4*150812a8SEvalZero  *
5*150812a8SEvalZero  * Redistribution and use in source and binary forms, with or without
6*150812a8SEvalZero  * modification, are permitted provided that the following conditions are met:
7*150812a8SEvalZero  *
8*150812a8SEvalZero  * 1. Redistributions of source code must retain the above copyright notice, this
9*150812a8SEvalZero  *    list of conditions and the following disclaimer.
10*150812a8SEvalZero  *
11*150812a8SEvalZero  * 2. Redistributions in binary form must reproduce the above copyright
12*150812a8SEvalZero  *    notice, this list of conditions and the following disclaimer in the
13*150812a8SEvalZero  *    documentation and/or other materials provided with the distribution.
14*150812a8SEvalZero  *
15*150812a8SEvalZero  * 3. Neither the name of the copyright holder nor the names of its
16*150812a8SEvalZero  *    contributors may be used to endorse or promote products derived from this
17*150812a8SEvalZero  *    software without specific prior written permission.
18*150812a8SEvalZero  *
19*150812a8SEvalZero  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20*150812a8SEvalZero  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21*150812a8SEvalZero  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22*150812a8SEvalZero  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23*150812a8SEvalZero  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24*150812a8SEvalZero  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25*150812a8SEvalZero  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26*150812a8SEvalZero  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27*150812a8SEvalZero  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28*150812a8SEvalZero  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29*150812a8SEvalZero  * POSSIBILITY OF SUCH DAMAGE.
30*150812a8SEvalZero  */
31*150812a8SEvalZero 
32*150812a8SEvalZero #ifndef NRFX_TWIM_H__
33*150812a8SEvalZero #define NRFX_TWIM_H__
34*150812a8SEvalZero 
35*150812a8SEvalZero #include <nrfx.h>
36*150812a8SEvalZero #include <hal/nrf_twim.h>
37*150812a8SEvalZero 
38*150812a8SEvalZero #ifdef __cplusplus
39*150812a8SEvalZero extern "C" {
40*150812a8SEvalZero #endif
41*150812a8SEvalZero 
42*150812a8SEvalZero /**
43*150812a8SEvalZero  * @defgroup nrfx_twim TWIM driver
44*150812a8SEvalZero  * @{
45*150812a8SEvalZero  * @ingroup nrf_twim
46*150812a8SEvalZero  * @brief   TWIM peripheral driver.
47*150812a8SEvalZero  */
48*150812a8SEvalZero 
49*150812a8SEvalZero /**
50*150812a8SEvalZero  * @brief Structure for the TWI master driver instance.
51*150812a8SEvalZero  */
52*150812a8SEvalZero typedef struct
53*150812a8SEvalZero {
54*150812a8SEvalZero     NRF_TWIM_Type * p_twim;       ///< Pointer to a structure with TWIM registers.
55*150812a8SEvalZero     uint8_t         drv_inst_idx; ///< Driver instance index.
56*150812a8SEvalZero } nrfx_twim_t;
57*150812a8SEvalZero 
58*150812a8SEvalZero /**
59*150812a8SEvalZero  * @brief Macro for creating a TWI master driver instance.
60*150812a8SEvalZero  */
61*150812a8SEvalZero #define NRFX_TWIM_INSTANCE(id)                               \
62*150812a8SEvalZero {                                                            \
63*150812a8SEvalZero     .p_twim       = NRFX_CONCAT_2(NRF_TWIM, id),             \
64*150812a8SEvalZero     .drv_inst_idx = NRFX_CONCAT_3(NRFX_TWIM, id, _INST_IDX), \
65*150812a8SEvalZero }
66*150812a8SEvalZero 
67*150812a8SEvalZero enum {
68*150812a8SEvalZero #if NRFX_CHECK(NRFX_TWIM0_ENABLED)
69*150812a8SEvalZero     NRFX_TWIM0_INST_IDX,
70*150812a8SEvalZero #endif
71*150812a8SEvalZero #if NRFX_CHECK(NRFX_TWIM1_ENABLED)
72*150812a8SEvalZero     NRFX_TWIM1_INST_IDX,
73*150812a8SEvalZero #endif
74*150812a8SEvalZero #if NRFX_CHECK(NRFX_TWIM2_ENABLED)
75*150812a8SEvalZero     NRFX_TWIM2_INST_IDX,
76*150812a8SEvalZero #endif
77*150812a8SEvalZero #if NRFX_CHECK(NRFX_TWIM3_ENABLED)
78*150812a8SEvalZero     NRFX_TWIM3_INST_IDX,
79*150812a8SEvalZero #endif
80*150812a8SEvalZero     NRFX_TWIM_ENABLED_COUNT
81*150812a8SEvalZero };
82*150812a8SEvalZero 
83*150812a8SEvalZero /**
84*150812a8SEvalZero  * @brief Structure for the TWI master driver instance configuration.
85*150812a8SEvalZero  */
86*150812a8SEvalZero typedef struct
87*150812a8SEvalZero {
88*150812a8SEvalZero     uint32_t             scl;                 ///< SCL pin number.
89*150812a8SEvalZero     uint32_t             sda;                 ///< SDA pin number.
90*150812a8SEvalZero     nrf_twim_frequency_t frequency;           ///< TWIM frequency.
91*150812a8SEvalZero     uint8_t              interrupt_priority;  ///< Interrupt priority.
92*150812a8SEvalZero     bool                 hold_bus_uninit;     ///< Hold pull up state on gpio pins after uninit.
93*150812a8SEvalZero } nrfx_twim_config_t;
94*150812a8SEvalZero 
95*150812a8SEvalZero /**
96*150812a8SEvalZero  * @brief TWI master driver instance default configuration.
97*150812a8SEvalZero  */
98*150812a8SEvalZero #define NRFX_TWIM_DEFAULT_CONFIG                                                    \
99*150812a8SEvalZero {                                                                                   \
100*150812a8SEvalZero     .frequency          = (nrf_twim_frequency_t)NRFX_TWIM_DEFAULT_CONFIG_FREQUENCY, \
101*150812a8SEvalZero     .scl                = 31,                                                       \
102*150812a8SEvalZero     .sda                = 31,                                                       \
103*150812a8SEvalZero     .interrupt_priority = NRFX_TWIM_DEFAULT_CONFIG_IRQ_PRIORITY,                    \
104*150812a8SEvalZero     .hold_bus_uninit    = NRFX_TWIM_DEFAULT_CONFIG_HOLD_BUS_UNINIT,                 \
105*150812a8SEvalZero }
106*150812a8SEvalZero 
107*150812a8SEvalZero #define NRFX_TWIM_FLAG_TX_POSTINC          (1UL << 0) /**< TX buffer address incremented after transfer. */
108*150812a8SEvalZero #define NRFX_TWIM_FLAG_RX_POSTINC          (1UL << 1) /**< RX buffer address incremented after transfer. */
109*150812a8SEvalZero #define NRFX_TWIM_FLAG_NO_XFER_EVT_HANDLER (1UL << 2) /**< Interrupt after each transfer is suppressed, and the event handler is not called. */
110*150812a8SEvalZero #define NRFX_TWIM_FLAG_HOLD_XFER           (1UL << 3) /**< Set up the transfer but do not start it. */
111*150812a8SEvalZero #define NRFX_TWIM_FLAG_REPEATED_XFER       (1UL << 4) /**< Flag indicating that the transfer will be executed multiple times. */
112*150812a8SEvalZero #define NRFX_TWIM_FLAG_TX_NO_STOP          (1UL << 5) /**< Flag indicating that the TX transfer will not end with a stop condition. */
113*150812a8SEvalZero 
114*150812a8SEvalZero /**
115*150812a8SEvalZero  * @brief TWI master driver event types.
116*150812a8SEvalZero  */
117*150812a8SEvalZero typedef enum
118*150812a8SEvalZero {
119*150812a8SEvalZero     NRFX_TWIM_EVT_DONE,         ///< Transfer completed event.
120*150812a8SEvalZero     NRFX_TWIM_EVT_ADDRESS_NACK, ///< Error event: NACK received after sending the address.
121*150812a8SEvalZero     NRFX_TWIM_EVT_DATA_NACK     ///< Error event: NACK received after sending a data byte.
122*150812a8SEvalZero } nrfx_twim_evt_type_t;
123*150812a8SEvalZero 
124*150812a8SEvalZero /**
125*150812a8SEvalZero  * @brief TWI master driver transfer types.
126*150812a8SEvalZero  */
127*150812a8SEvalZero typedef enum
128*150812a8SEvalZero {
129*150812a8SEvalZero     NRFX_TWIM_XFER_TX,          ///< TX transfer.
130*150812a8SEvalZero     NRFX_TWIM_XFER_RX,          ///< RX transfer.
131*150812a8SEvalZero     NRFX_TWIM_XFER_TXRX,        ///< TX transfer followed by RX transfer with repeated start.
132*150812a8SEvalZero     NRFX_TWIM_XFER_TXTX         ///< TX transfer followed by TX transfer with repeated start.
133*150812a8SEvalZero } nrfx_twim_xfer_type_t;
134*150812a8SEvalZero 
135*150812a8SEvalZero /**
136*150812a8SEvalZero  * @brief Structure for a TWI transfer descriptor.
137*150812a8SEvalZero  */
138*150812a8SEvalZero typedef struct
139*150812a8SEvalZero {
140*150812a8SEvalZero     nrfx_twim_xfer_type_t   type;             ///< Type of transfer.
141*150812a8SEvalZero     uint8_t                 address;          ///< Slave address.
142*150812a8SEvalZero     size_t                  primary_length;   ///< Number of bytes transferred.
143*150812a8SEvalZero     size_t                  secondary_length; ///< Number of bytes transferred.
144*150812a8SEvalZero     uint8_t *               p_primary_buf;    ///< Pointer to transferred data.
145*150812a8SEvalZero     uint8_t *               p_secondary_buf;  ///< Pointer to transferred data.
146*150812a8SEvalZero } nrfx_twim_xfer_desc_t;
147*150812a8SEvalZero 
148*150812a8SEvalZero 
149*150812a8SEvalZero /**@brief Macro for setting the TX transfer descriptor. */
150*150812a8SEvalZero #define NRFX_TWIM_XFER_DESC_TX(addr, p_data, length) \
151*150812a8SEvalZero     {                                                \
152*150812a8SEvalZero         .type = NRFX_TWIM_XFER_TX,                   \
153*150812a8SEvalZero         .address = addr,                             \
154*150812a8SEvalZero         .primary_length = length,                    \
155*150812a8SEvalZero         .p_primary_buf  = p_data,                    \
156*150812a8SEvalZero     }
157*150812a8SEvalZero 
158*150812a8SEvalZero /**@brief Macro for setting the RX transfer descriptor. */
159*150812a8SEvalZero #define NRFX_TWIM_XFER_DESC_RX(addr, p_data, length) \
160*150812a8SEvalZero     {                                                \
161*150812a8SEvalZero         .type           = NRFX_TWIM_XFER_RX,         \
162*150812a8SEvalZero         .address        = addr,                      \
163*150812a8SEvalZero         .primary_length = length,                    \
164*150812a8SEvalZero         .p_primary_buf  = p_data,                    \
165*150812a8SEvalZero     }
166*150812a8SEvalZero 
167*150812a8SEvalZero /**@brief Macro for setting the TXRX transfer descriptor. */
168*150812a8SEvalZero #define NRFX_TWIM_XFER_DESC_TXRX(addr, p_tx, tx_len, p_rx, rx_len) \
169*150812a8SEvalZero     {                                                              \
170*150812a8SEvalZero         .type             = NRFX_TWIM_XFER_TXRX,                   \
171*150812a8SEvalZero         .address          = addr,                                  \
172*150812a8SEvalZero         .primary_length   = tx_len,                                \
173*150812a8SEvalZero         .secondary_length = rx_len,                                \
174*150812a8SEvalZero         .p_primary_buf    = p_tx,                                  \
175*150812a8SEvalZero         .p_secondary_buf  = p_rx,                                  \
176*150812a8SEvalZero     }
177*150812a8SEvalZero 
178*150812a8SEvalZero /**@brief Macro for setting the TXTX transfer descriptor. */
179*150812a8SEvalZero #define NRFX_TWIM_XFER_DESC_TXTX(addr, p_tx, tx_len, p_tx2, tx_len2) \
180*150812a8SEvalZero     {                                                                \
181*150812a8SEvalZero         .type             = NRFX_TWIM_XFER_TXTX,                     \
182*150812a8SEvalZero         .address          = addr,                                    \
183*150812a8SEvalZero         .primary_length   = tx_len,                                  \
184*150812a8SEvalZero         .secondary_length = tx_len2,                                 \
185*150812a8SEvalZero         .p_primary_buf    = p_tx,                                    \
186*150812a8SEvalZero         .p_secondary_buf  = p_tx2,                                   \
187*150812a8SEvalZero     }
188*150812a8SEvalZero 
189*150812a8SEvalZero /**
190*150812a8SEvalZero  * @brief Structure for a TWI event.
191*150812a8SEvalZero  */
192*150812a8SEvalZero typedef struct
193*150812a8SEvalZero {
194*150812a8SEvalZero     nrfx_twim_evt_type_t  type;      ///< Event type.
195*150812a8SEvalZero     nrfx_twim_xfer_desc_t xfer_desc; ///< Transfer details.
196*150812a8SEvalZero } nrfx_twim_evt_t;
197*150812a8SEvalZero 
198*150812a8SEvalZero /**
199*150812a8SEvalZero  * @brief TWI event handler prototype.
200*150812a8SEvalZero  */
201*150812a8SEvalZero typedef void (* nrfx_twim_evt_handler_t)(nrfx_twim_evt_t const * p_event,
202*150812a8SEvalZero                                          void *                  p_context);
203*150812a8SEvalZero 
204*150812a8SEvalZero /**
205*150812a8SEvalZero  * @brief Function for initializing the TWI driver instance.
206*150812a8SEvalZero  *
207*150812a8SEvalZero  * @param[in] p_instance      Pointer to the driver instance structure.
208*150812a8SEvalZero  * @param[in] p_config        Pointer to the structure with initial configuration.
209*150812a8SEvalZero  * @param[in] event_handler   Event handler provided by the user. If NULL, blocking mode is enabled.
210*150812a8SEvalZero  * @param[in] p_context       Context passed to event handler.
211*150812a8SEvalZero  *
212*150812a8SEvalZero  * @retval NRFX_SUCCESS             If initialization was successful.
213*150812a8SEvalZero  * @retval NRFX_ERROR_INVALID_STATE If the driver is in invalid state.
214*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY          If some other peripheral with the same
215*150812a8SEvalZero  *                                  instance ID is already in use. This is
216*150812a8SEvalZero  *                                  possible only if @ref nrfx_prs module
217*150812a8SEvalZero  *                                  is enabled.
218*150812a8SEvalZero  */
219*150812a8SEvalZero nrfx_err_t nrfx_twim_init(nrfx_twim_t const *        p_instance,
220*150812a8SEvalZero                           nrfx_twim_config_t const * p_config,
221*150812a8SEvalZero                           nrfx_twim_evt_handler_t    event_handler,
222*150812a8SEvalZero                           void *                     p_context);
223*150812a8SEvalZero 
224*150812a8SEvalZero /**
225*150812a8SEvalZero  * @brief Function for uninitializing the TWI instance.
226*150812a8SEvalZero  *
227*150812a8SEvalZero  * @param[in] p_instance Pointer to the driver instance structure.
228*150812a8SEvalZero  */
229*150812a8SEvalZero void nrfx_twim_uninit(nrfx_twim_t const * p_instance);
230*150812a8SEvalZero 
231*150812a8SEvalZero /**
232*150812a8SEvalZero  * @brief Function for enabling the TWI instance.
233*150812a8SEvalZero  *
234*150812a8SEvalZero  * @param[in] p_instance Pointer to the driver instance structure.
235*150812a8SEvalZero  */
236*150812a8SEvalZero void nrfx_twim_enable(nrfx_twim_t const * p_instance);
237*150812a8SEvalZero 
238*150812a8SEvalZero /**
239*150812a8SEvalZero  * @brief Function for disabling the TWI instance.
240*150812a8SEvalZero  *
241*150812a8SEvalZero  * @param[in] p_instance Pointer to the driver instance structure.
242*150812a8SEvalZero  */
243*150812a8SEvalZero void nrfx_twim_disable(nrfx_twim_t const * p_instance);
244*150812a8SEvalZero 
245*150812a8SEvalZero /**
246*150812a8SEvalZero  * @brief Function for sending data to a TWI slave.
247*150812a8SEvalZero  *
248*150812a8SEvalZero  * The transmission will be stopped when an error occurs. If a transfer is ongoing,
249*150812a8SEvalZero  * the function returns the error code @ref NRFX_ERROR_BUSY.
250*150812a8SEvalZero  *
251*150812a8SEvalZero  * @note Peripherals using EasyDMA (including TWIM) require the transfer buffers
252*150812a8SEvalZero  *       to be placed in the Data RAM region. If this condition is not met,
253*150812a8SEvalZero  *       this function will fail with the error code NRFX_ERROR_INVALID_ADDR.
254*150812a8SEvalZero  *
255*150812a8SEvalZero  * @param[in] p_instance Pointer to the driver instance structure.
256*150812a8SEvalZero  * @param[in] address    Address of a specific slave device (only 7 LSB).
257*150812a8SEvalZero  * @param[in] p_data     Pointer to a transmit buffer.
258*150812a8SEvalZero  * @param[in] length     Number of bytes to send. Maximum possible length is
259*150812a8SEvalZero  *                       dependent on the used SoC (see the MAXCNT register
260*150812a8SEvalZero  *                       description in the Product Specification). The driver
261*150812a8SEvalZero  *                       checks it with assertion.
262*150812a8SEvalZero  * @param[in] no_stop    If set, the stop condition is not generated on the bus
263*150812a8SEvalZero  *                       after the transfer has completed successfully (allowing
264*150812a8SEvalZero  *                       for a repeated start in the next transfer).
265*150812a8SEvalZero  *
266*150812a8SEvalZero  * @retval NRFX_SUCCESS                  If the procedure was successful.
267*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY               If the driver is not ready for a new transfer.
268*150812a8SEvalZero  * @retval NRFX_ERROR_INTERNAL           If an error was detected by hardware.
269*150812a8SEvalZero  * @retval NRFX_ERROR_INVALID_ADDR       If the provided buffer is not placed in the Data RAM region.
270*150812a8SEvalZero  * @retval NRFX_ERROR_DRV_TWI_ERR_ANACK  If NACK received after sending the address in polling mode.
271*150812a8SEvalZero  * @retval NRFX_ERROR_DRV_TWI_ERR_DNACK  If NACK received after sending a data byte in polling mode.
272*150812a8SEvalZero  */
273*150812a8SEvalZero nrfx_err_t nrfx_twim_tx(nrfx_twim_t const * p_instance,
274*150812a8SEvalZero                         uint8_t             address,
275*150812a8SEvalZero                         uint8_t const *     p_data,
276*150812a8SEvalZero                         size_t              length,
277*150812a8SEvalZero                         bool                no_stop);
278*150812a8SEvalZero 
279*150812a8SEvalZero /**
280*150812a8SEvalZero  * @brief Function for reading data from a TWI slave.
281*150812a8SEvalZero  *
282*150812a8SEvalZero  * The transmission will be stopped when an error occurs. If a transfer is ongoing,
283*150812a8SEvalZero  * the function returns the error code @ref NRFX_ERROR_BUSY.
284*150812a8SEvalZero  *
285*150812a8SEvalZero  * @param[in] p_instance Pointer to the driver instance structure.
286*150812a8SEvalZero  * @param[in] address    Address of a specific slave device (only 7 LSB).
287*150812a8SEvalZero  * @param[in] p_data     Pointer to a receive buffer.
288*150812a8SEvalZero  * @param[in] length     Number of bytes to be received. Maximum possible length
289*150812a8SEvalZero  *                       is dependent on the used SoC (see the MAXCNT register
290*150812a8SEvalZero  *                       description in the Product Specification). The driver
291*150812a8SEvalZero  *                       checks it with assertion.
292*150812a8SEvalZero  *
293*150812a8SEvalZero  * @retval NRFX_SUCCESS                    If the procedure was successful.
294*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY                 If the driver is not ready for a new transfer.
295*150812a8SEvalZero  * @retval NRFX_ERROR_INTERNAL             If an error was detected by hardware.
296*150812a8SEvalZero  * @retval NRFX_ERROR_DRV_TWI_ERR_ANACK    If NACK received after sending the address in polling mode.
297*150812a8SEvalZero  * @retval NRFX_ERROR_DRV_TWI_ERR_DNACK    If NACK received after sending a data byte in polling mode.
298*150812a8SEvalZero  */
299*150812a8SEvalZero nrfx_err_t nrfx_twim_rx(nrfx_twim_t const * p_instance,
300*150812a8SEvalZero                         uint8_t             address,
301*150812a8SEvalZero                         uint8_t *           p_data,
302*150812a8SEvalZero                         size_t              length);
303*150812a8SEvalZero 
304*150812a8SEvalZero /**
305*150812a8SEvalZero  * @brief Function for preparing a TWI transfer.
306*150812a8SEvalZero  *
307*150812a8SEvalZero  * The following transfer types can be configured (@ref nrfx_twim_xfer_desc_t::type):
308*150812a8SEvalZero  * - @ref NRFX_TWIM_XFER_TXRX<span></span>: Write operation followed by a read operation (without STOP condition in between).
309*150812a8SEvalZero  * - @ref NRFX_TWIM_XFER_TXTX<span></span>: Write operation followed by a write operation (without STOP condition in between).
310*150812a8SEvalZero  * - @ref NRFX_TWIM_XFER_TX<span></span>:   Write operation (with or without STOP condition).
311*150812a8SEvalZero  * - @ref NRFX_TWIM_XFER_RX<span></span>:   Read operation  (with STOP condition).
312*150812a8SEvalZero  *
313*150812a8SEvalZero  * @note TXRX and TXTX transfers are supported only in non-blocking mode.
314*150812a8SEvalZero  *
315*150812a8SEvalZero  * Additional options are provided using the flags parameter:
316*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_TX_POSTINC and @ref NRFX_TWIM_FLAG_RX_POSTINC<span></span>: Post-incrementation of buffer addresses. Supported only by TWIM.
317*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_NO_XFER_EVT_HANDLER<span></span>: No user event handler after transfer completion. In most cases, this also means no interrupt at the end of the transfer.
318*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_HOLD_XFER<span></span>: Driver is not starting the transfer. Use this flag if the transfer is triggered externally by PPI. Supported only by TWIM.
319*150812a8SEvalZero  *   Use @ref nrfx_twim_start_task_get to get the address of the start task.
320*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_REPEATED_XFER<span></span>: Prepare for repeated transfers. You can set up a number of transfers that will be triggered externally (for example by PPI).
321*150812a8SEvalZero  *   An example is a TXRX transfer with the options @ref NRFX_TWIM_FLAG_RX_POSTINC, @ref NRFX_TWIM_FLAG_NO_XFER_EVT_HANDLER, and @ref NRFX_TWIM_FLAG_REPEATED_XFER.
322*150812a8SEvalZero  *   After the transfer is set up, a set of transfers can be triggered by PPI that will read, for example, the same register of an
323*150812a8SEvalZero  *   external component and put it into a RAM buffer without any interrupts. @ref nrfx_twim_stopped_event_get can be used to get the
324*150812a8SEvalZero  *   address of the STOPPED event, which can be used to count the number of transfers. If @ref NRFX_TWIM_FLAG_REPEATED_XFER is used,
325*150812a8SEvalZero  *   the driver does not set the driver instance into busy state, so you must ensure that the next transfers are set up
326*150812a8SEvalZero  *   when TWIM is not active. Supported only by TWIM.
327*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_TX_NO_STOP<span></span>: No stop condition after TX transfer.
328*150812a8SEvalZero  *
329*150812a8SEvalZero  * @note
330*150812a8SEvalZero  * Some flag combinations are invalid:
331*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_TX_NO_STOP with @ref nrfx_twim_xfer_desc_t::type different than @ref NRFX_TWIM_XFER_TX
332*150812a8SEvalZero  * - @ref NRFX_TWIM_FLAG_REPEATED_XFER with @ref nrfx_twim_xfer_desc_t::type set to @ref NRFX_TWIM_XFER_TXTX
333*150812a8SEvalZero  *
334*150812a8SEvalZero  * If @ref nrfx_twim_xfer_desc_t::type is set to @ref NRFX_TWIM_XFER_TX and the @ref NRFX_TWIM_FLAG_TX_NO_STOP and @ref NRFX_TWIM_FLAG_REPEATED_XFER
335*150812a8SEvalZero  * flags are set, two tasks must be used to trigger a transfer: TASKS_RESUME followed by TASKS_STARTTX. If no stop condition is generated,
336*150812a8SEvalZero  * TWIM is in SUSPENDED state. Therefore, it must be resumed before the transfer can be started.
337*150812a8SEvalZero  *
338*150812a8SEvalZero  * @note Peripherals using EasyDMA (including TWIM) require the transfer buffers
339*150812a8SEvalZero  *       to be placed in the Data RAM region. If this condition is not met,
340*150812a8SEvalZero  *       this function will fail with the error code NRFX_ERROR_INVALID_ADDR.
341*150812a8SEvalZero  *
342*150812a8SEvalZero  * @param[in] p_instance        Pointer to the driver instance structure.
343*150812a8SEvalZero  * @param[in] p_xfer_desc       Pointer to the transfer descriptor.
344*150812a8SEvalZero  * @param[in] flags             Transfer options (0 for default settings).
345*150812a8SEvalZero  *
346*150812a8SEvalZero  * @retval NRFX_SUCCESS                    If the procedure was successful.
347*150812a8SEvalZero  * @retval NRFX_ERROR_BUSY                 If the driver is not ready for a new transfer.
348*150812a8SEvalZero  * @retval NRFX_ERROR_NOT_SUPPORTED        If the provided parameters are not supported.
349*150812a8SEvalZero  * @retval NRFX_ERROR_INTERNAL             If an error was detected by hardware.
350*150812a8SEvalZero  * @retval NRFX_ERROR_INVALID_ADDR         If the provided buffers are not placed in the Data RAM region.
351*150812a8SEvalZero  * @retval NRFX_ERROR_DRV_TWI_ERR_ANACK    If NACK received after sending the address.
352*150812a8SEvalZero  * @retval NRFX_ERROR_DRV_TWI_ERR_DNACK    If NACK received after sending a data byte.
353*150812a8SEvalZero  */
354*150812a8SEvalZero nrfx_err_t nrfx_twim_xfer(nrfx_twim_t           const * p_instance,
355*150812a8SEvalZero                           nrfx_twim_xfer_desc_t const * p_xfer_desc,
356*150812a8SEvalZero                           uint32_t                      flags);
357*150812a8SEvalZero 
358*150812a8SEvalZero /**
359*150812a8SEvalZero  * @brief Function for checking the TWI driver state.
360*150812a8SEvalZero  *
361*150812a8SEvalZero  * @param[in] p_instance TWI instance.
362*150812a8SEvalZero  *
363*150812a8SEvalZero  * @retval true  If the TWI driver is currently busy performing a transfer.
364*150812a8SEvalZero  * @retval false If the TWI driver is ready for a new transfer.
365*150812a8SEvalZero  */
366*150812a8SEvalZero bool nrfx_twim_is_busy(nrfx_twim_t const * p_instance);
367*150812a8SEvalZero 
368*150812a8SEvalZero 
369*150812a8SEvalZero /**
370*150812a8SEvalZero  * @brief Function for returning the address of a TWIM start task.
371*150812a8SEvalZero  *
372*150812a8SEvalZero  * This function should be used if @ref nrfx_twim_xfer was called with the flag @ref NRFX_TWIM_FLAG_HOLD_XFER.
373*150812a8SEvalZero  * In that case, the transfer is not started by the driver, but it must be started externally by PPI.
374*150812a8SEvalZero  *
375*150812a8SEvalZero  * @param[in]  p_instance Pointer to the driver instance structure.
376*150812a8SEvalZero  * @param[in]  xfer_type  Transfer type used in the last call of the @ref nrfx_twim_xfer function.
377*150812a8SEvalZero  *
378*150812a8SEvalZero  * @return     Start task address (TX or RX) depending on the value of xfer_type.
379*150812a8SEvalZero  */
380*150812a8SEvalZero uint32_t nrfx_twim_start_task_get(nrfx_twim_t const * p_instance, nrfx_twim_xfer_type_t xfer_type);
381*150812a8SEvalZero 
382*150812a8SEvalZero /**
383*150812a8SEvalZero  * @brief Function for returning the address of a STOPPED TWIM event.
384*150812a8SEvalZero  *
385*150812a8SEvalZero  * A STOPPED event can be used to detect the end of a transfer if the @ref NRFX_TWIM_FLAG_NO_XFER_EVT_HANDLER
386*150812a8SEvalZero  * option is used.
387*150812a8SEvalZero  *
388*150812a8SEvalZero  * @param[in]  p_instance Pointer to the driver instance structure.
389*150812a8SEvalZero  *
390*150812a8SEvalZero  * @return     STOPPED event address.
391*150812a8SEvalZero  */
392*150812a8SEvalZero uint32_t nrfx_twim_stopped_event_get(nrfx_twim_t const * p_instance);
393*150812a8SEvalZero 
394*150812a8SEvalZero 
395*150812a8SEvalZero void nrfx_twim_0_irq_handler(void);
396*150812a8SEvalZero void nrfx_twim_1_irq_handler(void);
397*150812a8SEvalZero void nrfx_twim_2_irq_handler(void);
398*150812a8SEvalZero void nrfx_twim_3_irq_handler(void);
399*150812a8SEvalZero 
400*150812a8SEvalZero 
401*150812a8SEvalZero /** @} */
402*150812a8SEvalZero 
403*150812a8SEvalZero #ifdef __cplusplus
404*150812a8SEvalZero }
405*150812a8SEvalZero #endif
406*150812a8SEvalZero 
407*150812a8SEvalZero #endif // NRFX_TWIM_H__
408