Contributors: 1
Author Tokens Token Proportion Commits Commit Proportion
Binbin Zhou 482 100.00% 4 100.00%
Total 482 4


/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright Openedhand Ltd.
 *
 * Author: Richard Purdie <richard@openedhand.com>
 *         Binbin Zhou <zhoubinbin@loongson.cn>
 *
 */

#ifndef _ES8323_H
#define _ES8323_H

/* ES8323 register space */

/* Chip Control and Power Management */
#define ES8323_CONTROL1		0x00
#define ES8323_CONTROL2		0x01
#define ES8323_CHIPPOWER	0x02

#define ES8323_CHIPPOWER_DACVREF_OFF	0
#define ES8323_CHIPPOWER_ADCVREF_OFF	1
#define ES8323_CHIPPOWER_DACDLL_OFF	2
#define ES8323_CHIPPOWER_ADCDLL_OFF	3
#define ES8323_CHIPPOWER_DACSTM_RESET	4
#define ES8323_CHIPPOWER_ADCSTM_RESET	5
#define ES8323_CHIPPOWER_DACDIG_OFF	6
#define ES8323_CHIPPOWER_ADCDIG_OFF	7

#define ES8323_ADCPOWER		0x03

#define ES8323_ADCPOWER_INT1LP		BIT(0)
#define ES8323_ADCPOWER_FLASHLP		BIT(1)
#define ES8323_ADCPOWER_PDNADCBIS	BIT(2)
#define ES8323_ADCPOWER_PDNMICB		BIT(3)

#define ES8323_ADCPOWER_PDNADCBIS_OFF	2
#define ES8323_ADCPOWER_PDNMICB_OFF	3
#define ES8323_ADCPOWER_PDNADCR_OFF	4
#define ES8323_ADCPOWER_PDNADCL_OFF	5
#define ES8323_ADCPOWER_PDNAINR_OFF	6
#define ES8323_ADCPOWER_PDNAINL_OFF	7

#define ES8323_DACPOWER		0x04

#define ES8323_DACPOWER_ROUT2_OFF	2
#define ES8323_DACPOWER_LOUT2_OFF	3
#define ES8323_DACPOWER_ROUT1_OFF	4
#define ES8323_DACPOWER_LOUT1_OFF	5
#define ES8323_DACPOWER_PDNDACR_OFF	6
#define ES8323_DACPOWER_PDNDACL_OFF	7

#define ES8323_CHIPLOPOW1	0x05
#define ES8323_CHIPLOPOW2	0x06
#define ES8323_ANAVOLMANAG	0x07
#define ES8323_MASTERMODE	0x08

#define ES8323_MASTERMODE_BCLKDIV	GENMASK(4, 0)
#define ES8323_MASTERMODE_BCLKINV	BIT(5)
#define ES8323_MASTERMODE_MCLKDIV2	BIT(6)
#define ES8323_MASTERMODE_MSC		BIT(7)

/* ADC Control */
#define ES8323_ADCCONTROL1	0x09

#define ES8323_ADCCONTROL1_MICAMPR_OFF	0
#define ES8323_ADCCONTROL1_MICAMPL_OFF	4

#define ES8323_ADCCONTROL2	0x0a
#define ES8323_ADCCONTROL3	0x0b
#define ES8323_ADCCONTROL4	0x0c

#define ES8323_ADCCONTROL4_ADCFORMAT	GENMASK(1, 0)
#define ES8323_FMT_I2S			0x0
#define ES8323_FMT_LEFT_J		0x1
#define ES8323_FMT_RIGHT_J		0x2
#define ES8323_FMT_DSP			0x3
#define ES8323_ADCCONTROL4_ADCWL	GENMASK(4, 2)
#define ES8323_S24_LE			0x0
#define ES8323_S20_LE			0x1
#define ES8323_S18_LE			0x2
#define ES8323_S16_LE			0x3
#define ES8323_S32_LE			0x4
#define ES8323_ADCCONTROL4_ADCLRP	BIT(5)
#define ES8323_ADCCONTROL4_DATSEL	GENMASK(7, 6)

