soc-devres.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /*
  2. * soc-devres.c -- ALSA SoC Audio Layer devres functions
  3. *
  4. * Copyright (C) 2013 Linaro Ltd
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License as published by the
  8. * Free Software Foundation; either version 2 of the License, or (at your
  9. * option) any later version.
  10. */
  11. #include <linux/module.h>
  12. #include <linux/moduleparam.h>
  13. #include <sound/soc.h>
  14. #include <sound/dmaengine_pcm.h>
  15. static void devm_component_release(struct device *dev, void *res)
  16. {
  17. snd_soc_unregister_component(*(struct device **)res);
  18. }
  19. /**
  20. * devm_snd_soc_register_component - resource managed component registration
  21. * @dev: Device used to manage component
  22. * @cmpnt_drv: Component driver
  23. * @dai_drv: DAI driver
  24. * @num_dai: Number of DAIs to register
  25. *
  26. * Register a component with automatic unregistration when the device is
  27. * unregistered.
  28. */
  29. int devm_snd_soc_register_component(struct device *dev,
  30. const struct snd_soc_component_driver *cmpnt_drv,
  31. struct snd_soc_dai_driver *dai_drv, int num_dai)
  32. {
  33. struct device **ptr;
  34. int ret;
  35. ptr = devres_alloc(devm_component_release, sizeof(*ptr), GFP_KERNEL);
  36. if (!ptr)
  37. return -ENOMEM;
  38. ret = snd_soc_register_component(dev, cmpnt_drv, dai_drv, num_dai);
  39. if (ret == 0) {
  40. *ptr = dev;
  41. devres_add(dev, ptr);
  42. } else {
  43. devres_free(ptr);
  44. }
  45. return ret;
  46. }
  47. EXPORT_SYMBOL_GPL(devm_snd_soc_register_component);
  48. static void devm_platform_release(struct device *dev, void *res)
  49. {
  50. snd_soc_unregister_platform(*(struct device **)res);
  51. }
  52. /**
  53. * devm_snd_soc_register_platform - resource managed platform registration
  54. * @dev: Device used to manage platform
  55. * @platform_drv: platform to register
  56. *
  57. * Register a platform driver with automatic unregistration when the device is
  58. * unregistered.
  59. */
  60. int devm_snd_soc_register_platform(struct device *dev,
  61. const struct snd_soc_platform_driver *platform_drv)
  62. {
  63. struct device **ptr;
  64. int ret;
  65. ptr = devres_alloc(devm_platform_release, sizeof(*ptr), GFP_KERNEL);
  66. if (!ptr)
  67. return -ENOMEM;
  68. ret = snd_soc_register_platform(dev, platform_drv);
  69. if (ret == 0) {
  70. *ptr = dev;
  71. devres_add(dev, ptr);
  72. } else {
  73. devres_free(ptr);
  74. }
  75. return ret;
  76. }
  77. EXPORT_SYMBOL_GPL(devm_snd_soc_register_platform);
  78. static void devm_card_release(struct device *dev, void *res)
  79. {
  80. snd_soc_unregister_card(*(struct snd_soc_card **)res);
  81. }
  82. /**
  83. * devm_snd_soc_register_card - resource managed card registration
  84. * @dev: Device used to manage card
  85. * @card: Card to register
  86. *
  87. * Register a card with automatic unregistration when the device is
  88. * unregistered.
  89. */
  90. int devm_snd_soc_register_card(struct device *dev, struct snd_soc_card *card)
  91. {
  92. struct snd_soc_card **ptr;
  93. int ret;
  94. ptr = devres_alloc(devm_card_release, sizeof(*ptr), GFP_KERNEL);
  95. if (!ptr)
  96. return -ENOMEM;
  97. ret = snd_soc_register_card(card);
  98. if (ret == 0) {
  99. *ptr = card;
  100. devres_add(dev, ptr);
  101. } else {
  102. devres_free(ptr);
  103. }
  104. return ret;
  105. }
  106. EXPORT_SYMBOL_GPL(devm_snd_soc_register_card);
  107. #ifdef CONFIG_SND_SOC_GENERIC_DMAENGINE_PCM
  108. static void devm_dmaengine_pcm_release(struct device *dev, void *res)
  109. {
  110. snd_dmaengine_pcm_unregister(*(struct device **)res);
  111. }
  112. /**
  113. * devm_snd_dmaengine_pcm_register - resource managed dmaengine PCM registration
  114. * @dev: The parent device for the PCM device
  115. * @config: Platform specific PCM configuration
  116. * @flags: Platform specific quirks
  117. *
  118. * Register a dmaengine based PCM device with automatic unregistration when the
  119. * device is unregistered.
  120. */
  121. int devm_snd_dmaengine_pcm_register(struct device *dev,
  122. const struct snd_dmaengine_pcm_config *config, unsigned int flags)
  123. {
  124. struct device **ptr;
  125. int ret;
  126. ptr = devres_alloc(devm_dmaengine_pcm_release, sizeof(*ptr), GFP_KERNEL);
  127. if (!ptr)
  128. return -ENOMEM;
  129. ret = snd_dmaengine_pcm_register(dev, config, flags);
  130. if (ret == 0) {
  131. *ptr = dev;
  132. devres_add(dev, ptr);
  133. } else {
  134. devres_free(ptr);
  135. }
  136. return ret;
  137. }
  138. EXPORT_SYMBOL_GPL(devm_snd_dmaengine_pcm_register);
  139. #endif