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:
Gregory Nutt 2018-08-03 08:51:55 -06:00
parent ee28cd9aeb
commit 10069067c1
29 changed files with 76 additions and 59 deletions

View File

@ -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;

View File

@ -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 */

View File

@ -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. */

View File

@ -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,
} }

View File

@ -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)

View File

@ -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

View File

@ -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;

View File

@ -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 */

View File

@ -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;

View File

@ -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 */

View File

@ -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;

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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)
{ {

View File

@ -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)
{ {

View File

@ -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;

View File

@ -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;
} }

View File

@ -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
} }

View File

@ -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;

View File

@ -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 */

View File

@ -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
} }

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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
} }

View File

@ -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
} }

View File

@ -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;

View File

@ -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 = &regval; msgs[1].buffer = &regval;
msgs[1].length = 1; msgs[1].length = 1;

View File

@ -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;