db1000.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * DB1000/DB1500/DB1100 ASoC audio fabric support code.
  3. *
  4. * (c) 2011 Manuel Lauss <manuel.lauss@googlemail.com>
  5. *
  6. */
  7. #include <linux/module.h>
  8. #include <linux/moduleparam.h>
  9. #include <linux/timer.h>
  10. #include <linux/interrupt.h>
  11. #include <linux/platform_device.h>
  12. #include <sound/core.h>
  13. #include <sound/pcm.h>
  14. #include <sound/soc.h>
  15. #include <asm/mach-au1x00/au1000.h>
  16. #include <asm/mach-db1x00/bcsr.h>
  17. #include "psc.h"
  18. static struct snd_soc_dai_link db1000_ac97_dai = {
  19. .name = "AC97",
  20. .stream_name = "AC97 HiFi",
  21. .codec_dai_name = "ac97-hifi",
  22. .cpu_dai_name = "alchemy-ac97c",
  23. .platform_name = "alchemy-pcm-dma.0",
  24. .codec_name = "ac97-codec",
  25. };
  26. static struct snd_soc_card db1000_ac97 = {
  27. .name = "DB1000_AC97",
  28. .owner = THIS_MODULE,
  29. .dai_link = &db1000_ac97_dai,
  30. .num_links = 1,
  31. };
  32. static int __devinit db1000_audio_probe(struct platform_device *pdev)
  33. {
  34. struct snd_soc_card *card = &db1000_ac97;
  35. card->dev = &pdev->dev;
  36. return snd_soc_register_card(card);
  37. }
  38. static int __devexit db1000_audio_remove(struct platform_device *pdev)
  39. {
  40. struct snd_soc_card *card = platform_get_drvdata(pdev);
  41. snd_soc_unregister_card(card);
  42. return 0;
  43. }
  44. static struct platform_driver db1000_audio_driver = {
  45. .driver = {
  46. .name = "db1000-audio",
  47. .owner = THIS_MODULE,
  48. .pm = &snd_soc_pm_ops,
  49. },
  50. .probe = db1000_audio_probe,
  51. .remove = __devexit_p(db1000_audio_remove),
  52. };
  53. module_platform_driver(db1000_audio_driver);
  54. MODULE_LICENSE("GPL");
  55. MODULE_DESCRIPTION("DB1000/DB1500/DB1100 ASoC audio");
  56. MODULE_AUTHOR("Manuel Lauss");