cs42l42-i2c.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * cs42l42-i2c.c -- CS42L42 ALSA SoC audio driver for I2C
  4. *
  5. * Copyright 2016, 2022 Cirrus Logic, Inc.
  6. */
  7. #include <linux/i2c.h>
  8. #include <linux/module.h>
  9. #include <linux/regmap.h>
  10. #include <linux/slab.h>
  11. #include <linux/types.h>
  12. #include "cs42l42.h"
  13. static int cs42l42_i2c_probe(struct i2c_client *i2c_client)
  14. {
  15. struct device *dev = &i2c_client->dev;
  16. struct cs42l42_private *cs42l42;
  17. struct regmap *regmap;
  18. int ret;
  19. cs42l42 = devm_kzalloc(dev, sizeof(*cs42l42), GFP_KERNEL);
  20. if (!cs42l42)
  21. return -ENOMEM;
  22. regmap = devm_regmap_init_i2c(i2c_client, &cs42l42_regmap);
  23. if (IS_ERR(regmap))
  24. return dev_err_probe(&i2c_client->dev, PTR_ERR(regmap),
  25. "regmap_init() failed\n");
  26. cs42l42->devid = CS42L42_CHIP_ID;
  27. cs42l42->dev = dev;
  28. cs42l42->regmap = regmap;
  29. cs42l42->irq = i2c_client->irq;
  30. ret = cs42l42_common_probe(cs42l42, &cs42l42_soc_component, &cs42l42_dai);
  31. if (ret)
  32. return ret;
  33. return cs42l42_init(cs42l42);
  34. }
  35. static void cs42l42_i2c_remove(struct i2c_client *i2c_client)
  36. {
  37. struct cs42l42_private *cs42l42 = dev_get_drvdata(&i2c_client->dev);
  38. cs42l42_common_remove(cs42l42);
  39. }
  40. static int __maybe_unused cs42l42_i2c_resume(struct device *dev)
  41. {
  42. int ret;
  43. ret = cs42l42_resume(dev);
  44. if (ret)
  45. return ret;
  46. cs42l42_resume_restore(dev);
  47. return 0;
  48. }
  49. static const struct dev_pm_ops cs42l42_i2c_pm_ops = {
  50. SET_SYSTEM_SLEEP_PM_OPS(cs42l42_suspend, cs42l42_i2c_resume)
  51. };
  52. static const struct of_device_id __maybe_unused cs42l42_of_match[] = {
  53. { .compatible = "cirrus,cs42l42", },
  54. {}
  55. };
  56. MODULE_DEVICE_TABLE(of, cs42l42_of_match);
  57. static const struct acpi_device_id __maybe_unused cs42l42_acpi_match[] = {
  58. {"10134242", 0,},
  59. {}
  60. };
  61. MODULE_DEVICE_TABLE(acpi, cs42l42_acpi_match);
  62. static const struct i2c_device_id cs42l42_id[] = {
  63. {"cs42l42", 0},
  64. {}
  65. };
  66. MODULE_DEVICE_TABLE(i2c, cs42l42_id);
  67. static struct i2c_driver cs42l42_i2c_driver = {
  68. .driver = {
  69. .name = "cs42l42",
  70. .pm = &cs42l42_i2c_pm_ops,
  71. .of_match_table = of_match_ptr(cs42l42_of_match),
  72. .acpi_match_table = ACPI_PTR(cs42l42_acpi_match),
  73. },
  74. .id_table = cs42l42_id,
  75. .probe_new = cs42l42_i2c_probe,
  76. .remove = cs42l42_i2c_remove,
  77. };
  78. module_i2c_driver(cs42l42_i2c_driver);
  79. MODULE_DESCRIPTION("ASoC CS42L42 I2C driver");
  80. MODULE_AUTHOR("Richard Fitzgerald <[email protected]>");
  81. MODULE_LICENSE("GPL");
  82. MODULE_IMPORT_NS(SND_SOC_CS42L42_CORE);