ASoC: cs42l52: Convert to devm_regmap_init_i2c()
authorBrian Austin <brian.austin@cirrus.com>
Mon, 4 Jun 2012 18:19:42 +0000 (13:19 -0500)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Tue, 5 Jun 2012 10:03:35 +0000 (11:03 +0100)
Signed-off-by: Brian Austin <brian.austin@cirrus.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/codecs/cs42l52.c

index ec03abc..628daf6 100644 (file)
@@ -1216,11 +1216,11 @@ static int cs42l52_i2c_probe(struct i2c_client *i2c_client,
                return -ENOMEM;
        cs42l52->dev = &i2c_client->dev;
 
-       cs42l52->regmap = regmap_init_i2c(i2c_client, &cs42l52_regmap);
+       cs42l52->regmap = devm_regmap_init_i2c(i2c_client, &cs42l52_regmap);
        if (IS_ERR(cs42l52->regmap)) {
                ret = PTR_ERR(cs42l52->regmap);
                dev_err(&i2c_client->dev, "regmap_init() failed: %d\n", ret);
-               goto err;
+               return ret;
        }
 
        i2c_set_clientdata(i2c_client, cs42l52);
@@ -1242,7 +1242,7 @@ static int cs42l52_i2c_probe(struct i2c_client *i2c_client,
                dev_err(&i2c_client->dev,
                        "CS42L52 Device ID (%X). Expected %X\n",
                        devid, CS42L52_CHIP_ID);
-               goto err_regmap;
+               return ret;
        }
 
        regcache_cache_only(cs42l52->regmap, true);
@@ -1250,23 +1250,13 @@ static int cs42l52_i2c_probe(struct i2c_client *i2c_client,
        ret =  snd_soc_register_codec(&i2c_client->dev,
                        &soc_codec_dev_cs42l52, &cs42l52_dai, 1);
        if (ret < 0)
-               goto err_regmap;
+               return ret;
        return 0;
-
-err_regmap:
-       regmap_exit(cs42l52->regmap);
-
-err:
-       return ret;
 }
 
 static int cs42l52_i2c_remove(struct i2c_client *client)
 {
-       struct cs42l52_private *cs42l52 = i2c_get_clientdata(client);
-
        snd_soc_unregister_codec(&client->dev);
-       regmap_exit(cs42l52->regmap);
-
        return 0;
 }