Commit 39d5790d authored by Jonathan Cameron's avatar Jonathan Cameron

iio: adc: fsl-imx25-gcq: Switch from of specific handing to fwnode based.

Using the generic firmware data access functions from property.h
provides a number of advantages:
1) Works with different firmware types.
2) Doesn't provide a 'bad' example for new IIO drivers.
3) Lets us use the new _scoped() loops with automatic reference count
   cleanup for fwnode_handle
Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20240218172731.1023367-2-jic23@kernel.orgSigned-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 8a85e72e
...@@ -12,8 +12,9 @@ ...@@ -12,8 +12,9 @@
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/mfd/imx25-tsadc.h> #include <linux/mfd/imx25-tsadc.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of.h> #include <linux/mod_devicetable.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/property.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <linux/regulator/consumer.h> #include <linux/regulator/consumer.h>
...@@ -198,8 +199,6 @@ static int mx25_gcq_ext_regulator_setup(struct device *dev, ...@@ -198,8 +199,6 @@ static int mx25_gcq_ext_regulator_setup(struct device *dev,
static int mx25_gcq_setup_cfgs(struct platform_device *pdev, static int mx25_gcq_setup_cfgs(struct platform_device *pdev,
struct mx25_gcq_priv *priv) struct mx25_gcq_priv *priv)
{ {
struct device_node *np = pdev->dev.of_node;
struct device_node *child;
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
int ret, i; int ret, i;
...@@ -216,37 +215,30 @@ static int mx25_gcq_setup_cfgs(struct platform_device *pdev, ...@@ -216,37 +215,30 @@ static int mx25_gcq_setup_cfgs(struct platform_device *pdev,
MX25_ADCQ_CFG_IN(i) | MX25_ADCQ_CFG_IN(i) |
MX25_ADCQ_CFG_REFN_NGND2); MX25_ADCQ_CFG_REFN_NGND2);
for_each_child_of_node(np, child) { device_for_each_child_node_scoped(dev, child) {
u32 reg; u32 reg;
u32 refp = MX25_ADCQ_CFG_REFP_INT; u32 refp = MX25_ADCQ_CFG_REFP_INT;
u32 refn = MX25_ADCQ_CFG_REFN_NGND2; u32 refn = MX25_ADCQ_CFG_REFN_NGND2;
ret = of_property_read_u32(child, "reg", &reg); ret = fwnode_property_read_u32(child, "reg", &reg);
if (ret) { if (ret)
dev_err(dev, "Failed to get reg property\n"); return dev_err_probe(dev, ret,
of_node_put(child); "Failed to get reg property\n");
return ret;
}
if (reg >= MX25_NUM_CFGS) { if (reg >= MX25_NUM_CFGS)
dev_err(dev, return dev_err_probe(dev, -EINVAL,
"reg value is greater than the number of available configuration registers\n"); "reg value is greater than the number of available configuration registers\n");
of_node_put(child);
return -EINVAL;
}
of_property_read_u32(child, "fsl,adc-refp", &refp); fwnode_property_read_u32(child, "fsl,adc-refp", &refp);
of_property_read_u32(child, "fsl,adc-refn", &refn); fwnode_property_read_u32(child, "fsl,adc-refn", &refn);
switch (refp) { switch (refp) {
case MX25_ADC_REFP_EXT: case MX25_ADC_REFP_EXT:
case MX25_ADC_REFP_XP: case MX25_ADC_REFP_XP:
case MX25_ADC_REFP_YP: case MX25_ADC_REFP_YP:
ret = mx25_gcq_ext_regulator_setup(&pdev->dev, priv, refp); ret = mx25_gcq_ext_regulator_setup(&pdev->dev, priv, refp);
if (ret) { if (ret)
of_node_put(child);
return ret; return ret;
}
priv->channel_vref_mv[reg] = priv->channel_vref_mv[reg] =
regulator_get_voltage(priv->vref[refp]); regulator_get_voltage(priv->vref[refp]);
/* Conversion from uV to mV */ /* Conversion from uV to mV */
...@@ -256,9 +248,8 @@ static int mx25_gcq_setup_cfgs(struct platform_device *pdev, ...@@ -256,9 +248,8 @@ static int mx25_gcq_setup_cfgs(struct platform_device *pdev,
priv->channel_vref_mv[reg] = 2500; priv->channel_vref_mv[reg] = 2500;
break; break;
default: default:
dev_err(dev, "Invalid positive reference %d\n", refp); return dev_err_probe(dev, -EINVAL,
of_node_put(child); "Invalid positive reference %d\n", refp);
return -EINVAL;
} }
/* /*
...@@ -268,16 +259,13 @@ static int mx25_gcq_setup_cfgs(struct platform_device *pdev, ...@@ -268,16 +259,13 @@ static int mx25_gcq_setup_cfgs(struct platform_device *pdev,
refp = MX25_ADCQ_CFG_REFP(refp); refp = MX25_ADCQ_CFG_REFP(refp);
refn = MX25_ADCQ_CFG_REFN(refn); refn = MX25_ADCQ_CFG_REFN(refn);
if ((refp & MX25_ADCQ_CFG_REFP_MASK) != refp) { if ((refp & MX25_ADCQ_CFG_REFP_MASK) != refp)
dev_err(dev, "Invalid fsl,adc-refp property value\n"); return dev_err_probe(dev, -EINVAL,
of_node_put(child); "Invalid fsl,adc-refp property value\n");
return -EINVAL;
} if ((refn & MX25_ADCQ_CFG_REFN_MASK) != refn)
if ((refn & MX25_ADCQ_CFG_REFN_MASK) != refn) { return dev_err_probe(dev, -EINVAL,
dev_err(dev, "Invalid fsl,adc-refn property value\n"); "Invalid fsl,adc-refn property value\n");
of_node_put(child);
return -EINVAL;
}
regmap_update_bits(priv->regs, MX25_ADCQ_CFG(reg), regmap_update_bits(priv->regs, MX25_ADCQ_CFG(reg),
MX25_ADCQ_CFG_REFP_MASK | MX25_ADCQ_CFG_REFP_MASK |
......
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