aboutsummaryrefslogtreecommitdiffstats
path: root/sound
diff options
context:
space:
mode:
Diffstat (limited to 'sound')
-rw-r--r--sound/soc/codecs/wm8753.c209
1 files changed, 105 insertions, 104 deletions
diff --git a/sound/soc/codecs/wm8753.c b/sound/soc/codecs/wm8753.c
index 93c22c4f0826..4b426888f98d 100644
--- a/sound/soc/codecs/wm8753.c
+++ b/sound/soc/codecs/wm8753.c
@@ -51,6 +51,11 @@
51 51
52#include "wm8753.h" 52#include "wm8753.h"
53 53
54#ifdef CONFIG_SPI_MASTER
55static struct spi_driver wm8753_spi_driver;
56static int wm8753_spi_write(struct spi_device *spi, const char *data, int len);
57#endif
58
54static int caps_charge = 2000; 59static int caps_charge = 2000;
55module_param(caps_charge, int, 0); 60module_param(caps_charge, int, 0);
56MODULE_PARM_DESC(caps_charge, "WM8753 cap charge time (msecs)"); 61MODULE_PARM_DESC(caps_charge, "WM8753 cap charge time (msecs)");
@@ -1626,53 +1631,7 @@ pcm_err:
1626static struct snd_soc_device *wm8753_socdev; 1631static struct snd_soc_device *wm8753_socdev;
1627 1632
1628#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE) 1633#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
1629 1634static struct i2c_driver wm8753_i2c_driver;
1630/*
1631 * WM8753 2 wire address is determined by GPIO5
1632 * state during powerup.
1633 * low = 0x1a
1634 * high = 0x1b
1635 */
1636
1637static int wm8753_i2c_probe(struct i2c_client *i2c,
1638 const struct i2c_device_id *id)
1639{
1640 struct snd_soc_device *socdev = wm8753_socdev;
1641 struct snd_soc_codec *codec = socdev->card->codec;
1642 int ret;
1643
1644 i2c_set_clientdata(i2c, codec);
1645 codec->control_data = i2c;
1646
1647 ret = wm8753_init(socdev);
1648 if (ret < 0)
1649 pr_err("failed to initialise WM8753\n");
1650
1651 return ret;
1652}
1653
1654static int wm8753_i2c_remove(struct i2c_client *client)
1655{
1656 struct snd_soc_codec *codec = i2c_get_clientdata(client);
1657 kfree(codec->reg_cache);
1658 return 0;
1659}
1660
1661static const struct i2c_device_id wm8753_i2c_id[] = {
1662 { "wm8753", 0 },
1663 { }
1664};
1665MODULE_DEVICE_TABLE(i2c, wm8753_i2c_id);
1666
1667static struct i2c_driver wm8753_i2c_driver = {
1668 .driver = {
1669 .name = "WM8753 I2C Codec",
1670 .owner = THIS_MODULE,
1671 },
1672 .probe = wm8753_i2c_probe,
1673 .remove = wm8753_i2c_remove,
1674 .id_table = wm8753_i2c_id,
1675};
1676 1635
1677static int wm8753_add_i2c_device(struct platform_device *pdev, 1636static int wm8753_add_i2c_device(struct platform_device *pdev,
1678 const struct wm8753_setup_data *setup) 1637 const struct wm8753_setup_data *setup)
@@ -1715,63 +1674,6 @@ err_driver:
1715} 1674}
1716#endif 1675#endif
1717 1676
1718#if defined(CONFIG_SPI_MASTER)
1719static int __devinit wm8753_spi_probe(struct spi_device *spi)
1720{
1721 struct snd_soc_device *socdev = wm8753_socdev;
1722 struct snd_soc_codec *codec = socdev->card->codec;
1723 int ret;
1724
1725 codec->control_data = spi;
1726
1727 ret = wm8753_init(socdev);
1728 if (ret < 0)
1729 dev_err(&spi->dev, "failed to initialise WM8753\n");
1730
1731 return ret;
1732}
1733
1734static int __devexit wm8753_spi_remove(struct spi_device *spi)
1735{
1736 return 0;
1737}
1738
1739static struct spi_driver wm8753_spi_driver = {
1740 .driver = {
1741 .name = "wm8753",
1742 .bus = &spi_bus_type,
1743 .owner = THIS_MODULE,
1744 },
1745 .probe = wm8753_spi_probe,
1746 .remove = __devexit_p(wm8753_spi_remove),
1747};
1748
1749static int wm8753_spi_write(struct spi_device *spi, const char *data, int len)
1750{
1751 struct spi_transfer t;
1752 struct spi_message m;
1753 u8 msg[2];
1754
1755 if (len <= 0)
1756 return 0;
1757
1758 msg[0] = data[0];
1759 msg[1] = data[1];
1760
1761 spi_message_init(&m);
1762 memset(&t, 0, (sizeof t));
1763
1764 t.tx_buf = &msg[0];
1765 t.len = len;
1766
1767 spi_message_add_tail(&t, &m);
1768 spi_sync(spi, &m);
1769
1770 return len;
1771}
1772#endif
1773
1774
1775static int wm8753_probe(struct platform_device *pdev) 1677static int wm8753_probe(struct platform_device *pdev)
1776{ 1678{
1777 struct snd_soc_device *socdev = platform_get_drvdata(pdev); 1679 struct snd_soc_device *socdev = platform_get_drvdata(pdev);
@@ -1876,6 +1778,105 @@ struct snd_soc_codec_device soc_codec_dev_wm8753 = {
1876}; 1778};
1877EXPORT_SYMBOL_GPL(soc_codec_dev_wm8753); 1779EXPORT_SYMBOL_GPL(soc_codec_dev_wm8753);
1878 1780
1781#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
1782
1783static int wm8753_i2c_probe(struct i2c_client *i2c,
1784 const struct i2c_device_id *id)
1785{
1786 struct snd_soc_device *socdev = wm8753_socdev;
1787 struct snd_soc_codec *codec = socdev->card->codec;
1788 int ret;
1789
1790 i2c_set_clientdata(i2c, codec);
1791 codec->control_data = i2c;
1792
1793 ret = wm8753_init(socdev);
1794 if (ret < 0)
1795 pr_err("failed to initialise WM8753\n");
1796
1797 return ret;
1798}
1799
1800static int wm8753_i2c_remove(struct i2c_client *client)
1801{
1802 struct snd_soc_codec *codec = i2c_get_clientdata(client);
1803 kfree(codec->reg_cache);
1804 return 0;
1805}
1806
1807static const struct i2c_device_id wm8753_i2c_id[] = {
1808 { "wm8753", 0 },
1809 { }
1810};
1811MODULE_DEVICE_TABLE(i2c, wm8753_i2c_id);
1812
1813static struct i2c_driver wm8753_i2c_driver = {
1814 .driver = {
1815 .name = "WM8753 I2C Codec",
1816 .owner = THIS_MODULE,
1817 },
1818 .probe = wm8753_i2c_probe,
1819 .remove = wm8753_i2c_remove,
1820 .id_table = wm8753_i2c_id,
1821};
1822#endif
1823
1824#if defined(CONFIG_SPI_MASTER)
1825static int wm8753_spi_write(struct spi_device *spi, const char *data, int len)
1826{
1827 struct spi_transfer t;
1828 struct spi_message m;
1829 u8 msg[2];
1830
1831 if (len <= 0)
1832 return 0;
1833
1834 msg[0] = data[0];
1835 msg[1] = data[1];
1836
1837 spi_message_init(&m);
1838 memset(&t, 0, (sizeof t));
1839
1840 t.tx_buf = &msg[0];
1841 t.len = len;
1842
1843 spi_message_add_tail(&t, &m);
1844 spi_sync(spi, &m);
1845
1846 return len;
1847}
1848
1849static int __devinit wm8753_spi_probe(struct spi_device *spi)
1850{
1851 struct snd_soc_device *socdev = wm8753_socdev;
1852 struct snd_soc_codec *codec = socdev->card->codec;
1853 int ret;
1854
1855 codec->control_data = spi;
1856
1857 ret = wm8753_init(socdev);
1858 if (ret < 0)
1859 dev_err(&spi->dev, "failed to initialise WM8753\n");
1860
1861 return ret;
1862}
1863
1864static int __devexit wm8753_spi_remove(struct spi_device *spi)
1865{
1866 return 0;
1867}
1868
1869static struct spi_driver wm8753_spi_driver = {
1870 .driver = {
1871 .name = "wm8753",
1872 .bus = &spi_bus_type,
1873 .owner = THIS_MODULE,
1874 },
1875 .probe = wm8753_spi_probe,
1876 .remove = __devexit_p(wm8753_spi_remove),
1877};
1878#endif
1879
1879static int __init wm8753_modinit(void) 1880static int __init wm8753_modinit(void)
1880{ 1881{
1881 return snd_soc_register_dais(wm8753_dai, ARRAY_SIZE(wm8753_dai)); 1882 return snd_soc_register_dais(wm8753_dai, ARRAY_SIZE(wm8753_dai));