* @set_sda_hold_time: callback to retrieve IP specific SDA hold timing
* @mode: operation mode - DW_IC_MASTER or DW_IC_SLAVE
* @rinfo: I²C GPIO recovery information
- * @suspended: set to true if the controller is suspended
*
* HCNT and LCNT parameters can be used if the platform knows more accurate
* values than the one computed based only on the input clock frequency.
int (*set_sda_hold_time)(struct dw_i2c_dev *dev);
int mode;
struct i2c_bus_recovery_info rinfo;
- bool suspended;
};
#define ACCESS_INTR_MASK BIT(0)
goto done_nolock;
}
- if (dev_WARN_ONCE(dev->dev, dev->suspended, "Transfer while suspended\n")) {
- ret = -ESHUTDOWN;
- goto done_nolock;
- }
-
reinit_completion(&dev->cmd_complete);
dev->msgs = msgs;
dev->msgs_num = num;
{
struct dw_i2c_dev *i_dev = dev_get_drvdata(dev);
- i2c_lock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
- i_dev->suspended = true;
- i2c_unlock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
+ i2c_mark_adapter_suspended(&i_dev->adapter);
return i2c_dw_pci_runtime_suspend(dev);
}
ret = i2c_dw_pci_runtime_resume(dev);
- i2c_lock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
- i_dev->suspended = false;
- i2c_unlock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
+ i2c_mark_adapter_resumed(&i_dev->adapter);
return ret;
}
{
struct dw_i2c_dev *i_dev = dev_get_drvdata(dev);
- i2c_lock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
- i_dev->suspended = true;
- i2c_unlock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
+ i2c_mark_adapter_suspended(&i_dev->adapter);
return dw_i2c_plat_runtime_suspend(dev);
}
struct dw_i2c_dev *i_dev = dev_get_drvdata(dev);
dw_i2c_plat_runtime_resume(dev);
-
- i2c_lock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
- i_dev->suspended = false;
- i2c_unlock_bus(&i_dev->adapter, I2C_LOCK_ROOT_ADAPTER);
+ i2c_mark_adapter_resumed(&i_dev->adapter);
return 0;
}