mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

The driver is for codec es8375 of everest Signed-off-by: Zhang Yi <zhangyi@everest-semi.com> Link: https://patch.msgid.link/20250523025502.23214-3-zhangyi@everest-semi.com Signed-off-by: Mark Brown <broonie@kernel.org>
123 lines
3.9 KiB
C
123 lines
3.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* ES8375.h -- ES8375 ALSA SoC Audio Codec
|
|
*
|
|
* Authors:
|
|
*
|
|
* Based on ES8375.h by Michael Zhang
|
|
*/
|
|
#ifndef _ES8375_H
|
|
#define _ES8375_H
|
|
|
|
// Registors
|
|
#define ES8375_RESET1 0x00
|
|
#define ES8375_MCLK_SEL 0x01
|
|
#define ES8375_CLK_MGR2 0x02
|
|
#define ES8375_CLK_MGR3 0x03
|
|
#define ES8375_CLK_MGR4 0x04
|
|
#define ES8375_CLK_MGR5 0x05
|
|
#define ES8375_CLK_MGR6 0x06
|
|
#define ES8375_CLK_MGR7 0x07
|
|
#define ES8375_CLK_MGR8 0x08
|
|
#define ES8375_CLK_MGR9 0x09
|
|
#define ES8375_CLK_MGR10 0x0A
|
|
#define ES8375_CLK_MGR11 0x0B
|
|
#define ES8375_CLK_MGR12 0x0C
|
|
#define ES8375_DIV_SPKCLK 0x0E
|
|
#define ES8375_CSM1 0x0F
|
|
#define ES8375_CSM2 0x10
|
|
#define ES8375_VMID_CHARGE2 0x11
|
|
#define ES8375_VMID_CHARGE3 0x12
|
|
#define ES8375_SDP 0x15
|
|
#define ES8375_SDP2 0x16
|
|
#define ES8375_ADC1 0x17
|
|
#define ES8375_ADC2 0x18
|
|
#define ES8375_ADC_OSR_GAIN 0x19
|
|
#define ES8375_ADC_VOLUME 0x1A
|
|
#define ES8375_ADC_AUTOMUTE 0x1B
|
|
#define ES8375_ADC_AUTOMUTE_ATTN 0x1C
|
|
#define ES8375_HPF1 0x1D
|
|
#define ES8375_DAC1 0x1F
|
|
#define ES8375_DAC2 0x20
|
|
#define ES8375_DAC_VOLUME 0x21
|
|
#define ES8375_DAC_VPPSCALE 0x22
|
|
#define ES8375_DAC_AUTOMUTE1 0x23
|
|
#define ES8375_DAC_AUTOMUTE 0x24
|
|
#define ES8375_DAC_CAL 0x25
|
|
#define ES8375_DAC_OTP 0x27
|
|
#define ES8375_ANALOG_SPK1 0x28
|
|
#define ES8375_ANALOG_SPK2 0x29
|
|
#define ES8375_VMID_SEL 0x2D
|
|
#define ES8375_ANALOG1 0x2E
|
|
#define ES8375_ANALOG2 0x32
|
|
#define ES8375_ANALOG3 0x37
|
|
#define ES8375_ADC2DAC_CLKTRI 0xF8
|
|
#define ES8375_SYS_CTRL2 0xF9
|
|
#define ES8375_FLAGS2 0xFB
|
|
#define ES8375_SPK_OFFSET 0xFC
|
|
#define ES8375_CHIP_ID1 0xFD
|
|
#define ES8375_CHIP_ID0 0xFE
|
|
#define ES8375_CHIP_VERSION 0xFF
|
|
|
|
// Bit Shifts
|
|
#define ADC_OSR_GAIN_SHIFT_0 0
|
|
#define ADC_RAMPRATE_SHIFT_0 0
|
|
#define ADC_VOLUME_SHIFT_0 0
|
|
#define ADC_AUTOMUTE_NG_SHIFT_0 0
|
|
#define ADC_AUTOMUTE_ATTN_SHIFT_0 0
|
|
#define DAC_RAMPRATE_SHIFT_0 0
|
|
#define DAC_VOLUME_SHIFT_0 0
|
|
#define DAC_VPPSCALE_SHIFT_0 0
|
|
#define DAC_AUTOMUTE_NG_SHIFT_0 0
|
|
#define DAC_AUTOMUTE_ATTN_SHIFT_0 0
|
|
#define DMIC_GAIN_SHIFT_2 2
|
|
#define ADC_AUTOMUTE_WS_SHIFT_3 3
|
|
#define DMIC_POL_SHIFT_4 4
|
|
#define DAC_RAMCLR_SHIFT_4 4
|
|
#define ES8375_EN_MODL_SHIFT_4 4
|
|
#define ADC_RAMCLR_SHIFT_5 5
|
|
#define ADC_HPF_SHIFT_5 5
|
|
#define DAC_INV_SHIFT_5 5
|
|
#define DAC_AUTOMUTE_WS_SHIFT_5 5
|
|
#define ES8375_EN_PGAL_SHIFT_5 5
|
|
#define ES8375_ADC_P2S_MUTE_SHIFT_5 5
|
|
#define ADC_INV_SHIFT_6 6
|
|
#define DAC_DEMMUTE_SHIFT_6 6
|
|
#define ES8375_DAC_S2P_MUTE_SHIFT_6 6
|
|
#define ADC_SRC_SHIFT_7 7
|
|
#define ADC_AUTOMUTE_SHIFT_7 7
|
|
#define DAC_DSMMUTE_SHIFT_7 7
|
|
#define DAC_AUTOMUTE_EN_SHIFT_7 7
|
|
|
|
// Function values
|
|
#define ES8375_ADC_OSR_GAIN_MAX 0x3F
|
|
#define ES8375_DMIC_GAIN_MAX 0x04
|
|
#define ES8375_ADC_AUTOMUTE_ATTN_MAX 0x1F
|
|
#define ES8375_AUTOMUTE_NG_MAX 0x07
|
|
#define ES8375_ADC_VOLUME_MAX 0xFF
|
|
#define ES8375_DAC_VOLUME_MAX 0xFF
|
|
#define ES8375_DAC_VPPSCALE_MAX 0x3F
|
|
#define ES8375_DAC_AUTOMUTE_ATTN_MAX 0x17
|
|
#define ES8375_REG_MAX 0xFF
|
|
|
|
enum ES8375_supplies {
|
|
ES8375_SUPPLY_VD = 0,
|
|
ES8375_SUPPLY_VA,
|
|
};
|
|
|
|
// Properties
|
|
#define ES8375_3V3 1
|
|
#define ES8375_1V8 0
|
|
|
|
#define ES8375_MCLK_PIN 0
|
|
#define ES8375_BCLK_PIN 1
|
|
#define ES8375_MCLK_SOURCE ES8375_MCLK_PIN
|
|
|
|
#define DMIC_POSITIVE_EDGE 0
|
|
#define DMIC_NEGATIVE_EDGE 1
|
|
#define DMIC_POL DMIC_POSITIVE_EDGE
|
|
|
|
#define PA_SHUTDOWN 0
|
|
#define PA_ENABLE 1
|
|
|
|
#endif
|