288 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			288 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0-only */
 | |
| /*
 | |
|  * ALSA SoC Audio driver for CS4234 codec
 | |
|  *
 | |
|  * Copyright (C) 2020 Cirrus Logic, Inc. and
 | |
|  *                    Cirrus Logic International Semiconductor Ltd.
 | |
|  */
 | |
| 
 | |
| #ifndef CS4234_H
 | |
| #define CS4234_H
 | |
| 
 | |
| #define CS4234_DEVID_AB			0x01
 | |
| #define CS4234_DEVID_CD			0x02
 | |
| #define CS4234_DEVID_EF			0x03
 | |
| #define CS4234_REVID			0x05
 | |
| 
 | |
| #define CS4234_CLOCK_SP			0x06
 | |
| #define CS4234_BASE_RATE_MASK		0xC0
 | |
| #define CS4234_BASE_RATE_SHIFT		6
 | |
| #define CS4234_SPEED_MODE_MASK		0x30
 | |
| #define CS4234_SPEED_MODE_SHIFT		4
 | |
| #define CS4234_MCLK_RATE_MASK		0x0E
 | |
| #define CS4234_MCLK_RATE_SHIFT		1
 | |
| 
 | |
| #define CS4234_SAMPLE_WIDTH		0x07
 | |
| #define CS4234_SDOUTX_SW_MASK		0xC0
 | |
| #define CS4234_SDOUTX_SW_SHIFT		6
 | |
| #define CS4234_INPUT_SW_MASK		0x30
 | |
| #define CS4234_INPUT_SW_SHIFT		4
 | |
| #define CS4234_LOW_LAT_SW_MASK		0x0C
 | |
| #define CS4234_LOW_LAT_SW_SHIFT		2
 | |
| #define CS4234_DAC5_SW_MASK		0x03
 | |
| #define CS4234_DAC5_SW_SHIFT		0
 | |
| 
 | |
| #define CS4234_SP_CTRL			0x08
 | |
| #define CS4234_INVT_SCLK_MASK		0x80
 | |
| #define CS4234_INVT_SCLK_SHIFT		7
 | |
| #define CS4234_DAC5_SRC_MASK		0x70
 | |
| #define CS4234_DAC5_SRC_SHIFT		4
 | |
| #define CS4234_SP_FORMAT_MASK		0x0C
 | |
| #define CS4234_SP_FORMAT_SHIFT		2
 | |
| #define CS4234_SDO_CHAIN_MASK		0x02
 | |
| #define CS4234_SDO_CHAIN_SHIFT		1
 | |
| #define CS4234_MST_SLV_MASK		0x01
 | |
| #define CS4234_MST_SLV_SHIFT		0
 | |
| 
 | |
| #define CS4234_SP_DATA_SEL		0x09
 | |
| #define CS4234_DAC14_SRC_MASK		0x38
 | |
| #define CS4234_DAC14_SRC_SHIFT		3
 | |
| #define CS4234_LL_SRC_MASK		0x07
 | |
| #define CS4234_LL_SRC_SHIFT		0
 | |
| 
 | |
| #define CS4234_SDIN1_MASK1		0x0A
 | |
| #define CS4234_SDIN1_MASK2		0x0B
 | |
| #define CS4234_SDIN2_MASK1		0x0C
 | |
| #define CS4234_SDIN2_MASK2		0x0D
 | |
| 
 | |
| #define CS4234_TPS_CTRL			0x0E
 | |
| #define CS4234_TPS_MODE_MASK		0x80
 | |
| #define CS4234_TPS_MODE_SHIFT		7
 | |
| #define CS4234_TPS_OFST_MASK		0x70
 | |
| #define CS4234_TPS_OFST_SHIFT		4
 | |
| #define CS4234_GRP_DELAY_MASK		0x0F
 | |
| #define CS4234_GRP_DELAY_SHIFT		0
 | |
| 
 | |
| #define CS4234_ADC_CTRL1		0x0F
 | |
| #define CS4234_VA_SEL_MASK		0x20
 | |
| #define CS4234_VA_SEL_SHIFT		5
 | |
| #define CS4234_ENA_HPF_MASK		0x10
 | |
| #define CS4234_ENA_HPF_SHIFT		4
 | |
| #define CS4234_INV_ADC_MASK		0x0F
 | |
| #define CS4234_INV_ADC4_MASK		0x08
 | |
| #define CS4234_INV_ADC4_SHIFT		3
 | |
| #define CS4234_INV_ADC3_MASK		0x04
 | |
| #define CS4234_INV_ADC3_SHIFT		2
 | |
