linux/sound/soc/codecs/rt700.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0 */
   2/*
   3 * rt700.h -- RT700 ALSA SoC audio driver header
   4 *
   5 * Copyright(c) 2019 Realtek Semiconductor Corp.
   6 */
   7
   8#ifndef __RT700_H__
   9#define __RT700_H__
  10
  11extern const struct dev_pm_ops rt700_runtime_pm;
  12
  13struct  rt700_priv {
  14        struct snd_soc_component *component;
  15        struct regmap *regmap;
  16        struct regmap *sdw_regmap;
  17        struct sdw_slave *slave;
  18        enum sdw_slave_status status;
  19        struct sdw_bus_params params;
  20        bool hw_init;
  21        bool first_hw_init;
  22        struct snd_soc_jack *hs_jack;
  23        struct delayed_work jack_detect_work;
  24        struct delayed_work jack_btn_check_work;
  25        int jack_type;
  26};
  27
  28struct sdw_stream_data {
  29        struct sdw_stream_runtime *sdw_stream;
  30};
  31
  32/* NID */
  33#define RT700_AUDIO_FUNCTION_GROUP                      0x01
  34#define RT700_DAC_OUT1                                  0x02
  35#define RT700_DAC_OUT2                                  0x03
  36#define RT700_ADC_IN1                                   0x09
  37#define RT700_ADC_IN2                                   0x08
  38#define RT700_DMIC1                                     0x12
  39#define RT700_DMIC2                                     0x13
  40#define RT700_SPK_OUT                                   0x14
  41#define RT700_MIC2                                      0x19
  42#define RT700_LINE1                                     0x1a
  43#define RT700_LINE2                                     0x1b
  44#define RT700_BEEP                                      0x1d
  45#define RT700_SPDIF                                     0x1e
  46#define RT700_VENDOR_REGISTERS                          0x20
  47#define RT700_HP_OUT                                    0x21
  48#define RT700_MIXER_IN1                                 0x22
  49#define RT700_MIXER_IN2                                 0x23
  50#define RT700_INLINE_CMD                                0x55
  51
  52/* Index (NID:20h) */
  53#define RT700_DAC_DC_CALI_CTL1                          0x00
  54#define RT700_PARA_VERB_CTL                             0x1a
  55#define RT700_COMBO_JACK_AUTO_CTL1                              0x45
  56#define RT700_COMBO_JACK_AUTO_CTL2                              0x46
  57#define RT700_INLINE_CMD_CTL                            0x48
  58#define RT700_DIGITAL_MISC_CTRL4                        0x4a
  59#define RT700_VREFOUT_CTL                               0x6b
  60#define RT700_FSM_CTL                           0x6f
  61#define RT700_IRQ_FLAG_TABLE1                           0x80
  62#define RT700_IRQ_FLAG_TABLE2                           0x81
  63#define RT700_IRQ_FLAG_TABLE3                           0x82
  64
  65/* Verb */
  66#define RT700_VERB_SET_CONNECT_SEL                      0x3100
  67#define RT700_VERB_SET_EAPD_BTLENABLE                   0x3c00
  68#define RT700_VERB_GET_CONNECT_SEL                      0xb100
  69#define RT700_VERB_SET_POWER_STATE                      0x3500
  70#define RT700_VERB_SET_CHANNEL_STREAMID                 0x3600
  71#define RT700_VERB_SET_PIN_WIDGET_CONTROL               0x3700
  72#define RT700_VERB_SET_UNSOLICITED_ENABLE               0x3800
  73#define RT700_SET_AMP_GAIN_MUTE_H                       0x7300
  74#define RT700_SET_AMP_GAIN_MUTE_L                       0x8380
  75#define RT700_VERB_GET_PIN_SENSE                        0xb900
  76
  77#define RT700_READ_HDA_3                                0x2012
  78#define RT700_READ_HDA_2                                0x2013
  79#define RT700_READ_HDA_1                                0x2014
  80#define RT700_READ_HDA_0                                0x2015
  81#define RT700_PRIV_INDEX_W_H                            0x7520
  82#define RT700_PRIV_INDEX_W_L                            0x85a0
  83#define RT700_PRIV_DATA_W_H                             0x7420
  84#define RT700_PRIV_DATA_W_L                             0x84a0
  85#define RT700_PRIV_INDEX_R_H                            0x9d20
  86#define RT700_PRIV_INDEX_R_L                            0xada0
  87#define RT700_PRIV_DATA_R_H                             0x9c20
  88#define RT700_PRIV_DATA_R_L                             0xaca0
  89#define RT700_DAC_FORMAT_H                              0x7203
  90#define RT700_DAC_FORMAT_L                              0x8283
  91#define RT700_ADC_FORMAT_H                              0x7209
  92#define RT700_ADC_FORMAT_L                              0x8289
  93#define RT700_SET_AUDIO_POWER_STATE\
  94        (RT700_VERB_SET_POWER_STATE | RT700_AUDIO_FUNCTION_GROUP)
  95#define RT700_SET_PIN_DMIC1\
  96        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_DMIC1)
  97#define RT700_SET_PIN_DMIC2\
  98        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_DMIC2)
  99#define RT700_SET_PIN_SPK\
 100        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_SPK_OUT)
 101#define RT700_SET_PIN_HP\
 102        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_HP_OUT)
 103#define RT700_SET_PIN_MIC2\
 104        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_MIC2)
 105#define RT700_SET_PIN_LINE1\
 106        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_LINE1)
 107#define RT700_SET_PIN_LINE2\
 108        (RT700_VERB_SET_PIN_WIDGET_CONTROL | RT700_LINE2)
 109#define RT700_SET_MIC2_UNSOLICITED_ENABLE\
 110        (RT700_VERB_SET_UNSOLICITED_ENABLE | RT700_MIC2)
 111#define RT700_SET_HP_UNSOLICITED_ENABLE\
 112        (RT700_VERB_SET_UNSOLICITED_ENABLE | RT700_HP_OUT)
 113#define RT700_SET_INLINE_UNSOLICITED_ENABLE\
 114        (RT700_VERB_SET_UNSOLICITED_ENABLE | RT700_INLINE_CMD)
 115#define RT700_SET_STREAMID_DAC1\
 116        (RT700_VERB_SET_CHANNEL_STREAMID | RT700_DAC_OUT1)
 117#define RT700_SET_STREAMID_DAC2\
 118        (RT700_VERB_SET_CHANNEL_STREAMID | RT700_DAC_OUT2)
 119#define RT700_SET_STREAMID_ADC1\
 120        (RT700_VERB_SET_CHANNEL_STREAMID | RT700_ADC_IN1)
 121#define RT700_SET_STREAMID_ADC2\
 122        (RT700_VERB_SET_CHANNEL_STREAMID | RT700_ADC_IN2)
 123#define RT700_SET_GAIN_DAC1_L\
 124        (RT700_SET_AMP_GAIN_MUTE_L | RT700_DAC_OUT1)
 125#define RT700_SET_GAIN_DAC1_H\
 126        (RT700_SET_AMP_GAIN_MUTE_H | RT700_DAC_OUT1)
 127#define RT700_SET_GAIN_ADC1_L\
 128        (RT700_SET_AMP_GAIN_MUTE_L | RT700_ADC_IN1)
 129#define RT700_SET_GAIN_ADC1_H\
 130        (RT700_SET_AMP_GAIN_MUTE_H | RT700_ADC_IN1)
 131#define RT700_SET_GAIN_ADC2_L\
 132        (RT700_SET_AMP_GAIN_MUTE_L | RT700_ADC_IN2)
 133#define RT700_SET_GAIN_ADC2_H\
 134        (RT700_SET_AMP_GAIN_MUTE_H | RT700_ADC_IN2)
 135#define RT700_SET_GAIN_AMIC_L\
 136        (RT700_SET_AMP_GAIN_MUTE_L | RT700_MIC2)
 137#define RT700_SET_GAIN_AMIC_H\
 138        (RT700_SET_AMP_GAIN_MUTE_H | RT700_MIC2)
 139#define RT700_SET_GAIN_HP_L\
 140        (RT700_SET_AMP_GAIN_MUTE_L | RT700_HP_OUT)
 141#define RT700_SET_GAIN_HP_H\
 142        (RT700_SET_AMP_GAIN_MUTE_H | RT700_HP_OUT)
 143#define RT700_SET_GAIN_SPK_L\
 144        (RT700_SET_AMP_GAIN_MUTE_L | RT700_SPK_OUT)
 145#define RT700_SET_GAIN_SPK_H\
 146        (RT700_SET_AMP_GAIN_MUTE_H | RT700_SPK_OUT)
 147#define RT700_SET_EAPD_SPK\
 148        (RT700_VERB_SET_EAPD_BTLENABLE | RT700_SPK_OUT)
 149
 150/* combo jack auto switch control 2 (0x46)(NID:20h) */
 151#define RT700_COMBOJACK_AUTO_DET_STATUS                 (0x1 << 11)
 152#define RT700_COMBOJACK_AUTO_DET_TRS                    (0x1 << 10)
 153#define RT700_COMBOJACK_AUTO_DET_CTIA                   (0x1 << 9)
 154#define RT700_COMBOJACK_AUTO_DET_OMTP                   (0x1 << 8)
 155
 156#define RT700_EAPD_HIGH                                 0x2
 157#define RT700_EAPD_LOW                                  0x0
 158#define RT700_MUTE_SFT                                  7
 159#define RT700_DIR_IN_SFT                                6
 160#define RT700_DIR_OUT_SFT                               7
 161
 162enum {
 163        RT700_AIF1,
 164        RT700_AIF2,
 165        RT700_AIFS,
 166};
 167
 168int rt700_io_init(struct device *dev, struct sdw_slave *slave);
 169int rt700_init(struct device *dev, struct regmap *sdw_regmap,
 170               struct regmap *regmap, struct sdw_slave *slave);
 171
 172int rt700_jack_detect(struct rt700_priv *rt700, bool *hp, bool *mic);
 173int rt700_clock_config(struct device *dev);
 174#endif /* __RT700_H__ */
 175