112 lines
2.9 KiB
C
112 lines
2.9 KiB
C
#ifndef __ADC_API_H__
|
|
#define __ADC_API_H__
|
|
|
|
|
|
//AD channel define
|
|
#define AD_CH_PA0 (0x0)
|
|
#define AD_CH_PA1 (0x1)
|
|
#define AD_CH_PA3 (0x2)
|
|
#define AD_CH_PA4 (0x3)
|
|
#define AD_CH_PA6 (0x4)
|
|
#define AD_CH_PB1 (0x5)
|
|
#define AD_CH_PB3 (0x6)
|
|
#define AD_CH_PB4 (0x7)
|
|
#define AD_CH_PB6 (0x8)
|
|
#define AD_CH_PB7 (0x9)
|
|
#define AD_CH_PC2 (0xA)
|
|
#define AD_CH_PC4 (0xB)
|
|
#define AD_CH_PC5 (0xC)
|
|
#define AD_CH_DP (0xD)
|
|
#define AD_CH_DM (0xE)
|
|
|
|
#define AD_CH_MUX (0xF) //PLL/PMU/AUDIO/BT/FM to ADC
|
|
|
|
//AD_CH_MUX
|
|
#define AD_OF_PMU ((0x0<<16) | AD_CH_MUX)
|
|
#define AD_OF_AUDIO ((0x1<<16) | AD_CH_MUX)
|
|
#define AD_OF_PLL ((0x2<<16) | AD_CH_MUX)
|
|
#define AD_OF_FM ((0x3<<16) | AD_CH_MUX)
|
|
#define AD_OF_BT ((0x4<<16) | AD_CH_MUX)
|
|
#define AD_OF_TRIM ((0x5<<16) | AD_CH_MUX)
|
|
//PMU
|
|
#define AD_CH_PMU_VBG ((0x0<<20) | AD_OF_PMU)
|
|
#define AD_CH_VDC13 ((0x1<<20) | AD_OF_PMU)
|
|
#define AD_CH_SYSVDD ((0x2<<20) | AD_OF_PMU)
|
|
#define AD_CH_DTEMP ((0x3<<20) | AD_OF_PMU)
|
|
#define AD_CH_PROGF ((0x4<<20) | AD_OF_PMU)
|
|
#define AD_CH_VBAT ((0x5<<20) | AD_OF_PMU) //1/4vbat
|
|
#define AD_CH_LDO5V ((0x6<<20) | AD_OF_PMU) //1/4 LDO5V
|
|
#define AD_CH_WVDD ((0x7<<20) | AD_OF_PMU)
|
|
//AUDIO
|
|
#define AD_CH_VOUTL ((BIT(0) << 20) | AD_OF_AUDIO)
|
|
#define AD_CH_VOUTR ((BIT(1) << 20) | AD_OF_AUDIO)
|
|
#define AD_CH_MICLDO ((BIT(2) << 20) | AD_OF_AUDIO)
|
|
#define AD_CH_CTADCREF ((BIT(3) << 20) | AD_OF_AUDIO)
|
|
#define AD_CH_DACVDD ((BIT(4) << 20) | AD_OF_AUDIO)
|
|
//PLL
|
|
#define AD_CH_BIAS ((0x0<<20) | AD_OF_PLL)
|
|
#define AD_CH_ANALOG ((0x1<<20) | AD_OF_PLL)
|
|
#define AD_CH_DIGITAL ((0x2<<20) | AD_OF_PLL)
|
|
#define AD_CH_480MEG ((0x3<<20) | AD_OF_PLL)
|
|
//FM
|
|
#define AD_CH_FMTX_SEL ((0x0<<20) | AD_OF_FM)
|
|
//BT
|
|
#define AD_CH_BT_SEL ((0x0<<20) | AD_OF_BT)
|
|
|
|
|
|
#define AD_CH_LDOREF AD_CH_PMU_VBG
|
|
|
|
#define ADC_MAX_CH 10
|
|
|
|
|
|
extern void adc_init();
|
|
|
|
extern void adc_vbg_init();
|
|
//p33 define
|
|
|
|
extern void adc_pmu_ch_select(u32 ch);
|
|
extern void adc_pmu_detect_en(u32 ch);
|
|
extern void adc_vdc13_save();
|
|
extern void adc_vdc13_restore();
|
|
|
|
u32 adc_sample(u32 ch);
|
|
|
|
u32 adc_get_value(u32 ch);
|
|
|
|
u32 adc_add_sample_ch(u32 ch);
|
|
|
|
u32 adc_remove_sample_ch(u32 ch);
|
|
|
|
u32 adc_value_to_voltage(u32 adc_vbg, u32 adc_ch_val);
|
|
|
|
void adc_set_vbat_vddio_tieup(u8 en);
|
|
|
|
u32 adc_set_sample_freq(u32 ch, u32 ms);
|
|
|
|
u8 get_wvdd_aims_level(u16 aims_mv);
|
|
|
|
u8 get_sysvdd_aims_level(u16 aims_mv);
|
|
|
|
u8 get_vdc13_aims_level(u16 aims_mv);
|
|
|
|
u8 get_mvddio_aims_level(u16 aims_mv);
|
|
|
|
u8 get_wvddio_aims_level(u16 aims_mv);
|
|
|
|
void pmu_voltage_dump(void);
|
|
|
|
void check_pmu_voltage(u8 tieup);
|
|
|
|
u8 get_cur_total_ad_ch(void);
|
|
|
|
|
|
u32 adc_get_voltage(u32 ch);
|
|
u32 adc_check_vbat_lowpower();
|
|
|
|
extern void adc_enter_occupy_mode(u32 ch);
|
|
extern void adc_exit_occupy_mode();
|
|
extern u32 adc_occupy_run();
|
|
extern u32 adc_get_occupy_value();
|
|
|
|
#endif
|