^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0-only */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * Platform data for Texas Instruments TLV320AIC3x codec
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) * Author: Jarkko Nikula <jarkko.nikula@bitmer.com>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) #ifndef __TLV320AIC3x_H__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) #define __TLV320AIC3x_H__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) /* GPIO API */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) enum {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) AIC3X_GPIO1_FUNC_DISABLED = 0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) AIC3X_GPIO1_FUNC_AUDIO_WORDCLK_ADC = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) AIC3X_GPIO1_FUNC_CLOCK_MUX = 2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) AIC3X_GPIO1_FUNC_CLOCK_MUX_DIV2 = 3,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) AIC3X_GPIO1_FUNC_CLOCK_MUX_DIV4 = 4,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) AIC3X_GPIO1_FUNC_CLOCK_MUX_DIV8 = 5,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) AIC3X_GPIO1_FUNC_SHORT_CIRCUIT_IRQ = 6,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) AIC3X_GPIO1_FUNC_AGC_NOISE_IRQ = 7,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) AIC3X_GPIO1_FUNC_INPUT = 8,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) AIC3X_GPIO1_FUNC_OUTPUT = 9,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) AIC3X_GPIO1_FUNC_DIGITAL_MIC_MODCLK = 10,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) AIC3X_GPIO1_FUNC_AUDIO_WORDCLK = 11,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) AIC3X_GPIO1_FUNC_BUTTON_IRQ = 12,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) AIC3X_GPIO1_FUNC_HEADSET_DETECT_IRQ = 13,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) AIC3X_GPIO1_FUNC_HEADSET_DETECT_OR_BUTTON_IRQ = 14,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) AIC3X_GPIO1_FUNC_ALL_IRQ = 16
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) enum {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) AIC3X_GPIO2_FUNC_DISABLED = 0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) AIC3X_GPIO2_FUNC_HEADSET_DETECT_IRQ = 2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) AIC3X_GPIO2_FUNC_INPUT = 3,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) AIC3X_GPIO2_FUNC_OUTPUT = 4,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) AIC3X_GPIO2_FUNC_DIGITAL_MIC_INPUT = 5,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) AIC3X_GPIO2_FUNC_AUDIO_BITCLK = 8,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) AIC3X_GPIO2_FUNC_HEADSET_DETECT_OR_BUTTON_IRQ = 9,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) AIC3X_GPIO2_FUNC_ALL_IRQ = 10,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) AIC3X_GPIO2_FUNC_SHORT_CIRCUIT_OR_AGC_IRQ = 11,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) AIC3X_GPIO2_FUNC_HEADSET_OR_BUTTON_PRESS_OR_SHORT_CIRCUIT_IRQ = 12,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) AIC3X_GPIO2_FUNC_SHORT_CIRCUIT_IRQ = 13,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) AIC3X_GPIO2_FUNC_AGC_NOISE_IRQ = 14,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) AIC3X_GPIO2_FUNC_BUTTON_PRESS_IRQ = 15
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) enum aic3x_micbias_voltage {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) AIC3X_MICBIAS_OFF = 0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) AIC3X_MICBIAS_2_0V = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) AIC3X_MICBIAS_2_5V = 2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) AIC3X_MICBIAS_AVDDV = 3,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) struct aic3x_setup_data {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) unsigned int gpio_func[2];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) struct aic3x_pdata {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) int gpio_reset; /* < 0 if not used */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) struct aic3x_setup_data *setup;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) /* Selects the micbias voltage */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) enum aic3x_micbias_voltage micbias_vg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) #endif