unplugged-kernel/drivers/misc/mediatek/auxadc/mt6739/mtk_auxadc_hw.h

63 lines
1.9 KiB
C
Raw Normal View History

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#ifndef _MTK_ADC_HW_H
#define _MTK_ADC_HW_H
extern void __iomem *auxadc_base;
extern void __iomem *auxadc_apmix_base;
extern void __iomem *auxadc_efuse_base;
#undef AUXADC_BASE
#undef APMIXED_BASE
#undef EFUSEC_BASE
#define AUXADC_BASE auxadc_base
#define APMIXED_BASE auxadc_apmix_base
#define EFUSEC_BASE auxadc_efuse_base
/* For calibration */
#define EFUSE_CALI
#define AUXADC_INDEX 104
#define ADC_GE_A_SHIFT 22
#define ADC_GE_A_MASK (0x3ff << ADC_GE_A_SHIFT)
#define ADC_OE_A_SHIFT 12
#define ADC_OE_A_MASK (0x3ff << ADC_OE_A_SHIFT)
#define ADC_CALI_EN_A_SHIFT 11
#define ADC_CALI_EN_A_MASK (0x1 << ADC_CALI_EN_A_SHIFT)
#define ADC_CALI_EN_A_REG (EFUSEC_BASE + 0x190)
#define ADC_GE_A_REG (EFUSEC_BASE + 0x190)
#define ADC_OE_A_REG (EFUSEC_BASE + 0x190)
/************************/
#define ADC_CHANNEL_MAX 16
#define MT_PDN_PERI_AUXADC MT_CG_PERI_AUXADC
#define AUXADC_NODE "mediatek,auxadc"
#define AUXADC_APMIX_NODE "mediatek,apmixed"
#define AUXADC_CON0 (AUXADC_BASE + 0x000)
#define AUXADC_CON1 (AUXADC_BASE + 0x004)
#define AUXADC_CON2 (AUXADC_BASE + 0x010)
#define AUXADC_DAT0 (AUXADC_BASE + 0x014)
#define AUXADC_TP_CMD (AUXADC_BASE + 0x005c)
#define AUXADC_TP_ADDR (AUXADC_BASE + 0x0060)
#define AUXADC_TP_CON0 (AUXADC_BASE + 0x0064)
#define AUXADC_TP_DATA0 (AUXADC_BASE + 0x0074)
#define AUXADC_DET_VOLT (AUXADC_BASE + 0x084)
#define AUXADC_DET_SEL (AUXADC_BASE + 0x088)
#define AUXADC_DET_PERIOD (AUXADC_BASE + 0x08C)
#define AUXADC_DET_DEBT (AUXADC_BASE + 0x090)
#define PAD_AUX_XP 13
#define PAD_AUX_YM 15
#define TP_CMD_ADDR_X 0x0005
#define AUXADC_CON_RTP (APMIXED_BASE + 0x0404)
#define AUXADC_CLOCK_BY_SPM
#endif /*_MTK_ADC_HW_H*/