| #define CS4234_INV_ADC2_MASK		0x02
 | |
| #define CS4234_INV_ADC2_SHIFT		1
 | |
| #define CS4234_INV_ADC1_MASK		0x01
 | |
| #define CS4234_INV_ADC1_SHIFT		0
 | |
| 
 | |
| #define CS4234_ADC_CTRL2		0x10
 | |
| #define CS4234_MUTE_ADC4_MASK		0x80
 | |
| #define CS4234_MUTE_ADC4_SHIFT		7
 | |
| #define CS4234_MUTE_ADC3_MASK		0x40
 | |
| #define CS4234_MUTE_ADC3_SHIFT		6
 | |
| #define CS4234_MUTE_ADC2_MASK		0x20
 | |
| #define CS4234_MUTE_ADC2_SHIFT		5
 | |
| #define CS4234_MUTE_ADC1_MASK		0x10
 | |
| #define CS4234_MUTE_ADC1_SHIFT		4
 | |
| #define CS4234_PDN_ADC4_MASK		0x08
 | |
| #define CS4234_PDN_ADC4_SHIFT		3
 | |
| #define CS4234_PDN_ADC3_MASK		0x04
 | |
| #define CS4234_PDN_ADC3_SHIFT		2
 | |
| #define CS4234_PDN_ADC2_MASK		0x02
 | |
| #define CS4234_PDN_ADC2_SHIFT		1
 | |
| #define CS4234_PDN_ADC1_MASK		0x01
 | |
| #define CS4234_PDN_ADC1_SHIFT		0
 | |
| 
 | |
| #define CS4234_LOW_LAT_CTRL1		0x11
 | |
| #define CS4234_LL_NG_MASK		0xE0
 | |
| #define CS4234_LL_NG_SHIFT		5
 | |
| #define CS4234_INV_LL_MASK		0x0F
 | |
| #define CS4234_INV_LL4_MASK		0x08
 | |
| #define CS4234_INV_LL4_SHIFT		3
 | |
| #define CS4234_INV_LL3_MASK		0x04
 | |
| #define CS4234_INV_LL3_SHIFT		2
 | |
| #define CS4234_INV_LL2_MASK		0x02
 | |
| #define CS4234_INV_LL2_SHIFT		1
 | |
| #define CS4234_INV_LL1_MASK		0x01
 | |
| #define CS4234_INV_LL1_SHIFT		0
 | |
| 
 | |
| #define CS4234_DAC_CTRL1		0x12
 | |
| #define CS4234_DAC14_NG_MASK		0xE0
 | |
| #define CS4234_DAC14_NG_SHIFT		5
 | |
| #define CS4234_DAC14_DE_MASK		0x10
 | |
| #define CS4234_DAC14_DE_SHIFT		4
 | |
| #define CS4234_DAC5_DE_MASK		0x08
 | |
| #define CS4234_DAC5_DE_SHIFT		3
 | |
| #define CS4234_DAC5_MVC_MASK		0x04
 | |
| #define CS4234_DAC5_MVC_SHIFT		2
 | |
| #define CS4234_DAC5_CFG_FLTR_MASK	0x03
 | |
| #define CS4234_DAC5_CFG_FLTR_SHIFT	0
 | |
| 
 | |
| #define CS4234_DAC_CTRL2		0x13
 | |
| #define CS4234_DAC5_NG_MASK		0xE0
 | |
| #define CS4234_DAC5_NG_SHIFT		5
 | |
| #define CS4234_INV_DAC_MASK		0x1F
 | |
| #define CS4234_INV_DAC5_MASK		0x10
 | |
| #define CS4234_INV_DAC5_SHIFT		4
 | |
| #define CS4234_INV_DAC4_MASK		0x08
 | |
| #define CS4234_INV_DAC4_SHIFT		3
 | |
| #define CS4234_INV_DAC3_MASK		0x04
 | |
| #define CS4234_INV_DAC3_SHIFT		2
 | |
| #define CS4234_INV_DAC2_MASK		0x02
 | |
| #define CS4234_INV_DAC2_SHIFT		1
 | |
| #define CS4234_INV_DAC1_MASK		0x01
 | |
| #define CS4234_INV_DAC1_SHIFT		0
 | |
| 
 | |
| #define CS4234_DAC_CTRL3		0x14
 | |
| #define CS4234_DAC5_ATT_MASK		0x80
 | |
| #define CS4234_DAC5_ATT_SHIFT		7
 | |
| #define CS4234_DAC14_ATT_MASK		0x40
 | |
| #define CS4234_DAC14_ATT_SHIFT		6
 | |
| #define CS4234_MUTE_LL_MASK		0x20
 | |
| #define CS4234_MUTE_LL_SHIFT		5
 | |
| #define CS4234_MUTE_DAC5_MASK		0x10
 | |
| #define CS4234_MUTE_DAC5_SHIFT		4
 | |
| #define CS4234_MUTE_DAC4_MASK		0x08
 | |
| #define CS4234_MUTE_DAC4_SHIFT		3
 | |
| #define CS4234_MUTE_DAC3_MASK		0x04
 | |
| #define CS4234_MUTE_DAC3_SHIFT		2
 | |
| #define CS4234_MUTE_DAC2_MASK		0x02
 | |
| #define CS4234_MUTE_DAC2_SHIFT		1
 | |
| #define CS4234_MUTE_DAC1_MASK		0x01
 | |
| #define CS4234_MUTE_DAC1_SHIFT		0
 | |
| 
 | |
| #define CS4234_DAC_CTRL4		0x15
 | |
| #define CS4234_VQ_RAMP_MASK		0x80
 | |
| #define CS4234_VQ_RAMP_SHIFT		7
 | |
| #define CS4234_TPS_GAIN_MASK		0x40
 | |
| #define CS4234_TPS_GAIN_SHIFT		6
 | |
| #define CS4234_PDN_DAC5_MASK		0x10
 | |
| #define CS4234_PDN_DAC5_SHIFT		4
 | |
| #define CS4234_PDN_DAC4_MASK		0x08
 | |
| #define CS4234_PDN_DAC4_SHIFT		3
 | |
| #define CS4234_PDN_DAC3_MASK		0x04
 | |
| #define CS4234_PDN_DAC3_SHIFT		2
 | |
| #define CS4234_PDN_DAC2_MASK		0x02
 | |
| #define CS4234_PDN_DAC2_SHIFT		1
 | |
| #define CS4234_PDN_DAC1_MASK		0x01
 | |
| #define CS4234_PDN_DAC1_SHIFT		0
 | |
| 
 | |
| #define CS4234_VOLUME_MODE		0x16
 | |
| #define CS4234_MUTE_DELAY_MASK		0xC0
 | |
| #define CS4234_MUTE_DELAY_SHIFT		6
 | |
| #define CS4234_MIN_DELAY_MASK		0x38
 | |
| #define CS4234_MIN_DELAY_SHIFT		3
 | |
| #define CS4234_MAX_DELAY_MASK		0x07
 | |
| #define CS4234_MAX_DELAY_SHIFT		0
 | |
| 
 | |
| #define CS4234_MASTER_VOL		0x17
 | |
| #define CS4234_DAC1_VOL			0x18
 | |
| #define CS4234_DAC2_VOL			0x19
 | |
| #define CS4234_DAC3_VOL			0x1A
 | |
| #define CS4234_DAC4_VOL			0x1B
 | |
| #define CS4234_DAC5_VOL			0x1C
 | |
| 
 | |
| #define CS4234_INT_CTRL			0x1E
 | |
| #define CS4234_INT_MODE_MASK		0x80
 | |
| #define CS4234_INT_MODE_SHIFT		7
 | |
| #define CS4234_INT_PIN_MASK		0x60
 | |
| #define CS4234_INT_PIN_SHIFT		5
 | |
| 
 | |
| #define CS4234_INT_MASK1		0x1F
 | |
| #define CS4234_MSK_TST_MODE_MASK	0x80
 | |
| #define CS4234_MSK_TST_MODE_ERR_SHIFT	7
 | |
| #define CS4234_MSK_SP_ERR_MASK		0x40
 | |
| #define CS4234_MSK_SP_ERR_SHIFT		6
 | |
| #define CS4234_MSK_CLK_ERR_MASK		0x08
 | |
| #define CS4234_MSK_CLK_ERR_SHIFT	5
 | |
| #define CS4234_MSK_ADC4_OVFL_MASK	0x08
 | |
| #define CS4234_MSK_ADC4_OVFL_SHIFT	3
 | |
| #define CS4234_MSK_ADC3_OVFL_MASK	0x04
 | |
| #define CS4234_MSK_ADC3_OVFL_SHIFT	2
 | |
| #define CS4234_MSK_ADC2_OVFL_MASK	0x02
 | |
| #define CS4234_MSK_ADC2_OVFL_SHIFT	1
 | |
| #define CS4234_MSK_ADC1_OVFL_MASK	0x01
 | |
| #define CS4234_MSK_ADC1_OVFL_SHIFT	0
 | |
| 
 | |
| #define CS4234_INT_MASK2		0x20
 | |
| #define CS4234_MSK_DAC5_CLIP_MASK	0x10
 | |
| #define CS4234_MSK_DAC5_CLIP_SHIFT	4
 | |
| #define CS4234_MSK_DAC4_CLIP_MASK	0x08
 | |
| #define CS4234_MSK_DAC4_CLIP_SHIFT	3
 | |
| #define CS4234_MSK_DAC3_CLIP_MASK	0x04
 | |
| #define CS4234_MSK_DAC3_CLIP_SHIFT	2
 | |
| #define CS4234_MSK_DAC2_CLIP_MASK	0x02
 | |
| #define CS4234_MSK_DAC2_CLIP_SHIFT	1
 | |
| #define CS4234_MSK_DAC1_CLIP_MASK	0x01
 | |
| #define CS4234_MSK_DAC1_CLIP_SHIFT	0
 | |
| 
 | |
| #define CS4234_INT_NOTIFY1		0x21
 | |
| #define CS4234_TST_MODE_MASK		0x80
 | |
| #define CS4234_TST_MODE_SHIFT		7
 | |
| #define CS4234_SP_ERR_MASK		0x40
 | |
| #define CS4234_SP_ERR_SHIFT		6
 | |
| #define CS4234_CLK_MOD_ERR_MASK		0x08
 | |
| #define CS4234_CLK_MOD_ERR_SHIFT	5
 | |
| #define CS4234_ADC4_OVFL_MASK		0x08
 | |
| #define CS4234_ADC4_OVFL_SHIFT		3
 | |
| #define CS4234_ADC3_OVFL_MASK		0x04
 | |
| #define CS4234_ADC3_OVFL_SHIFT		2
 | |
| #define CS4234_ADC2_OVFL_MASK		0x02
 | |
| #define CS4234_ADC2_OVFL_SHIFT		1
 | |
| #define CS4234_ADC1_OVFL_MASK		0x01
 | |
| #define CS4234_ADC1_OVFL_SHIFT		0
 | |
| 
 | |
| #define CS4234_INT_NOTIFY2		0x22
 | |
| #define CS4234_DAC5_CLIP_MASK		0x10
 | |
| #define CS4234_DAC5_CLIP_SHIFT		4
 | |
| #define CS4234_DAC4_CLIP_MASK		0x08
 | |
| #define CS4234_DAC4_CLIP_SHIFT		3
 | |
| #define CS4234_DAC3_CLIP_MASK		0x04
 | |
| #define CS4234_DAC3_CLIP_SHIFT		2
 | |
| #define CS4234_DAC2_CLIP_MASK		0x02
 | |
| #define CS4234_DAC2_CLIP_SHIFT		1
 | |
| #define CS4234_DAC1_CLIP_MASK		0x01
 | |
| #define CS4234_DAC1_CLIP_SHIFT		0
 | |
| 
 | |
| #define CS4234_MAX_REGISTER		CS4234_INT_NOTIFY2
 | |
| 
 | |
| #define CS4234_SUPPORTED_ID		0x423400
 | |
| #define CS4234_BOOT_TIME_US		3000
 | |
| #define CS4234_HOLD_RESET_TIME_US	1000
 | |
| #define CS4234_VQ_CHARGE_MS		1000
 | |
| 
 | |
| #define CS4234_PCM_RATES	(SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_44100 | \
 | |
| 				 SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_64000 | \
 | |
| 				 SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000)
 | |
| 
 | |
| #define CS4234_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S18_3LE | \
 | |
| 			SNDRV_PCM_FMTBIT_S20_LE | SNDRV_PCM_FMTBIT_S24_LE | \
 | |
| 			SNDRV_PCM_FMTBIT_S24_3LE)
 | |
| 
 | |
| enum cs4234_supplies {
 | |
| 	CS4234_SUPPLY_VA = 0,
 | |
| 	CS4234_SUPPLY_VL,
 | |
| };
 | |
| 
 | |
| enum cs4234_va_sel {
 | |
| 	CS4234_3V3 = 0,
 | |
| 	CS4234_5V,
 | |
| };
 | |
| 
 | |
| enum cs4234_sp_format {
 | |
| 	CS4234_LEFT_J = 0,
 | |
| 	CS4234_I2S,
 | |
| 	CS4234_TDM,
 | |
| };
 | |
| 
 | |
| enum cs4234_base_rate_advisory {
 | |
| 	CS4234_48K = 0,
 | |
| 	CS4234_44K1,
 | |
| 	CS4234_32K,
 | |
| };
 | |
| 
 | |
| #endif
 |