Commit a3aaf777 authored by Jean-Baptiste Maneyrol's avatar Jean-Baptiste Maneyrol Committed by Jonathan Cameron

iio: imu: inv_mpu6050: set power on/off only once during all init

This way there is no need anymore to export the power function to
i2c and spi modules.
Bus setup is done inside init when power is on and the result is
now checked.
Signed-off-by: default avatarJean-Baptiste Maneyrol <jmaneyrol@invensense.com>
Signed-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 14c046ed
...@@ -301,7 +301,6 @@ int inv_mpu6050_set_power_itg(struct inv_mpu6050_state *st, bool power_on) ...@@ -301,7 +301,6 @@ int inv_mpu6050_set_power_itg(struct inv_mpu6050_state *st, bool power_on)
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(inv_mpu6050_set_power_itg);
static int inv_mpu6050_set_gyro_fsr(struct inv_mpu6050_state *st, static int inv_mpu6050_set_gyro_fsr(struct inv_mpu6050_state *st,
enum inv_mpu6050_fsr_e val) enum inv_mpu6050_fsr_e val)
...@@ -371,27 +370,23 @@ static int inv_mpu6050_init_config(struct iio_dev *indio_dev) ...@@ -371,27 +370,23 @@ static int inv_mpu6050_init_config(struct iio_dev *indio_dev)
u8 d; u8 d;
struct inv_mpu6050_state *st = iio_priv(indio_dev); struct inv_mpu6050_state *st = iio_priv(indio_dev);
result = inv_mpu6050_set_power_itg(st, true);
if (result)
return result;
result = inv_mpu6050_set_gyro_fsr(st, INV_MPU6050_FSR_2000DPS); result = inv_mpu6050_set_gyro_fsr(st, INV_MPU6050_FSR_2000DPS);
if (result) if (result)
goto error_power_off; return result;
result = inv_mpu6050_set_lpf_regs(st, INV_MPU6050_FILTER_20HZ); result = inv_mpu6050_set_lpf_regs(st, INV_MPU6050_FILTER_20HZ);
if (result) if (result)
goto error_power_off; return result;
d = INV_MPU6050_FIFO_RATE_TO_DIVIDER(INV_MPU6050_INIT_FIFO_RATE); d = INV_MPU6050_FIFO_RATE_TO_DIVIDER(INV_MPU6050_INIT_FIFO_RATE);
result = regmap_write(st->map, st->reg->sample_rate_div, d); result = regmap_write(st->map, st->reg->sample_rate_div, d);
if (result) if (result)
goto error_power_off; return result;
d = (INV_MPU6050_FS_02G << INV_MPU6050_ACCL_CONFIG_FSR_SHIFT); d = (INV_MPU6050_FS_02G << INV_MPU6050_ACCL_CONFIG_FSR_SHIFT);
result = regmap_write(st->map, st->reg->accl_config, d); result = regmap_write(st->map, st->reg->accl_config, d);
if (result) if (result)
goto error_power_off; return result;
result = regmap_write(st->map, st->reg->int_pin_cfg, st->irq_mask); result = regmap_write(st->map, st->reg->int_pin_cfg, st->irq_mask);
if (result) if (result)
...@@ -410,13 +405,9 @@ static int inv_mpu6050_init_config(struct iio_dev *indio_dev) ...@@ -410,13 +405,9 @@ static int inv_mpu6050_init_config(struct iio_dev *indio_dev)
/* magn chip init, noop if not present in the chip */ /* magn chip init, noop if not present in the chip */
result = inv_mpu_magn_probe(st); result = inv_mpu_magn_probe(st);
if (result) if (result)
goto error_power_off;
return inv_mpu6050_set_power_itg(st, false);
error_power_off:
inv_mpu6050_set_power_itg(st, false);
return result; return result;
return 0;
} }
static int inv_mpu6050_sensor_set(struct inv_mpu6050_state *st, int reg, static int inv_mpu6050_sensor_set(struct inv_mpu6050_state *st, int reg,
...@@ -1176,7 +1167,7 @@ static int inv_check_and_setup_chip(struct inv_mpu6050_state *st) ...@@ -1176,7 +1167,7 @@ static int inv_check_and_setup_chip(struct inv_mpu6050_state *st)
if (result) if (result)
goto error_power_off; goto error_power_off;
return inv_mpu6050_set_power_itg(st, false); return 0;
error_power_off: error_power_off:
inv_mpu6050_set_power_itg(st, false); inv_mpu6050_set_power_itg(st, false);
...@@ -1341,7 +1332,7 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name, ...@@ -1341,7 +1332,7 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name,
result = inv_mpu6050_init_config(indio_dev); result = inv_mpu6050_init_config(indio_dev);
if (result) { if (result) {
dev_err(dev, "Could not initialize device.\n"); dev_err(dev, "Could not initialize device.\n");
return result; goto error_power_off;
} }
dev_set_drvdata(dev, indio_dev); dev_set_drvdata(dev, indio_dev);
...@@ -1353,8 +1344,16 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name, ...@@ -1353,8 +1344,16 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name,
indio_dev->name = dev_name(dev); indio_dev->name = dev_name(dev);
/* requires parent device set in indio_dev */ /* requires parent device set in indio_dev */
if (inv_mpu_bus_setup) if (inv_mpu_bus_setup) {
inv_mpu_bus_setup(indio_dev); result = inv_mpu_bus_setup(indio_dev);
if (result)
goto error_power_off;
}
/* chip init is done, turning off */
result = inv_mpu6050_set_power_itg(st, false);
if (result)
return result;
switch (chip_type) { switch (chip_type) {
case INV_MPU9150: case INV_MPU9150:
...@@ -1413,6 +1412,10 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name, ...@@ -1413,6 +1412,10 @@ int inv_mpu_core_probe(struct regmap *regmap, int irq, const char *name,
} }
return 0; return 0;
error_power_off:
inv_mpu6050_set_power_itg(st, false);
return result;
} }
EXPORT_SYMBOL_GPL(inv_mpu_core_probe); EXPORT_SYMBOL_GPL(inv_mpu_core_probe);
......
...@@ -78,22 +78,13 @@ static int inv_mpu_i2c_aux_setup(struct iio_dev *indio_dev) ...@@ -78,22 +78,13 @@ static int inv_mpu_i2c_aux_setup(struct iio_dev *indio_dev)
/* enable i2c bypass when using i2c auxiliary bus */ /* enable i2c bypass when using i2c auxiliary bus */
if (inv_mpu_i2c_aux_bus(dev)) { if (inv_mpu_i2c_aux_bus(dev)) {
ret = inv_mpu6050_set_power_itg(st, true);
if (ret)
return ret;
ret = regmap_write(st->map, st->reg->int_pin_cfg, ret = regmap_write(st->map, st->reg->int_pin_cfg,
st->irq_mask | INV_MPU6050_BIT_BYPASS_EN); st->irq_mask | INV_MPU6050_BIT_BYPASS_EN);
if (ret) if (ret)
goto error; return ret;
ret = inv_mpu6050_set_power_itg(st, false);
if (ret)
goto error;
} }
return 0; return 0;
error:
inv_mpu6050_set_power_itg(st, false);
return ret;
} }
/** /**
......
...@@ -21,10 +21,6 @@ static int inv_mpu_i2c_disable(struct iio_dev *indio_dev) ...@@ -21,10 +21,6 @@ static int inv_mpu_i2c_disable(struct iio_dev *indio_dev)
struct inv_mpu6050_state *st = iio_priv(indio_dev); struct inv_mpu6050_state *st = iio_priv(indio_dev);
int ret = 0; int ret = 0;
ret = inv_mpu6050_set_power_itg(st, true);
if (ret)
return ret;
if (st->reg->i2c_if) { if (st->reg->i2c_if) {
ret = regmap_write(st->map, st->reg->i2c_if, ret = regmap_write(st->map, st->reg->i2c_if,
INV_ICM20602_BIT_I2C_IF_DIS); INV_ICM20602_BIT_I2C_IF_DIS);
...@@ -33,12 +29,8 @@ static int inv_mpu_i2c_disable(struct iio_dev *indio_dev) ...@@ -33,12 +29,8 @@ static int inv_mpu_i2c_disable(struct iio_dev *indio_dev)
ret = regmap_write(st->map, st->reg->user_ctrl, ret = regmap_write(st->map, st->reg->user_ctrl,
st->chip_config.user_ctrl); st->chip_config.user_ctrl);
} }
if (ret) {
inv_mpu6050_set_power_itg(st, false);
return ret;
}
return inv_mpu6050_set_power_itg(st, false); return ret;
} }
static int inv_mpu_probe(struct spi_device *spi) static int inv_mpu_probe(struct spi_device *spi)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment