staging: iio: isl29028: remove chip test and defaults from isl29028_chip_init()

isl29028_chip_init() contains the device driver defaults and
two I2C calls that detect the presence of the chip. This patch
moves these into isl29028_probe() so that this function can
be used by the power management runtinme in a followup patch. This
patch also renames isl29028_chip_init() to
isl29028_chip_init_and_power_on().

Signed-off-by: Brian Masney <masneyb@onstation.org>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
This commit is contained in:
Brian Masney 2016-12-03 21:19:27 -05:00 committed by Jonathan Cameron
parent f40531d1e7
commit 58f643669e
1 changed files with 22 additions and 20 deletions

View File

@ -418,29 +418,11 @@ static const struct iio_info isl29028_info = {
.write_raw = isl29028_write_raw, .write_raw = isl29028_write_raw,
}; };
static int isl29028_chip_init(struct isl29028_chip *chip) static int isl29028_chip_init_and_power_on(struct isl29028_chip *chip)
{ {
struct device *dev = regmap_get_device(chip->regmap); struct device *dev = regmap_get_device(chip->regmap);
int ret; int ret;
chip->enable_prox = false;
chip->prox_sampling = 20;
chip->lux_scale = 2000;
chip->als_ir_mode = ISL29028_MODE_NONE;
ret = regmap_write(chip->regmap, ISL29028_REG_TEST1_MODE, 0x0);
if (ret < 0) {
dev_err(dev, "%s(): write to reg %d failed, err = %d\n",
__func__, ISL29028_REG_TEST1_MODE, ret);
return ret;
}
ret = regmap_write(chip->regmap, ISL29028_REG_TEST2_MODE, 0x0);
if (ret < 0) {
dev_err(dev, "%s(): write to reg %d failed, err = %d\n",
__func__, ISL29028_REG_TEST2_MODE, ret);
return ret;
}
ret = regmap_write(chip->regmap, ISL29028_REG_CONFIGURE, 0x0); ret = regmap_write(chip->regmap, ISL29028_REG_CONFIGURE, 0x0);
if (ret < 0) { if (ret < 0) {
dev_err(dev, "%s(): write to reg %d failed, err = %d\n", dev_err(dev, "%s(): write to reg %d failed, err = %d\n",
@ -508,7 +490,27 @@ static int isl29028_probe(struct i2c_client *client,
return ret; return ret;
} }
ret = isl29028_chip_init(chip); chip->enable_prox = false;
chip->prox_sampling = 20;
chip->lux_scale = 2000;
chip->als_ir_mode = ISL29028_MODE_NONE;
ret = regmap_write(chip->regmap, ISL29028_REG_TEST1_MODE, 0x0);
if (ret < 0) {
dev_err(&client->dev,
"%s(): write to reg %d failed, err = %d\n", __func__,
ISL29028_REG_TEST1_MODE, ret);
return ret;
}
ret = regmap_write(chip->regmap, ISL29028_REG_TEST2_MODE, 0x0);
if (ret < 0) {
dev_err(&client->dev,
"%s(): write to reg %d failed, err = %d\n", __func__,
ISL29028_REG_TEST2_MODE, ret);
return ret;
}
ret = isl29028_chip_init_and_power_on(chip);
if (ret < 0) { if (ret < 0) {
dev_err(&client->dev, "chip initialization failed: %d\n", ret); dev_err(&client->dev, "chip initialization failed: %d\n", ret);
return ret; return ret;