Commit 34c76a51 authored by Antoniu Miclaus's avatar Antoniu Miclaus Committed by Guenter Roeck

hwmon: (ltc2991) remove device reference from state

Remove device reference from struct ltc2991_state since it is used only
inside the init function.

Pass the struct device as parameter to the init function instead.
Signed-off-by: default avatarAntoniu Miclaus <antoniu.miclaus@analog.com>
Link: https://lore.kernel.org/r/20231031095647.48376-1-antoniu.miclaus@analog.comSigned-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
parent 89fec128
...@@ -54,7 +54,6 @@ ...@@ -54,7 +54,6 @@
#define LTC2991_VCC_CH_NR 0 #define LTC2991_VCC_CH_NR 0
struct ltc2991_state { struct ltc2991_state {
struct device *dev;
struct regmap *regmap; struct regmap *regmap;
u32 r_sense_uohm[LTC2991_MAX_CHANNEL]; u32 r_sense_uohm[LTC2991_MAX_CHANNEL];
bool temp_en[LTC2991_MAX_CHANNEL]; bool temp_en[LTC2991_MAX_CHANNEL];
...@@ -283,19 +282,19 @@ static const struct regmap_config ltc2991_regmap_config = { ...@@ -283,19 +282,19 @@ static const struct regmap_config ltc2991_regmap_config = {
.max_register = 0x1D, .max_register = 0x1D,
}; };
static int ltc2991_init(struct ltc2991_state *st) static int ltc2991_init(struct ltc2991_state *st, struct device *dev)
{ {
struct fwnode_handle *child; struct fwnode_handle *child;
int ret; int ret;
u32 val, addr; u32 val, addr;
u8 v5_v8_reg_data = 0, v1_v4_reg_data = 0; u8 v5_v8_reg_data = 0, v1_v4_reg_data = 0;
ret = devm_regulator_get_enable(st->dev, "vcc"); ret = devm_regulator_get_enable(dev, "vcc");
if (ret) if (ret)
return dev_err_probe(st->dev, ret, return dev_err_probe(dev, ret,
"failed to enable regulator\n"); "failed to enable regulator\n");
device_for_each_child_node(st->dev, child) { device_for_each_child_node(dev, child) {
ret = fwnode_property_read_u32(child, "reg", &addr); ret = fwnode_property_read_u32(child, "reg", &addr);
if (ret < 0) { if (ret < 0) {
fwnode_handle_put(child); fwnode_handle_put(child);
...@@ -312,7 +311,7 @@ static int ltc2991_init(struct ltc2991_state *st) ...@@ -312,7 +311,7 @@ static int ltc2991_init(struct ltc2991_state *st)
&val); &val);
if (!ret) { if (!ret) {
if (!val) if (!val)
return dev_err_probe(st->dev, -EINVAL, return dev_err_probe(dev, -EINVAL,
"shunt resistor value cannot be zero\n"); "shunt resistor value cannot be zero\n");
st->r_sense_uohm[addr] = val; st->r_sense_uohm[addr] = val;
...@@ -361,18 +360,18 @@ static int ltc2991_init(struct ltc2991_state *st) ...@@ -361,18 +360,18 @@ static int ltc2991_init(struct ltc2991_state *st)
ret = regmap_write(st->regmap, LTC2991_V5_V8_CTRL, v5_v8_reg_data); ret = regmap_write(st->regmap, LTC2991_V5_V8_CTRL, v5_v8_reg_data);
if (ret) if (ret)
return dev_err_probe(st->dev, ret, return dev_err_probe(dev, ret,
"Error: Failed to set V5-V8 CTRL reg.\n"); "Error: Failed to set V5-V8 CTRL reg.\n");
ret = regmap_write(st->regmap, LTC2991_V1_V4_CTRL, v1_v4_reg_data); ret = regmap_write(st->regmap, LTC2991_V1_V4_CTRL, v1_v4_reg_data);
if (ret) if (ret)
return dev_err_probe(st->dev, ret, return dev_err_probe(dev, ret,
"Error: Failed to set V1-V4 CTRL reg.\n"); "Error: Failed to set V1-V4 CTRL reg.\n");
ret = regmap_write(st->regmap, LTC2991_PWM_TH_LSB_T_INT, ret = regmap_write(st->regmap, LTC2991_PWM_TH_LSB_T_INT,
LTC2991_REPEAT_ACQ_EN); LTC2991_REPEAT_ACQ_EN);
if (ret) if (ret)
return dev_err_probe(st->dev, ret, return dev_err_probe(dev, ret,
"Error: Failed to set continuous mode.\n"); "Error: Failed to set continuous mode.\n");
/* Enable all channels and trigger conversions */ /* Enable all channels and trigger conversions */
...@@ -392,12 +391,11 @@ static int ltc2991_i2c_probe(struct i2c_client *client) ...@@ -392,12 +391,11 @@ static int ltc2991_i2c_probe(struct i2c_client *client)
if (!st) if (!st)
return -ENOMEM; return -ENOMEM;
st->dev = &client->dev;
st->regmap = devm_regmap_init_i2c(client, &ltc2991_regmap_config); st->regmap = devm_regmap_init_i2c(client, &ltc2991_regmap_config);
if (IS_ERR(st->regmap)) if (IS_ERR(st->regmap))
return PTR_ERR(st->regmap); return PTR_ERR(st->regmap);
ret = ltc2991_init(st); ret = ltc2991_init(st, &client->dev);
if (ret) if (ret)
return ret; return ret;
......
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