#define ES8323_ADCCONTROL5	0x0d

#define ES8323_ADCCONTROL5_ADCFSRATIO	GENMASK(4, 0)
#define ES8323_ADCCONTROL5_ADCFSMODE	BIT(5)
#define ES8323_ADCCONTROL5_ADCFS_MASK	(ES8323_ADCCONTROL5_ADCFSRATIO |\
					 ES8323_ADCCONTROL5_ADCFSMODE)

#define ES8323_ADCCONTROL6	0x0e
#define ES8323_ADCCONTROL7	0x0f

#define ES8323_ADCCONTROL7_ADCMUTE_OFF	2

#define ES8323_LADC_VOL		0x10
#define ES8323_RADC_VOL		0x11
#define ES8323_ADCCONTROL10	0x12
#define ES8323_ADCCONTROL11	0x13
#define ES8323_ADCCONTROL12	0x14

#define ES8323_ADCCONTROL12_ALCATK_OFF	0
#define ES8323_ADCCONTROL12_ALCDCY_OFF	4

#define ES8323_ADCCONTROL13	0x15

#define ES8323_ADCCONTROL13_TIMEOUT_OFF	5
#define ES8323_ADCCONTROL13_ALCZC_OFF	6

#define ES8323_ADCCONTROL14	0x16

#define ES8323_ADCCONTROL14_NGAT_OFF	0
#define ES8323_ADCCONTROL14_NGG_OFF	1
#define ES8323_ADCCONTROL14_NGTH_OFF	3

/* DAC Control */
#define ES8323_DACCONTROL1	0x17

#define ES8323_DACCONTROL1_DACFORMAT	GENMASK(1, 0)
#define ES8323_DACCONTROL1_DACWL	GENMASK(5, 3)
#define ES8323_DACCONTROL1_DACLRP	BIT(6)
#define ES8323_DACCONTROL1_DACLRSWAP	BIT(7)

#define ES8323_DACCONTROL2	0x18

#define ES8323_DACCONTROL2_DACFSRATIO	GENMASK(4, 0)
#define ES8323_DACCONTROL2_DACFSMODE	BIT(5)
#define ES8323_DACCONTROL2_DACFS_MASK	(ES8323_DACCONTROL2_DACFSRATIO |\
					 ES8323_DACCONTROL2_DACFSMODE)

#define ES8323_DACCONTROL3	0x19

#define ES8323_DACCONTROL3_DACMUTE	BIT(2)

#define ES8323_LDAC_VOL		0x1a
#define ES8323_RDAC_VOL		0x1b
#define ES8323_DACCONTROL6	0x1c
#define ES8323_DACCONTROL7	0x1d
#define ES8323_DACCONTROL8	0x1e
#define ES8323_DACCONTROL9	0x1f
#define ES8323_DACCONTROL10	0x20
#define ES8323_DACCONTROL11	0x21
#define ES8323_DACCONTROL12	0x22
#define ES8323_DACCONTROL13	0x23
#define ES8323_DACCONTROL14	0x24
#define ES8323_DACCONTROL15	0x25
#define ES8323_DACCONTROL16	0x26
#define ES8323_DACCONTROL17	0x27

#define ES8323_DACCONTROL17_LI2LOVOL_OFF	3

#define ES8323_DACCONTROL18	0x28
#define ES8323_DACCONTROL19	0x29
#define ES8323_DACCONTROL20	0x2a

#define ES8323_DACCONTROL20_RI2ROVOL_OFF	3

#define ES8323_DACCONTROL21	0x2b
#define ES8323_DACCONTROL22	0x2c
#define ES8323_DACCONTROL23	0x2d
#define ES8323_LOUT1_VOL	0x2e
#define ES8323_ROUT1_VOL	0x2f
#define ES8323_LOUT2_VOL	0x30
#define ES8323_ROUT2_VOL	0x31
#define ES8323_DACCONTROL28	0x32
#define ES8323_DACCONTROL29	0x33
#define ES8323_DACCONTROL30	0x34

#endif