ak4531_codec.h 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. #ifndef __SOUND_AK4531_CODEC_H
  3. #define __SOUND_AK4531_CODEC_H
  4. /*
  5. * Copyright (c) by Jaroslav Kysela <perex@perex.cz>
  6. * Universal interface for Audio Codec '97
  7. *
  8. * For more details look to AC '97 component specification revision 2.1
  9. * by Intel Corporation (http://developer.intel.com).
  10. */
  11. #include <sound/info.h>
  12. #include <sound/control.h>
  13. /*
  14. * ASAHI KASEI - AK4531 codec
  15. * - not really AC'97 codec, but it uses very similar interface as AC'97
  16. */
  17. /*
  18. * AK4531 codec registers
  19. */
  20. #define AK4531_LMASTER 0x00 /* master volume left */
  21. #define AK4531_RMASTER 0x01 /* master volume right */
  22. #define AK4531_LVOICE 0x02 /* channel volume left */
  23. #define AK4531_RVOICE 0x03 /* channel volume right */
  24. #define AK4531_LFM 0x04 /* FM volume left */
  25. #define AK4531_RFM 0x05 /* FM volume right */
  26. #define AK4531_LCD 0x06 /* CD volume left */
  27. #define AK4531_RCD 0x07 /* CD volume right */
  28. #define AK4531_LLINE 0x08 /* LINE volume left */
  29. #define AK4531_RLINE 0x09 /* LINE volume right */
  30. #define AK4531_LAUXA 0x0a /* AUXA volume left */
  31. #define AK4531_RAUXA 0x0b /* AUXA volume right */
  32. #define AK4531_MONO1 0x0c /* MONO1 volume left */
  33. #define AK4531_MONO2 0x0d /* MONO1 volume right */
  34. #define AK4531_MIC 0x0e /* MIC volume */
  35. #define AK4531_MONO_OUT 0x0f /* Mono-out volume */
  36. #define AK4531_OUT_SW1 0x10 /* Output mixer switch 1 */
  37. #define AK4531_OUT_SW2 0x11 /* Output mixer switch 2 */
  38. #define AK4531_LIN_SW1 0x12 /* Input left mixer switch 1 */
  39. #define AK4531_RIN_SW1 0x13 /* Input right mixer switch 1 */
  40. #define AK4531_LIN_SW2 0x14 /* Input left mixer switch 2 */
  41. #define AK4531_RIN_SW2 0x15 /* Input right mixer switch 2 */
  42. #define AK4531_RESET 0x16 /* Reset & power down */
  43. #define AK4531_CLOCK 0x17 /* Clock select */
  44. #define AK4531_AD_IN 0x18 /* AD input select */
  45. #define AK4531_MIC_GAIN 0x19 /* MIC amplified gain */
  46. struct snd_ak4531 {
  47. void (*write) (struct snd_ak4531 *ak4531, unsigned short reg,
  48. unsigned short val);
  49. void *private_data;
  50. void (*private_free) (struct snd_ak4531 *ak4531);
  51. /* --- */
  52. unsigned char regs[0x20];
  53. struct mutex reg_mutex;
  54. };
  55. int snd_ak4531_mixer(struct snd_card *card, struct snd_ak4531 *_ak4531,
  56. struct snd_ak4531 **rak4531);
  57. #ifdef CONFIG_PM
  58. void snd_ak4531_suspend(struct snd_ak4531 *ak4531);
  59. void snd_ak4531_resume(struct snd_ak4531 *ak4531);
  60. #else
  61. static inline void snd_ak4531_suspend(struct snd_ak4531 *ak4531) {}
  62. static inline void snd_ak4531_resume(struct snd_ak4531 *ak4531) {}
  63. #endif
  64. #endif /* __SOUND_AK4531_CODEC_H */