include/nuttx/i2c/i2c_master.h: Rename I2C_M_NORESTART to I2C_M_NOSTART since it may be used in other contexts than a repeated start. Add comments to clarilfy setup for repeated start.
This commit is contained in:
parent
ee28cd9aeb
commit
10069067c1
@ -1155,7 +1155,7 @@ static int efm32_i2c_isr_process(struct efm32_i2c_priv_s *priv)
|
|||||||
|
|
||||||
/* Send byte continue with/without restart ? */
|
/* Send byte continue with/without restart ? */
|
||||||
|
|
||||||
if (!(priv->flags & I2C_M_NORESTART))
|
if (!(priv->flags & I2C_M_NOSTART))
|
||||||
{
|
{
|
||||||
priv->i2c_state = I2CSTATE_RSTARTADDRSEND;
|
priv->i2c_state = I2CSTATE_RSTARTADDRSEND;
|
||||||
continue;
|
continue;
|
||||||
|
@ -1159,7 +1159,7 @@ static int kinetis_i2c_transfer(struct i2c_master_s *dev,
|
|||||||
* the same type as the current one, we can avoid the restart
|
* the same type as the current one, we can avoid the restart
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if ((nextmsg->flags & I2C_M_NORESTART) &&
|
if ((nextmsg->flags & I2C_M_NOSTART) &&
|
||||||
nextmsg->addr == priv->msgs->addr &&
|
nextmsg->addr == priv->msgs->addr &&
|
||||||
nextmsg->frequency == priv->msgs->frequency &&
|
nextmsg->frequency == priv->msgs->frequency &&
|
||||||
(nextmsg->flags & I2C_M_READ) == (priv->msgs->flags & I2C_M_READ))
|
(nextmsg->flags & I2C_M_READ) == (priv->msgs->flags & I2C_M_READ))
|
||||||
@ -1174,7 +1174,7 @@ static int kinetis_i2c_transfer(struct i2c_master_s *dev,
|
|||||||
* be correctly used here).
|
* be correctly used here).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!(priv->msgs->flags & I2C_M_NORESTART))
|
if (!(priv->msgs->flags & I2C_M_NOSTART))
|
||||||
{
|
{
|
||||||
/* Initiate the transfer, in case restart is required */
|
/* Initiate the transfer, in case restart is required */
|
||||||
|
|
||||||
|
@ -739,7 +739,7 @@ static int lc823450_i2c_poll(FAR struct lc823450_i2c_priv_s *priv)
|
|||||||
|
|
||||||
i2cinfo("other message remaining (msgc=%d)\n", priv->msgc);
|
i2cinfo("other message remaining (msgc=%d)\n", priv->msgc);
|
||||||
|
|
||||||
if (priv->msgv->flags & I2C_M_NORESTART)
|
if (priv->msgv->flags & I2C_M_NOSTART)
|
||||||
{
|
{
|
||||||
/* In this case, we don't have to restart using START condition. */
|
/* In this case, we don't have to restart using START condition. */
|
||||||
|
|
||||||
|
@ -483,7 +483,7 @@ static void chg_disable(void)
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
.addr = R2A20056BM_ADDR,
|
.addr = R2A20056BM_ADDR,
|
||||||
.flags = I2C_M_NORESTART,
|
.flags = I2C_M_NOSTART,
|
||||||
.buffer = (uint8_t *)&data,
|
.buffer = (uint8_t *)&data,
|
||||||
.length = 1,
|
.length = 1,
|
||||||
}
|
}
|
||||||
|
@ -391,7 +391,7 @@ static void lpc54_i2c_xfrsetup(struct lpc54_i2cdev_s *priv)
|
|||||||
|
|
||||||
/* Select the initial state */
|
/* Select the initial state */
|
||||||
|
|
||||||
if ((msg->flags & I2C_M_NORESTART) != 0)
|
if ((msg->flags & I2C_M_NOSTART) != 0)
|
||||||
{
|
{
|
||||||
/* Start condition will be ommited. Begin the tranfer in the data
|
/* Start condition will be ommited. Begin the tranfer in the data
|
||||||
* phase.
|
* phase.
|
||||||
@ -662,7 +662,7 @@ static bool lpc54_i2c_statemachine(struct lpc54_i2cdev_s *priv)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
nextmsg = msg + 1;
|
nextmsg = msg + 1;
|
||||||
dostop = ((nextmsg->flags & I2C_M_NORESTART) != 0);
|
dostop = ((nextmsg->flags & I2C_M_NOSTART) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dostop)
|
if (dostop)
|
||||||
|
@ -601,7 +601,7 @@ static int twi_interrupt(int irq, FAR void *context, FAR void *arg)
|
|||||||
* restart?
|
* restart?
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (priv->msgc <= 1 || (next->flags & I2C_M_NORESTART) == 0)
|
if (priv->msgc <= 1 || (next->flags & I2C_M_NOSTART) == 0)
|
||||||
{
|
{
|
||||||
/* The transfer is complete. Disable the RXRDY interrupt and
|
/* The transfer is complete. Disable the RXRDY interrupt and
|
||||||
* enable the TXCOMP interrupt
|
* enable the TXCOMP interrupt
|
||||||
@ -634,7 +634,7 @@ static int twi_interrupt(int irq, FAR void *context, FAR void *arg)
|
|||||||
* restart?
|
* restart?
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (priv->msgc <= 1 || (next->flags & I2C_M_NORESTART) == 0)
|
if (priv->msgc <= 1 || (next->flags & I2C_M_NOSTART) == 0)
|
||||||
{
|
{
|
||||||
/* This is the last message OR a restart is required before
|
/* This is the last message OR a restart is required before
|
||||||
* the next mesage. Send the stop signal.
|
* the next mesage. Send the stop signal.
|
||||||
@ -688,7 +688,7 @@ static int twi_interrupt(int irq, FAR void *context, FAR void *arg)
|
|||||||
* restart?
|
* restart?
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (priv->msgc <= 1 || (next->flags & I2C_M_NORESTART) == 0)
|
if (priv->msgc <= 1 || (next->flags & I2C_M_NOSTART) == 0)
|
||||||
{
|
{
|
||||||
/* The transfer is complete. Disable the TXRDY interrupt and
|
/* The transfer is complete. Disable the TXRDY interrupt and
|
||||||
* enable the TXCOMP interrupt
|
* enable the TXCOMP interrupt
|
||||||
|
@ -1375,7 +1375,7 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
|
|
||||||
if (priv->msgc > 0 && priv->msgv != NULL)
|
if (priv->msgc > 0 && priv->msgv != NULL)
|
||||||
{
|
{
|
||||||
if (priv->msgv->flags & I2C_M_NORESTART)
|
if (priv->msgv->flags & I2C_M_NOSTART)
|
||||||
{
|
{
|
||||||
stm32_i2c_traceevent(priv, I2CEVENT_BTFNOSTART, priv->msgc);
|
stm32_i2c_traceevent(priv, I2CEVENT_BTFNOSTART, priv->msgc);
|
||||||
priv->ptr = priv->msgv->buffer;
|
priv->ptr = priv->msgv->buffer;
|
||||||
|
@ -1601,7 +1601,7 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
* do nothing.
|
* do nothing.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
else if (priv->msgc > 0 && ((priv->msgv->flags & I2C_M_NORESTART) != 0))
|
else if (priv->msgc > 0 && ((priv->msgv->flags & I2C_M_NOSTART) != 0))
|
||||||
{
|
{
|
||||||
/* Set condition to get to next message */
|
/* Set condition to get to next message */
|
||||||
|
|
||||||
|
@ -1399,7 +1399,7 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
|
|
||||||
if (priv->msgc > 0)
|
if (priv->msgc > 0)
|
||||||
{
|
{
|
||||||
if (priv->msgv->flags & I2C_M_NORESTART)
|
if (priv->msgv->flags & I2C_M_NOSTART)
|
||||||
{
|
{
|
||||||
stm32_i2c_traceevent(priv, I2CEVENT_BTFNOSTART, priv->msgc);
|
stm32_i2c_traceevent(priv, I2CEVENT_BTFNOSTART, priv->msgc);
|
||||||
priv->ptr = priv->msgv->buffer;
|
priv->ptr = priv->msgv->buffer;
|
||||||
|
@ -1315,8 +1315,8 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
* return the error to the waiting task.
|
* return the error to the waiting task.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (((priv->msgv[0].flags & I2C_M_NORESTART) != 0 && (status & I2C_SR1_TXE) == 0) ||
|
if (((priv->msgv[0].flags & I2C_M_NOSTART) != 0 && (status & I2C_SR1_TXE) == 0) ||
|
||||||
((priv->msgv[0].flags & I2C_M_NORESTART) == 0 && (status & I2C_SR1_SB) == 0))
|
((priv->msgv[0].flags & I2C_M_NOSTART) == 0 && (status & I2C_SR1_SB) == 0))
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_STM32_I2C_DMA) || defined(CONFIG_I2C_POLLED)
|
#if defined(CONFIG_STM32_I2C_DMA) || defined(CONFIG_I2C_POLLED)
|
||||||
return OK;
|
return OK;
|
||||||
@ -1778,7 +1778,7 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
{
|
{
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
if (priv->dcnt == 1 &&
|
if (priv->dcnt == 1 &&
|
||||||
(priv->msgc == 0 || (priv->msgv->flags & I2C_M_NORESTART) == 0))
|
(priv->msgc == 0 || (priv->msgv->flags & I2C_M_NOSTART) == 0))
|
||||||
{
|
{
|
||||||
stm32_i2c_modifyreg(priv, STM32_I2C_CR2_OFFSET, I2C_CR2_ITBUFEN, 0);
|
stm32_i2c_modifyreg(priv, STM32_I2C_CR2_OFFSET, I2C_CR2_ITBUFEN, 0);
|
||||||
}
|
}
|
||||||
@ -1807,13 +1807,13 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
|
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
if (((status & I2C_SR1_ADDR) != 0 && priv->dcnt > 0) ||
|
if (((status & I2C_SR1_ADDR) != 0 && priv->dcnt > 0) ||
|
||||||
(priv->msgc > 0 && (priv->msgv->flags & I2C_M_NORESTART) != 0))
|
(priv->msgc > 0 && (priv->msgv->flags & I2C_M_NOSTART) != 0))
|
||||||
{
|
{
|
||||||
stm32_i2c_modifyreg(priv, STM32_I2C_CR2_OFFSET, 0, I2C_CR2_ITBUFEN);
|
stm32_i2c_modifyreg(priv, STM32_I2C_CR2_OFFSET, 0, I2C_CR2_ITBUFEN);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (priv->dcnt == 0 &&
|
if (priv->dcnt == 0 &&
|
||||||
priv->msgc > 0 && (priv->msgv->flags & I2C_M_NORESTART) != 0)
|
priv->msgc > 0 && (priv->msgv->flags & I2C_M_NOSTART) != 0)
|
||||||
{
|
{
|
||||||
/* Set condition to get to next message */
|
/* Set condition to get to next message */
|
||||||
|
|
||||||
|
@ -1371,7 +1371,7 @@ static int stm32f0_i2c_isr_process(struct stm32f0_i2c_priv_s *priv)
|
|||||||
|
|
||||||
if (priv->msgc > 0)
|
if (priv->msgc > 0)
|
||||||
{
|
{
|
||||||
if (priv->msgv->flags & I2C_M_NORESTART)
|
if (priv->msgv->flags & I2C_M_NOSTART)
|
||||||
{
|
{
|
||||||
stm32f0_i2c_traceevent(priv, I2CEVENT_BTFNOSTART, priv->msgc);
|
stm32f0_i2c_traceevent(priv, I2CEVENT_BTFNOSTART, priv->msgc);
|
||||||
priv->ptr = priv->msgv->buffer;
|
priv->ptr = priv->msgv->buffer;
|
||||||
|
@ -83,7 +83,7 @@
|
|||||||
* All supported features have been tested and found to be operational.
|
* All supported features have been tested and found to be operational.
|
||||||
*
|
*
|
||||||
* Although the RELOAD capability has been tested as it was required to
|
* Although the RELOAD capability has been tested as it was required to
|
||||||
* implement the I2C_M_NORESTART flag on F3 hardware, the associated
|
* implement the I2C_M_NOSTART flag on F3 hardware, the associated
|
||||||
* logic to support the transfer messages with more than 255 byte
|
* logic to support the transfer messages with more than 255 byte
|
||||||
* payloads has not been tested as the author lacked access to a real
|
* payloads has not been tested as the author lacked access to a real
|
||||||
* device supporting these types of transfers.
|
* device supporting these types of transfers.
|
||||||
@ -1439,7 +1439,7 @@ static inline void stm32_i2c_sendstart(FAR struct stm32_i2c_priv_s *priv)
|
|||||||
* The following flags can be used to override this behavior as follows:
|
* The following flags can be used to override this behavior as follows:
|
||||||
*
|
*
|
||||||
* - I2C_M_READ: Sets the transfer direction to READ (R/W bit = 1)
|
* - I2C_M_READ: Sets the transfer direction to READ (R/W bit = 1)
|
||||||
* - I2C_M_NORESTART: Prevents a RESTART from being issued prior to the
|
* - I2C_M_NOSTART: Prevents a RESTART from being issued prior to the
|
||||||
* transfer of the message (where allowed by the protocol).
|
* transfer of the message (where allowed by the protocol).
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ -1448,7 +1448,7 @@ static inline void stm32_i2c_sendstart(FAR struct stm32_i2c_priv_s *priv)
|
|||||||
priv->dcnt = priv->msgv->length;
|
priv->dcnt = priv->msgv->length;
|
||||||
priv->flags = priv->msgv->flags;
|
priv->flags = priv->msgv->flags;
|
||||||
|
|
||||||
if ((priv->flags & I2C_M_NORESTART) == 0)
|
if ((priv->flags & I2C_M_NOSTART) == 0)
|
||||||
{
|
{
|
||||||
/* Flag the first byte as an address byte */
|
/* Flag the first byte as an address byte */
|
||||||
|
|
||||||
@ -1466,7 +1466,7 @@ static inline void stm32_i2c_sendstart(FAR struct stm32_i2c_priv_s *priv)
|
|||||||
|
|
||||||
if (priv->msgc > 0)
|
if (priv->msgc > 0)
|
||||||
{
|
{
|
||||||
next_norestart = (((priv->msgv + 1)->flags & I2C_M_NORESTART) != 0);
|
next_norestart = (((priv->msgv + 1)->flags & I2C_M_NOSTART) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (next_norestart || priv->dcnt > 255)
|
if (next_norestart || priv->dcnt > 255)
|
||||||
@ -1890,7 +1890,7 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
*
|
*
|
||||||
* The fact that the hardware must either RESTART or STOP when a TC
|
* The fact that the hardware must either RESTART or STOP when a TC
|
||||||
* event occurs explains why, when messages must be sent back to back
|
* event occurs explains why, when messages must be sent back to back
|
||||||
* (i.e. without a restart by specifying the I2C_M_NORESTART flag),
|
* (i.e. without a restart by specifying the I2C_M_NOSTART flag),
|
||||||
* RELOAD mode must be enabled and TCR event(s) must be generated
|
* RELOAD mode must be enabled and TCR event(s) must be generated
|
||||||
* instead. See the TCR handler for more.
|
* instead. See the TCR handler for more.
|
||||||
*/
|
*/
|
||||||
@ -1969,7 +1969,7 @@ static int stm32_i2c_isr_process(struct stm32_i2c_priv_s *priv)
|
|||||||
*
|
*
|
||||||
* 1) We're trying to send a message with a payload greater than 255 bytes.
|
* 1) We're trying to send a message with a payload greater than 255 bytes.
|
||||||
* 2) We're trying to send messages back to back, regardless of their
|
* 2) We're trying to send messages back to back, regardless of their
|
||||||
* payload size, to avoid a RESTART (i.e. I2C_M_NORESTART flag is set).
|
* payload size, to avoid a RESTART (i.e. I2C_M_NOSTART flag is set).
|
||||||
*
|
*
|
||||||
* These conditions may be true simultaneously, as would be the case if
|
* These conditions may be true simultaneously, as would be the case if
|
||||||
* we're sending multiple messages with payloads > 255 bytes. So we only
|
* we're sending multiple messages with payloads > 255 bytes. So we only
|
||||||
|
@ -84,7 +84,7 @@
|
|||||||
* - Multiple instances (shared bus)
|
* - Multiple instances (shared bus)
|
||||||
* - Interrupt based operation
|
* - Interrupt based operation
|
||||||
* - RELOAD support
|
* - RELOAD support
|
||||||
* - I2C_M_NORESTART support
|
* - I2C_M_NOSTART support
|
||||||
*
|
*
|
||||||
* Test Environment:
|
* Test Environment:
|
||||||
* - STM32L451CEU6 based board with I2C slaves LIS2DH accelerometer and
|
* - STM32L451CEU6 based board with I2C slaves LIS2DH accelerometer and
|
||||||
@ -111,7 +111,7 @@
|
|||||||
* All supported features have been tested and found to be operational.
|
* All supported features have been tested and found to be operational.
|
||||||
*
|
*
|
||||||
* Although the RELOAD capability has been tested as it was required to
|
* Although the RELOAD capability has been tested as it was required to
|
||||||
* implement the I2C_M_NORESTART flag on F3 hardware, the associated
|
* implement the I2C_M_NOSTART flag on F3 hardware, the associated
|
||||||
* logic to support the transfer messages with more than 255 byte
|
* logic to support the transfer messages with more than 255 byte
|
||||||
* payloads has not been tested as the author lacked access to a real
|
* payloads has not been tested as the author lacked access to a real
|
||||||
* device supporting these types of transfers.
|
* device supporting these types of transfers.
|
||||||
@ -1568,7 +1568,7 @@ static inline void stm32l4_i2c_sendstart(FAR struct stm32l4_i2c_priv_s *priv)
|
|||||||
* The following flags can be used to override this behavior as follows:
|
* The following flags can be used to override this behavior as follows:
|
||||||
*
|
*
|
||||||
* - I2C_M_READ: Sets the transfer direction to READ (R/W bit = 1)
|
* - I2C_M_READ: Sets the transfer direction to READ (R/W bit = 1)
|
||||||
* - I2C_M_NORESTART: Prevents a RESTART from being issued prior to the
|
* - I2C_M_NOSTART: Prevents a RESTART from being issued prior to the
|
||||||
* transfer of the message (where allowed by the protocol).
|
* transfer of the message (where allowed by the protocol).
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ -1577,7 +1577,7 @@ static inline void stm32l4_i2c_sendstart(FAR struct stm32l4_i2c_priv_s *priv)
|
|||||||
priv->dcnt = priv->msgv->length;
|
priv->dcnt = priv->msgv->length;
|
||||||
priv->flags = priv->msgv->flags;
|
priv->flags = priv->msgv->flags;
|
||||||
|
|
||||||
if ((priv->flags & I2C_M_NORESTART) != 0)
|
if ((priv->flags & I2C_M_NOSTART) != 0)
|
||||||
{
|
{
|
||||||
/* Flag the first byte as an address byte */
|
/* Flag the first byte as an address byte */
|
||||||
|
|
||||||
@ -1595,7 +1595,7 @@ static inline void stm32l4_i2c_sendstart(FAR struct stm32l4_i2c_priv_s *priv)
|
|||||||
|
|
||||||
if (priv->msgc > 0)
|
if (priv->msgc > 0)
|
||||||
{
|
{
|
||||||
next_norestart = (((priv->msgv + 1)->flags & I2C_M_NORESTART) != 0);
|
next_norestart = (((priv->msgv + 1)->flags & I2C_M_NOSTART) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (next_norestart || priv->dcnt > 255)
|
if (next_norestart || priv->dcnt > 255)
|
||||||
@ -2019,7 +2019,7 @@ static int stm32l4_i2c_isr_process(struct stm32l4_i2c_priv_s *priv)
|
|||||||
*
|
*
|
||||||
* The fact that the hardware must either RESTART or STOP when a TC
|
* The fact that the hardware must either RESTART or STOP when a TC
|
||||||
* event occurs explains why, when messages must be sent back to back
|
* event occurs explains why, when messages must be sent back to back
|
||||||
* (i.e. without a restart by specifying the I2C_M_NORESTART flag),
|
* (i.e. without a restart by specifying the I2C_M_NOSTART flag),
|
||||||
* RELOAD mode must be enabled and TCR event(s) must be generated
|
* RELOAD mode must be enabled and TCR event(s) must be generated
|
||||||
* instead. See the TCR handler for more.
|
* instead. See the TCR handler for more.
|
||||||
*/
|
*/
|
||||||
@ -2098,7 +2098,7 @@ static int stm32l4_i2c_isr_process(struct stm32l4_i2c_priv_s *priv)
|
|||||||
*
|
*
|
||||||
* 1) We're trying to send a message with a payload greater than 255 bytes.
|
* 1) We're trying to send a message with a payload greater than 255 bytes.
|
||||||
* 2) We're trying to send messages back to back, regardless of their
|
* 2) We're trying to send messages back to back, regardless of their
|
||||||
* payload size, to avoid a RESTART (i.e. I2C_M_NORESTART flag is set).
|
* payload size, to avoid a RESTART (i.e. I2C_M_NOSTART flag is set).
|
||||||
*
|
*
|
||||||
* These conditions may be true simultaneously, as would be the case if
|
* These conditions may be true simultaneously, as would be the case if
|
||||||
* we're sending multiple messages with payloads > 255 bytes. So we only
|
* we're sending multiple messages with payloads > 255 bytes. So we only
|
||||||
|
@ -1308,7 +1308,7 @@ static int tiva_i2c_process(struct tiva_i2c_priv_s *priv, uint32_t status)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
tiva_i2c_traceevent(priv, I2CEVENT_NEXTMSG, priv->msgc);
|
tiva_i2c_traceevent(priv, I2CEVENT_NEXTMSG, priv->msgc);
|
||||||
if ((priv->msgv->flags & I2C_M_NORESTART) != 0)
|
if ((priv->msgv->flags & I2C_M_NOSTART) != 0)
|
||||||
{
|
{
|
||||||
/* Just continue transferring data. In this case,
|
/* Just continue transferring data. In this case,
|
||||||
* no STOP was sent at the end of the last message
|
* no STOP was sent at the end of the last message
|
||||||
|
@ -872,13 +872,13 @@ static int ez80_i2c_transfer(FAR struct i2c_master_s *dev,
|
|||||||
/* No... Check if the next message should have a repeated start or
|
/* No... Check if the next message should have a repeated start or
|
||||||
* not. The conditions for NO repeated start are:
|
* not. The conditions for NO repeated start are:
|
||||||
*
|
*
|
||||||
* - I2C_M_NORESTART bit set
|
* - I2C_M_NOSTART bit set
|
||||||
* - Same direction (I2C_M_READ)
|
* - Same direction (I2C_M_READ)
|
||||||
* - Same address (and I2C_M_TEN)
|
* - Same address (and I2C_M_TEN)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
next = &msgs[i + 1];
|
next = &msgs[i + 1];
|
||||||
if ((msg->flags & I2C_M_NORESTART) != 0 &&
|
if ((msg->flags & I2C_M_NOSTART) != 0 &&
|
||||||
(msg->flags & (I2C_M_READ | I2C_M_TEN)) == (next->flags & (I2C_M_READ | I2C_M_TEN)) &&
|
(msg->flags & (I2C_M_READ | I2C_M_TEN)) == (next->flags & (I2C_M_READ | I2C_M_TEN)) &&
|
||||||
msg->addr == next->addr)
|
msg->addr == next->addr)
|
||||||
{
|
{
|
||||||
|
@ -560,13 +560,13 @@ static int z8_i2c_transfer(FAR struct i2c_master_s *dev,
|
|||||||
/* No... Check if the next message should have a repeated start or
|
/* No... Check if the next message should have a repeated start or
|
||||||
* not. The conditions for NO repeated start are:
|
* not. The conditions for NO repeated start are:
|
||||||
*
|
*
|
||||||
* - I2C_M_NORESTART bit set
|
* - I2C_M_NOSTART bit set
|
||||||
* - Same direction (I2C_M_READ)
|
* - Same direction (I2C_M_READ)
|
||||||
* - Same address (and I2C_M_TEN)
|
* - Same address (and I2C_M_TEN)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
next = &msgs[i + 1];
|
next = &msgs[i + 1];
|
||||||
if ((msg->flags & I2C_M_NORESTART) != 0 &&
|
if ((msg->flags & I2C_M_NOSTART) != 0 &&
|
||||||
(msg->flags & (I2C_M_READ | I2C_M_TEN)) == (next->flags & (I2C_M_READ | I2C_M_TEN)) &&
|
(msg->flags & (I2C_M_READ | I2C_M_TEN)) == (next->flags & (I2C_M_READ | I2C_M_TEN)) &&
|
||||||
msg->addr == next->addr)
|
msg->addr == next->addr)
|
||||||
{
|
{
|
||||||
|
@ -285,7 +285,7 @@ static int ee24xx_writepage(FAR struct ee24xx_dev_s *eedev, uint32_t memaddr,
|
|||||||
|
|
||||||
msgs[1].frequency = msgs[0].frequency;
|
msgs[1].frequency = msgs[0].frequency;
|
||||||
msgs[1].addr = msgs[0].addr;
|
msgs[1].addr = msgs[0].addr;
|
||||||
msgs[1].flags = I2C_M_NORESTART;
|
msgs[1].flags = I2C_M_NOSTART;
|
||||||
msgs[1].buffer = (uint8_t*)buffer;
|
msgs[1].buffer = (uint8_t*)buffer;
|
||||||
msgs[1].length = len;
|
msgs[1].length = len;
|
||||||
|
|
||||||
|
@ -81,11 +81,13 @@ int i2c_writeread(FAR struct i2c_master_s *dev,
|
|||||||
DEBUGASSERT(config->addrlen == 10 || config->addrlen == 7);
|
DEBUGASSERT(config->addrlen == 10 || config->addrlen == 7);
|
||||||
flags = (config->addrlen == 10) ? I2C_M_TEN : 0;
|
flags = (config->addrlen == 10) ? I2C_M_TEN : 0;
|
||||||
|
|
||||||
/* Format two messages: The first is a write */
|
/* Format two messages: The first is a write which is never terminated
|
||||||
|
* with STOP condition.
|
||||||
|
*/
|
||||||
|
|
||||||
msg[0].frequency = config->frequency,
|
msg[0].frequency = config->frequency,
|
||||||
msg[0].addr = config->address;
|
msg[0].addr = config->address;
|
||||||
msg[0].flags = flags;
|
msg[0].flags = flags | I2C_M_NOSTOP;
|
||||||
msg[0].buffer = (FAR uint8_t *)wbuffer; /* Override const */
|
msg[0].buffer = (FAR uint8_t *)wbuffer; /* Override const */
|
||||||
msg[0].length = wbuflen;
|
msg[0].length = wbuflen;
|
||||||
|
|
||||||
@ -95,12 +97,11 @@ int i2c_writeread(FAR struct i2c_master_s *dev,
|
|||||||
|
|
||||||
if (rbuflen > 0)
|
if (rbuflen > 0)
|
||||||
{
|
{
|
||||||
msg[0].flags |= I2C_M_NOSTOP;
|
|
||||||
msg[1].flags = (flags | I2C_M_READ);
|
msg[1].flags = (flags | I2C_M_READ);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
msg[1].flags = (flags | I2C_M_NORESTART);
|
msg[1].flags = (flags | I2C_M_NOSTART);
|
||||||
rbuflen = -rbuflen;
|
rbuflen = -rbuflen;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -266,7 +266,7 @@ static int mbr3108_i2c_write(FAR struct mbr3108_dev_s *dev, uint8_t reg,
|
|||||||
{
|
{
|
||||||
.frequency = CONFIG_MBR3108_I2C_FREQUENCY,
|
.frequency = CONFIG_MBR3108_I2C_FREQUENCY,
|
||||||
.addr = dev->addr,
|
.addr = dev->addr,
|
||||||
.flags = I2C_M_NORESTART,
|
.flags = I2C_M_NOSTART,
|
||||||
.buffer = (void *)buf,
|
.buffer = (void *)buf,
|
||||||
.length = buflen
|
.length = buflen
|
||||||
}
|
}
|
||||||
|
@ -415,7 +415,7 @@ static int mxt_putreg(FAR struct mxt_dev_s *priv, uint16_t regaddr,
|
|||||||
|
|
||||||
msg[1].frequency = priv->frequency;
|
msg[1].frequency = priv->frequency;
|
||||||
msg[1].addr = priv->lower->address;
|
msg[1].addr = priv->lower->address;
|
||||||
msg[1].flags = I2C_M_NORESTART;
|
msg[1].flags = I2C_M_NOSTART;
|
||||||
msg[1].buffer = (FAR uint8_t *)buffer;
|
msg[1].buffer = (FAR uint8_t *)buffer;
|
||||||
msg[1].length = buflen;
|
msg[1].length = buflen;
|
||||||
|
|
||||||
|
@ -139,7 +139,7 @@ int ssd1306_sendblk(FAR struct ssd1306_dev_s *priv, uint8_t *data, uint8_t len)
|
|||||||
|
|
||||||
msg[1].frequency = CONFIG_SSD1306_I2CFREQ; /* I2C frequency */
|
msg[1].frequency = CONFIG_SSD1306_I2CFREQ; /* I2C frequency */
|
||||||
msg[1].addr = priv->addr; /* 7-bit address */
|
msg[1].addr = priv->addr; /* 7-bit address */
|
||||||
msg[1].flags = I2C_M_NORESTART; /* Write transaction with no RESTART */
|
msg[1].flags = I2C_M_NOSTART; /* Write transaction with no RESTART */
|
||||||
msg[1].buffer = data; /* Transfer from this address */
|
msg[1].buffer = data; /* Transfer from this address */
|
||||||
msg[1].length = len; /* Send the data, then STOP */
|
msg[1].length = len; /* Send the data, then STOP */
|
||||||
|
|
||||||
|
@ -234,7 +234,7 @@ static int32_t hts221_write_reg8(FAR struct hts221_dev_s *priv,
|
|||||||
{
|
{
|
||||||
.frequency = CONFIG_HTS221_I2C_FREQUENCY,
|
.frequency = CONFIG_HTS221_I2C_FREQUENCY,
|
||||||
.addr = priv->addr,
|
.addr = priv->addr,
|
||||||
.flags = I2C_M_NORESTART,
|
.flags = I2C_M_NOSTART,
|
||||||
.buffer = (FAR void *)&command[1],
|
.buffer = (FAR void *)&command[1],
|
||||||
.length = 1
|
.length = 1
|
||||||
}
|
}
|
||||||
|
@ -1552,7 +1552,7 @@ static int lis2dh_access(FAR struct lis2dh_dev_s *dev, uint8_t subaddr,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
flags = I2C_M_NORESTART;
|
flags = I2C_M_NOSTART;
|
||||||
length = -length;
|
length = -length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -141,7 +141,7 @@ static int lis331dl_access(FAR struct lis331dl_dev_s *dev, uint8_t subaddr,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
flags = I2C_M_NORESTART;
|
flags = I2C_M_NOSTART;
|
||||||
length = -length;
|
length = -length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -290,7 +290,7 @@ static int lps25h_write_reg8(struct lps25h_dev_s *dev, uint8_t reg_addr,
|
|||||||
{
|
{
|
||||||
.frequency = CONFIG_LPS25H_I2C_FREQUENCY,
|
.frequency = CONFIG_LPS25H_I2C_FREQUENCY,
|
||||||
.addr = dev->addr,
|
.addr = dev->addr,
|
||||||
.flags = I2C_M_NORESTART,
|
.flags = I2C_M_NOSTART,
|
||||||
.buffer = (void *)&value,
|
.buffer = (void *)&value,
|
||||||
.length = 1
|
.length = 1
|
||||||
}
|
}
|
||||||
|
@ -194,7 +194,7 @@ static int max44009_write_reg8(FAR struct max44009_dev_s *dev,
|
|||||||
{
|
{
|
||||||
.frequency = CONFIG_MAX44009_I2C_FREQUENCY,
|
.frequency = CONFIG_MAX44009_I2C_FREQUENCY,
|
||||||
.addr = dev->addr,
|
.addr = dev->addr,
|
||||||
.flags = I2C_M_NORESTART,
|
.flags = I2C_M_NOSTART,
|
||||||
.buffer = (void *)&command[1],
|
.buffer = (void *)&command[1],
|
||||||
.length = 1
|
.length = 1
|
||||||
}
|
}
|
||||||
|
@ -179,7 +179,7 @@ static int sht21_access(FAR struct sht21_dev_s *priv,
|
|||||||
|
|
||||||
msg[1].frequency = CONFIG_SHT21_I2C_FREQUENCY;
|
msg[1].frequency = CONFIG_SHT21_I2C_FREQUENCY;
|
||||||
msg[1].addr = priv->addr;
|
msg[1].addr = priv->addr;
|
||||||
msg[1].flags = read ? I2C_M_READ : I2C_M_NORESTART;
|
msg[1].flags = read ? I2C_M_READ : I2C_M_NOSTART;
|
||||||
msg[1].buffer = reg_value;
|
msg[1].buffer = reg_value;
|
||||||
msg[1].length = len;
|
msg[1].length = len;
|
||||||
|
|
||||||
|
@ -135,7 +135,7 @@ static int cs2100_write_reg(FAR const struct cs2100_config_s *config,
|
|||||||
|
|
||||||
msga[1].frequency = config->i2cfreq;
|
msga[1].frequency = config->i2cfreq;
|
||||||
msgs[1].addr = config->i2caddr;
|
msgs[1].addr = config->i2caddr;
|
||||||
msgs[1].flags = I2C_M_NORESTART;
|
msgs[1].flags = I2C_M_NOSTART;
|
||||||
msgs[1].buffer = ®val;
|
msgs[1].buffer = ®val;
|
||||||
msgs[1].length = 1;
|
msgs[1].length = 1;
|
||||||
|
|
||||||
|
@ -73,13 +73,29 @@
|
|||||||
#define I2C_READADDR10H(a) (I2C_ADDR10H(a) | I2C_READBIT)
|
#define I2C_READADDR10H(a) (I2C_ADDR10H(a) | I2C_READBIT)
|
||||||
#define I2C_READADDR10L(a) I2C_ADDR10L(a)
|
#define I2C_READADDR10L(a) I2C_ADDR10L(a)
|
||||||
|
|
||||||
/* Bit definitions for the flags field in struct i2c_msg_s */
|
/* Bit definitions for the flags field in struct i2c_msg_s
|
||||||
|
*
|
||||||
|
* START/STOP Rules:
|
||||||
|
*
|
||||||
|
* 1. The lower half I2C driver will always issue the START condition at the
|
||||||
|
* beginning of a message unless I2C_M_NOSTART flat is set in the
|
||||||
|
* message.
|
||||||
|
*
|
||||||
|
* 2. The lower half I2C driver will always issue the STOP condition at the
|
||||||
|
* end of the messages unless:
|
||||||
|
*
|
||||||
|
* a. The I2C_M_NOSTOP flag is set in the message, OR
|
||||||
|
* b. The following message has the I2C_M_NOSTART flag set (meaning
|
||||||
|
* that following message is simply a continuation of the transfer).
|
||||||
|
*
|
||||||
|
* A proper I2C repeated start would then have I2C_M_NOSTOP set on msg[n]
|
||||||
|
* and I2C_M_NOSTART *not* set on msg[n+1];
|
||||||
|
*/
|
||||||
|
|
||||||
#define I2C_M_READ 0x0001 /* Read data, from slave to master */
|
#define I2C_M_READ 0x0001 /* Read data, from slave to master */
|
||||||
#define I2C_M_TEN 0x0002 /* Ten bit address */
|
#define I2C_M_TEN 0x0002 /* Ten bit address */
|
||||||
#define I2C_M_NOSTOP 0x0040 /* Message should not end with a STOP */
|
#define I2C_M_NOSTOP 0x0040 /* Message should not end with a STOP */
|
||||||
#define I2C_M_NORESTART 0x0080 /* Message should not begin with
|
#define I2C_M_NOSTART 0x0080 /* Message should not begin with a START */
|
||||||
* (re-)START of transfer */
|
|
||||||
|
|
||||||
/* I2C Character Driver IOCTL Commands **************************************/
|
/* I2C Character Driver IOCTL Commands **************************************/
|
||||||
/* The I2C driver is intended to support application testing of the I2C bus.
|
/* The I2C driver is intended to support application testing of the I2C bus.
|
||||||
@ -153,7 +169,7 @@
|
|||||||
* Public Types
|
* Public Types
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* The I2C vtable */
|
/* The I2C lower half driver interface */
|
||||||
|
|
||||||
struct i2c_master_s;
|
struct i2c_master_s;
|
||||||
struct i2c_msg_s;
|
struct i2c_msg_s;
|
||||||
|
Loading…
Reference in New Issue
Block a user