Commit 4aad1d94 authored by Rob Herring (Arm)'s avatar Rob Herring (Arm) Committed by Mark Brown

ASoC: PCM6240: Use of_property_read_reg()

Replace the open-coded parsing of "reg" with of_property_read_reg().
The #ifdef is also easily replaced with IS_ENABLED().
Signed-off-by: default avatarRob Herring (Arm) <robh@kernel.org>
Link: https://patch.msgid.link/20240702215349.839350-1-robh@kernel.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent d06432b0
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of_irq.h> #include <linux/of_irq.h>
#include <linux/of_address.h>
#include <linux/regmap.h> #include <linux/regmap.h>
#include <sound/pcm_params.h> #include <sound/pcm_params.h>
#include <sound/soc.h> #include <sound/soc.h>
...@@ -2081,10 +2082,6 @@ static int pcmdevice_i2c_probe(struct i2c_client *i2c) ...@@ -2081,10 +2082,6 @@ static int pcmdevice_i2c_probe(struct i2c_client *i2c)
struct device_node *np; struct device_node *np;
unsigned int dev_addrs[PCMDEVICE_MAX_I2C_DEVICES]; unsigned int dev_addrs[PCMDEVICE_MAX_I2C_DEVICES];
int ret = 0, i = 0, ndev = 0; int ret = 0, i = 0, ndev = 0;
#ifdef CONFIG_OF
const __be32 *reg, *reg_end;
int len, sw, aw;
#endif
pcm_dev = devm_kzalloc(&i2c->dev, sizeof(*pcm_dev), GFP_KERNEL); pcm_dev = devm_kzalloc(&i2c->dev, sizeof(*pcm_dev), GFP_KERNEL);
if (!pcm_dev) if (!pcm_dev)
...@@ -2118,27 +2115,19 @@ static int pcmdevice_i2c_probe(struct i2c_client *i2c) ...@@ -2118,27 +2115,19 @@ static int pcmdevice_i2c_probe(struct i2c_client *i2c)
i2c_set_clientdata(i2c, pcm_dev); i2c_set_clientdata(i2c, pcm_dev);
mutex_init(&pcm_dev->codec_lock); mutex_init(&pcm_dev->codec_lock);
np = pcm_dev->dev->of_node; np = pcm_dev->dev->of_node;
#ifdef CONFIG_OF
aw = of_n_addr_cells(np); if (IS_ENABLED(CONFIG_OF)) {
sw = of_n_size_cells(np); u64 addr;
if (sw == 0) {
reg = (const __be32 *)of_get_property(np, for (i = 0; i < PCMDEVICE_MAX_I2C_DEVICES; i++) {
"reg", &len); if (of_property_read_reg(np, i, &addr, NULL))
reg_end = reg + len/sizeof(*reg); break;
ndev = 0; dev_addrs[ndev++] = addr;
do { }
dev_addrs[ndev] = of_read_number(reg, aw);
reg += aw;
ndev++;
} while (reg < reg_end);
} else { } else {
ndev = 1; ndev = 1;
dev_addrs[0] = i2c->addr; dev_addrs[0] = i2c->addr;
} }
#else
ndev = 1;
dev_addrs[0] = i2c->addr;
#endif
pcm_dev->irq_info.gpio = of_irq_get(np, 0); pcm_dev->irq_info.gpio = of_irq_get(np, 0);
for (i = 0; i < ndev; i++) for (i = 0; i < ndev; i++)
......
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