Contributors: 2
Author Tokens Token Proportion Commits Commit Proportion
Chris Morgan 309 56.28% 1 50.00%
Weidong Wang 240 43.72% 1 50.00%
Total 549 2


// SPDX-License-Identifier: GPL-2.0-only
//
// aw87390.h  --  aw87390 ALSA SoC Audio driver
//
// Copyright (c) 2023 awinic Technology CO., LTD
//
// Author: Weidong Wang <wangweidong.a@awinic.com>
//

#ifndef __AW87390_H__
#define __AW87390_H__

#define AW87390_ID_REG			(0x00)
#define AW87390_SYSCTRL_REG		(0x01)
#define AW87390_MDCTRL_REG		(0x02)
#define AW87390_CPOVP_REG		(0x03)
#define AW87390_CPP_REG		(0x04)
#define AW87390_PAG_REG		(0x05)
#define AW87390_AGC3P_REG		(0x06)
#define AW87390_AGC3PA_REG		(0x07)
#define AW87390_AGC2P_REG		(0x08)
#define AW87390_AGC2PA_REG		(0x09)
#define AW87390_AGC1PA_REG		(0x0A)
#define AW87390_SYSST_REG		(0x59)
#define AW87390_SYSINT_REG		(0x60)
#define AW87390_DFT_SYSCTRL_REG	(0x61)
#define AW87390_DFT_MDCTRL_REG		(0x62)
#define AW87390_DFT_CPADP_REG		(0x63)
#define AW87390_DFT_AGCPA_REG		(0x64)
#define AW87390_DFT_POFR_REG		(0x65)
#define AW87390_DFT_OC_REG		(0x66)
#define AW87390_DFT_ADP1_REG		(0x67)
#define AW87390_DFT_REF_REG		(0x68)
#define AW87390_DFT_LDO_REG		(0x69)
#define AW87390_ADP1_REG		(0x70)
#define AW87390_ADP2_REG		(0x71)
#define AW87390_NG1_REG		(0x72)
#define AW87390_NG2_REG		(0x73)
#define AW87390_NG3_REG		(0x74)
#define AW87390_CP_REG			(0x75)
#define AW87390_AB_REG			(0x76)
#define AW87390_TEST_REG		(0x77)
#define AW87390_ENCR_REG		(0x78)
#define AW87390_DELAY_REG_ADDR		(0xFE)

#define AW87390_SOFT_RESET_VALUE	(0xAA)
#define AW87390_POWER_DOWN_VALUE	(0x00)
#define AW87390_REG_MAX		(0xFF)
#define AW87390_DEV_DEFAULT_CH		(0)
#define AW87390_INIT_PROFILE		(0)
#define AW87390_REG_DELAY_TIME		(1000)
#define AW87390_I2C_NAME		"aw87390"
#define AW87390_ACF_FILE		"aw87390_acf.bin"

#define AW87391_SYSCTRL_REG		(0x01)
#define AW87391_REG_VER_SEL_LOW		(0 << 6)
#define AW87391_REG_VER_SEL_NORMAL	(1 << 6)
#define AW87391_REG_VER_SEL_SUPER	(2 << 6)
#define AW87391_REG_EN_ADAP		BIT(5)
#define AW87391_REG_EN_2X		BIT(4)
#define AW87391_EN_SPK			BIT(3)
#define AW87391_EN_PA			BIT(2)
#define AW87391_REG_EN_CP		BIT(1)
#define AW87391_EN_SW			BIT(0)

#define AW87391_CP_REG                  (0x02)
#define AW87391_REG_CP_OVP_6_50V	0
#define AW87391_REG_CP_OVP_6_75V	1
#define AW87391_REG_CP_OVP_7_00V	2
#define AW87391_REG_CP_OVP_7_25V	3
#define AW87391_REG_CP_OVP_7_50V	4
#define AW87391_REG_CP_OVP_7_75V	5
#define AW87391_REG_CP_OVP_8_00V	6
#define AW87391_REG_CP_OVP_8_25V	7
#define AW87391_REG_CP_OVP_8_50V	8

