aqt1000-clsh.h 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /* Copyright (c) 2015-2018, The Linux Foundation. All rights reserved.
  3. */
  4. #ifndef _AQT1000_CLSH_H
  5. #define _AQT1000_CLSH_H
  6. #include <linux/module.h>
  7. #include <linux/slab.h>
  8. #include <sound/soc.h>
  9. #include <linux/kernel.h>
  10. #define CLSH_REQ_ENABLE true
  11. #define CLSH_REQ_DISABLE false
  12. #define AQT_CLSH_EVENT_PRE_DAC 0x01
  13. #define AQT_CLSH_EVENT_POST_PA 0x02
  14. /*
  15. * Basic states for Class H state machine.
  16. * represented as a bit mask within a u8 data type
  17. * bit 0: HPH Left mode
  18. * bit 1: HPH Right mode
  19. */
  20. #define AQT_CLSH_STATE_IDLE 0x00
  21. #define AQT_CLSH_STATE_HPHL (0x01 << 0)
  22. #define AQT_CLSH_STATE_HPHR (0x01 << 1)
  23. /*
  24. * Though number of CLSH states are 2, max state shoulbe be 3
  25. * because state array index starts from 1.
  26. */
  27. #define AQT_CLSH_STATE_MAX 3
  28. #define NUM_CLSH_STATES (0x01 << AQT_CLSH_STATE_MAX)
  29. /* Derived State: Bits 1 and 2 should be set for Headphone stereo */
  30. #define AQT_CLSH_STATE_HPH_ST (AQT_CLSH_STATE_HPHL | \
  31. AQT_CLSH_STATE_HPHR)
  32. enum {
  33. CLS_H_NORMAL = 0, /* Class-H Default */
  34. CLS_H_HIFI, /* Class-H HiFi */
  35. CLS_H_LP, /* Class-H Low Power */
  36. CLS_AB, /* Class-AB Low HIFI*/
  37. CLS_H_LOHIFI, /* LoHIFI */
  38. CLS_H_ULP, /* Ultra Low power */
  39. CLS_AB_HIFI, /* Class-AB */
  40. CLS_NONE, /* None of the above modes */
  41. };
  42. enum {
  43. DAC_GAIN_0DB = 0,
  44. DAC_GAIN_0P2DB,
  45. DAC_GAIN_0P4DB,
  46. DAC_GAIN_0P6DB,
  47. DAC_GAIN_0P8DB,
  48. DAC_GAIN_M0P2DB,
  49. DAC_GAIN_M0P4DB,
  50. DAC_GAIN_M0P6DB,
  51. };
  52. enum {
  53. VREF_FILT_R_0OHM = 0,
  54. VREF_FILT_R_25KOHM,
  55. VREF_FILT_R_50KOHM,
  56. VREF_FILT_R_100KOHM,
  57. };
  58. enum {
  59. DELTA_I_0MA,
  60. DELTA_I_10MA,
  61. DELTA_I_20MA,
  62. DELTA_I_30MA,
  63. DELTA_I_40MA,
  64. DELTA_I_50MA,
  65. };
  66. struct aqt_imped_val {
  67. u32 imped_val;
  68. u8 index;
  69. };
  70. struct aqt_clsh_cdc_data {
  71. u8 state;
  72. int flyback_users;
  73. int buck_users;
  74. int clsh_users;
  75. int interpolator_modes[AQT_CLSH_STATE_MAX];
  76. };
  77. struct aqt_reg_mask_val {
  78. u16 reg;
  79. u8 mask;
  80. u8 val;
  81. };
  82. extern void aqt_clsh_fsm(struct snd_soc_component *component,
  83. struct aqt_clsh_cdc_data *cdc_clsh_d,
  84. u8 clsh_event, u8 req_state,
  85. int int_mode);
  86. extern void aqt_clsh_init(struct aqt_clsh_cdc_data *clsh);
  87. extern int aqt_clsh_get_clsh_state(struct aqt_clsh_cdc_data *clsh);
  88. extern void aqt_clsh_imped_config(struct snd_soc_component *component,
  89. int imped, bool reset);
  90. #endif /* _AQT1000_CLSH_H */