/* board_lock protects board_list and first_dynamic_bus_num. * only i2c core components are allowed to use these symbols.
*/ externstruct rw_semaphore __i2c_board_lock; externstruct list_head __i2c_board_list; externint __i2c_first_dynamic_bus_num;
int i2c_check_7bit_addr_validity_strict(unsignedshort addr); int i2c_dev_irq_from_resources(conststruct resource *resources, unsignedint num_resources);
/* * We only allow atomic transfers for very late communication, e.g. to access a * PMIC when powering down. Atomic transfers are a corner case and not for * generic use!
*/ staticinlinebool i2c_in_atomic_xfer_mode(void)
{ return system_state > SYSTEM_RUNNING &&
(IS_ENABLED(CONFIG_PREEMPT_COUNT) ? !preemptible() : irqs_disabled());
}
staticinlineint __i2c_lock_bus_helper(struct i2c_adapter *adap)
{ int ret = 0;
if (i2c_in_atomic_xfer_mode()) {
WARN(!adap->algo->master_xfer_atomic && !adap->algo->smbus_xfer_atomic, "No atomic I2C transfer handler for '%s'\n", dev_name(&adap->dev));
ret = i2c_trylock_bus(adap, I2C_LOCK_SEGMENT) ? 0 : -EAGAIN;
} else {
i2c_lock_bus(adap, I2C_LOCK_SEGMENT);
}
return ret;
}
staticinlineint __i2c_check_suspended(struct i2c_adapter *adap)
{ if (test_bit(I2C_ALF_IS_SUSPENDED, &adap->locked_flags)) { if (!test_and_set_bit(I2C_ALF_SUSPEND_REPORTED, &adap->locked_flags))
dev_WARN(&adap->dev, "Transfer while suspended\n"); return -ESHUTDOWN;
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.