diff options
Diffstat (limited to 'sound/soc/codecs/wm8753.c')
| -rw-r--r-- | sound/soc/codecs/wm8753.c | 47 |
1 files changed, 13 insertions, 34 deletions
diff --git a/sound/soc/codecs/wm8753.c b/sound/soc/codecs/wm8753.c index 2e4a775ae560..0a4ab4c423d1 100644 --- a/sound/soc/codecs/wm8753.c +++ b/sound/soc/codecs/wm8753.c | |||
| @@ -1550,7 +1550,7 @@ static const struct regmap_config wm8753_regmap = { | |||
| 1550 | }; | 1550 | }; |
| 1551 | 1551 | ||
| 1552 | #if defined(CONFIG_SPI_MASTER) | 1552 | #if defined(CONFIG_SPI_MASTER) |
| 1553 | static int __devinit wm8753_spi_probe(struct spi_device *spi) | 1553 | static int wm8753_spi_probe(struct spi_device *spi) |
| 1554 | { | 1554 | { |
| 1555 | struct wm8753_priv *wm8753; | 1555 | struct wm8753_priv *wm8753; |
| 1556 | int ret; | 1556 | int ret; |
| @@ -1562,36 +1562,25 @@ static int __devinit wm8753_spi_probe(struct spi_device *spi) | |||
| 1562 | 1562 | ||
| 1563 | spi_set_drvdata(spi, wm8753); | 1563 | spi_set_drvdata(spi, wm8753); |
| 1564 | 1564 | ||
| 1565 | wm8753->regmap = regmap_init_spi(spi, &wm8753_regmap); | 1565 | wm8753->regmap = devm_regmap_init_spi(spi, &wm8753_regmap); |
| 1566 | if (IS_ERR(wm8753->regmap)) { | 1566 | if (IS_ERR(wm8753->regmap)) { |
| 1567 | ret = PTR_ERR(wm8753->regmap); | 1567 | ret = PTR_ERR(wm8753->regmap); |
| 1568 | dev_err(&spi->dev, "Failed to allocate register map: %d\n", | 1568 | dev_err(&spi->dev, "Failed to allocate register map: %d\n", |
| 1569 | ret); | 1569 | ret); |
| 1570 | goto err; | 1570 | return ret; |
| 1571 | } | 1571 | } |
| 1572 | 1572 | ||
| 1573 | ret = snd_soc_register_codec(&spi->dev, &soc_codec_dev_wm8753, | 1573 | ret = snd_soc_register_codec(&spi->dev, &soc_codec_dev_wm8753, |
| 1574 | wm8753_dai, ARRAY_SIZE(wm8753_dai)); | 1574 | wm8753_dai, ARRAY_SIZE(wm8753_dai)); |
| 1575 | if (ret != 0) { | 1575 | if (ret != 0) |
| 1576 | dev_err(&spi->dev, "Failed to register CODEC: %d\n", ret); | 1576 | dev_err(&spi->dev, "Failed to register CODEC: %d\n", ret); |
| 1577 | goto err_regmap; | ||
| 1578 | } | ||
| 1579 | 1577 | ||
| 1580 | return 0; | ||
| 1581 | |||
| 1582 | err_regmap: | ||
| 1583 | regmap_exit(wm8753->regmap); | ||
| 1584 | err: | ||
| 1585 | return ret; | 1578 | return ret; |
| 1586 | } | 1579 | } |
| 1587 | 1580 | ||
| 1588 | static int __devexit wm8753_spi_remove(struct spi_device *spi) | 1581 | static int wm8753_spi_remove(struct spi_device *spi) |
| 1589 | { | 1582 | { |
| 1590 | struct wm8753_priv *wm8753 = spi_get_drvdata(spi); | ||
| 1591 | |||
| 1592 | snd_soc_unregister_codec(&spi->dev); | 1583 | snd_soc_unregister_codec(&spi->dev); |
| 1593 | regmap_exit(wm8753->regmap); | ||
| 1594 | kfree(wm8753); | ||
| 1595 | return 0; | 1584 | return 0; |
| 1596 | } | 1585 | } |
| 1597 | 1586 | ||
| @@ -1602,13 +1591,13 @@ static struct spi_driver wm8753_spi_driver = { | |||
| 1602 | .of_match_table = wm8753_of_match, | 1591 | .of_match_table = wm8753_of_match, |
| 1603 | }, | 1592 | }, |
| 1604 | .probe = wm8753_spi_probe, | 1593 | .probe = wm8753_spi_probe, |
| 1605 | .remove = __devexit_p(wm8753_spi_remove), | 1594 | .remove = wm8753_spi_remove, |
| 1606 | }; | 1595 | }; |
| 1607 | #endif /* CONFIG_SPI_MASTER */ | 1596 | #endif /* CONFIG_SPI_MASTER */ |
| 1608 | 1597 | ||
| 1609 | #if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE) | 1598 | #if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE) |
| 1610 | static __devinit int wm8753_i2c_probe(struct i2c_client *i2c, | 1599 | static int wm8753_i2c_probe(struct i2c_client *i2c, |
| 1611 | const struct i2c_device_id *id) | 1600 | const struct i2c_device_id *id) |
| 1612 | { | 1601 | { |
| 1613 | struct wm8753_priv *wm8753; | 1602 | struct wm8753_priv *wm8753; |
| 1614 | int ret; | 1603 | int ret; |
| @@ -1620,35 +1609,25 @@ static __devinit int wm8753_i2c_probe(struct i2c_client *i2c, | |||
| 1620 | 1609 | ||
| 1621 | i2c_set_clientdata(i2c, wm8753); | 1610 | i2c_set_clientdata(i2c, wm8753); |
| 1622 | 1611 | ||
| 1623 | wm8753->regmap = regmap_init_i2c(i2c, &wm8753_regmap); | 1612 | wm8753->regmap = devm_regmap_init_i2c(i2c, &wm8753_regmap); |
| 1624 | if (IS_ERR(wm8753->regmap)) { | 1613 | if (IS_ERR(wm8753->regmap)) { |
| 1625 | ret = PTR_ERR(wm8753->regmap); | 1614 | ret = PTR_ERR(wm8753->regmap); |
| 1626 | dev_err(&i2c->dev, "Failed to allocate register map: %d\n", | 1615 | dev_err(&i2c->dev, "Failed to allocate register map: %d\n", |
| 1627 | ret); | 1616 | ret); |
| 1628 | goto err; | 1617 | return ret; |
| 1629 | } | 1618 | } |
| 1630 | 1619 | ||
| 1631 | ret = snd_soc_register_codec(&i2c->dev, &soc_codec_dev_wm8753, | 1620 | ret = snd_soc_register_codec(&i2c->dev, &soc_codec_dev_wm8753, |
| 1632 | wm8753_dai, ARRAY_SIZE(wm8753_dai)); | 1621 | wm8753_dai, ARRAY_SIZE(wm8753_dai)); |
| 1633 | if (ret != 0) { | 1622 | if (ret != 0) |
| 1634 | dev_err(&i2c->dev, "Failed to register CODEC: %d\n", ret); | 1623 | dev_err(&i2c->dev, "Failed to register CODEC: %d\n", ret); |
| 1635 | goto err_regmap; | ||
| 1636 | } | ||
| 1637 | 1624 | ||
| 1638 | return 0; | ||
| 1639 | |||
| 1640 | err_regmap: | ||
| 1641 | regmap_exit(wm8753->regmap); | ||
| 1642 | err: | ||
| 1643 | return ret; | 1625 | return ret; |
| 1644 | } | 1626 | } |
| 1645 | 1627 | ||
| 1646 | static __devexit int wm8753_i2c_remove(struct i2c_client *client) | 1628 | static int wm8753_i2c_remove(struct i2c_client *client) |
| 1647 | { | 1629 | { |
| 1648 | struct wm8753_priv *wm8753 = i2c_get_clientdata(client); | ||
| 1649 | |||
| 1650 | snd_soc_unregister_codec(&client->dev); | 1630 | snd_soc_unregister_codec(&client->dev); |
| 1651 | regmap_exit(wm8753->regmap); | ||
| 1652 | return 0; | 1631 | return 0; |
| 1653 | } | 1632 | } |
| 1654 | 1633 | ||
| @@ -1665,7 +1644,7 @@ static struct i2c_driver wm8753_i2c_driver = { | |||
| 1665 | .of_match_table = wm8753_of_match, | 1644 | .of_match_table = wm8753_of_match, |
| 1666 | }, | 1645 | }, |
| 1667 | .probe = wm8753_i2c_probe, | 1646 | .probe = wm8753_i2c_probe, |
| 1668 | .remove = __devexit_p(wm8753_i2c_remove), | 1647 | .remove = wm8753_i2c_remove, |
| 1669 | .id_table = wm8753_i2c_id, | 1648 | .id_table = wm8753_i2c_id, |
| 1670 | }; | 1649 | }; |
| 1671 | #endif | 1650 | #endif |