#define AW87391_PAG_REG                 (0x03)
#define AW87391_GAIN_12DB		0
#define AW87391_GAIN_15DB		1
#define AW87391_GAIN_18DB		2
#define AW87391_GAIN_21DB		3
#define AW87391_GAIN_24DB		4

#define AW87391_AGCPO_REG               (0x04)
#define AW87391_AK1_S_016		(2 << 5)
#define AW87391_AK1_S_032		(3 << 5)
#define AW87391_PD_AGC1_PWRDN		BIT(4)
/* AGC2PO supports values between 500mW (0000) to 1600mW (1011) */
#define AW87391_AGC2PO_MW(n)		((n / 100) - 5)

#define AW87391_AGC2PA_REG              (0x05)
#define AW87391_RK_S_5_12		(0 << 5)
#define AW87391_RK_S_10_24		(1 << 5)
#define AW87391_RK_S_20_48		(2 << 5)
#define AW87391_RK_S_41			(3 << 5)
#define AW87391_RK_S_82			(4 << 5)
#define AW87391_RK_S_164		(5 << 5)
#define AW87391_RK_S_328		(6 << 5)
#define AW87391_RK_S_656		(7 << 5)
#define AW87391_AK2_S_1_28		(0 << 2)
#define AW87391_AK2_S_2_56		(1 << 2)
#define AW87391_AK2_S_10_24		(2 << 2)
#define AW87391_AK2_S_41		(3 << 2)
#define AW87391_AK2_S_82		(4 << 2)
#define AW87391_AK2_S_164		(5 << 2)
#define AW87391_AK2_S_328		(6 << 2)
#define AW87391_AK2_S_656		(7 << 2)
#define AW87391_AK2F_S_10_24		0
#define AW87391_AK2F_S_20_48		1
#define AW87391_AK2F_S_41		2
#define AW87391_AK2F_S_82		3

#define AW87391_SYSST_REG               (0x06)
#define AW87391_UVLO			BIT(7)
#define AW87391_OTN			BIT(6)
#define AW87391_OC_FLAG			BIT(5)
#define AW87391_ADAP_CP			BIT(4)
#define AW87391_STARTOK			BIT(3)
#define AW87391_CP_OVP			BIT(2)
#define AW87391_PORN			BIT(1)

#define AW87391_SYSINT_REG              (0x07)
#define AW87391_UVLOI			BIT(7)
#define AW87391_ONTI			BIT(6)
#define AW87391_OC_FLAGI		BIT(5)
#define AW87391_ADAP_CPI		BIT(4)
#define AW87391_STARTOKI		BIT(3)
#define AW87391_CP_OVPI			BIT(2)
#define AW87391_PORNI			BIT(1)

#define AW87391_DFT_THGEN0_REG          (0x63)
#define AW87391_ADAPVTH_01W		(0 << 2)
#define AW87391_ADAPVTH_02W		(1 << 2)
#define AW87391_ADAPVTH_03W		(2 << 2)
#define AW87391_ADAPVTH_04W		(3 << 2)

#define AW87391_I2C_NAME                "aw87391"

#define AW87390_PROFILE_EXT(xname, profile_info, profile_get, profile_set) \
{ \
	.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
	.name = xname, \
	.info = profile_info, \
	.get = profile_get, \
	.put = profile_set, \
}

enum aw87390_id {
	AW87390_CHIP_ID = 0x76,
	AW87391_CHIP_ID = 0xc1,
};

enum {
	AW87390_DEV_FW_FAILED = 0,
	AW87390_DEV_FW_OK,
};

enum {
	AW87390_DEV_PW_OFF = 0,
	AW87390_DEV_PW_ON,
};

struct aw87390 {
	struct aw_device *aw_pa;
	struct mutex lock;
	struct regmap *regmap;
	struct aw_container *aw_cfg;
	struct regulator *vdd_reg;
};

#endif