Qcom LK阶段如何使用ADC介绍

点击打开链接

摘要

本文叙述了在高通平台LK阶段读取mpp2引脚电平的实现过程,附上实现代码。主要实现过程包括配置引脚功能,读取引脚电压。需要特别注意配置mpp2通道和AIN route的选择。

需要修改的文件:

bootable\bootloader\lk\app\aboot\aboot.c
Pm8x41_adc.c (dev\pmic\pm8x41)
Pm8x41_adc.h (dev\pmic\pm8x41\include)

PM8916 MPP2引脚说明

可以看出MPP2引脚具有ADC输入的功能。
Qcom LK阶段如何使用ADC介绍
Qcom LK阶段如何使用ADC介绍

修改过程及例子

在使用mpp2引脚之前需要配置这个引脚为ADC功能,在LK阶段提供了一个操作函数,在Pm8x41_adc.c (dev\pmic\pm8x41)中实现。
/*
 * API: pm8x41_enable_mpp_as_adc
 * Configurate the MPP pin as the ADC feature.
 */
void pm8x41_enable_mpp_as_adc(uint16_t mpp_num)
注意:mpp2mpp_num值为0x01

使用pm8x41_adc_channel_read(mpp2_chan);读取该引脚ADC采样得到的电压值
另外mpp2_chan的值是33(0x21)这个通道号是根据这个寄存器VADC1_LC_USR_ADC_CH_SEL_CTL来的:
Qcom LK阶段如何使用ADC介绍
Qcom LK阶段如何使用ADC介绍

在配置引脚的地方有一个
选择ADC输入路线选择的地方,根据寄存器信息可知道这里可以选择AMUX5-8!
Qcom LK阶段如何使用ADC介绍
Qcom LK阶段如何使用ADC介绍

下面是需要修改的代码:

\bootable\bootloader\lk\app\aboot\aboot.c
  1. void adc_test_selc_lcm()  
  2. {  
  3.          uint32_t vadc_chan3;  
  4.    
  5.          uint16_t mpp2_chan = 33;  
  6.          /* 
  7.           * TEST: Read the voltage on batt_id & vbat_sns channels 
  8.           */  
  9.           
  10.          pm8x41_enable_mpp_as_adc_for_mpp2(1);  
  11.           
  12.          vadc_chan3 = pm8x41_adc_channel_read(mpp2_chan);  
  13.          dprintf(INFO, "The channel [%d] voltage is :%d\n",mpp2_chan, vadc_chan3);  
  14.    
  15. }  
  16.    
  17. void aboot_init(const struct app_descriptor *app)  
  18. {  
  19. ……  
  20. adc_test_selc_lcm();  
  21. ……  
  22. }  


Pm8x41_adc.c (dev\pmic\pm8x41)
 
  1. /* 
  2.  * This is the predefined adc configuration values for the supported 
  3.  * channels 
  4.  */  
  5. static struct adc_conf adc_data[] = {  
  6.          CHAN_INIT(VADC_USR1_BASE, VADC_BAT_CHAN_ID,     VADC_MODE_NORMAL, VADC_DECIM_RATIO_VAL, HW_SET_DELAY_100US, FAST_AVG_SAMP_1, CALIB_RATIO),  
  7.          CHAN_INIT(VADC_USR1_BASE, VADC_BAT_VOL_CHAN_ID, VADC_MODE_NORMAL, VADC_DECIM_RATIO_VAL, HW_SET_DELAY_100US, FAST_AVG_SAMP_1, CALIB_ABS),  
  8.          CHAN_INIT(VADC_USR1_BASE, MPP_8_CHAN_ID, VADC_MODE_NORMAL, VADC_DECIM_RATIO_VAL, HW_SET_DELAY_100US, FAST_AVG_SAMP_1, CALIB_ABS),  
  9.          CHAN_INIT(VADC_USR1_BASE, MPP_2_CHAN_ID, VADC_MODE_NORMAL, VADC_DECIM_RATIO_VAL, HW_SET_DELAY_100US, FAST_AVG_SAMP_1, CALIB_ABS),  
  10.    
  11. };  
  12.    
  13. void pm8x41_enable_mpp_as_adc_for_mpp2(uint16_t mpp_num)  
  14. {  
  15.          uint32_t val;  
  16.          if(mpp_num >MPP_MAX_NUM)  
  17.          {dprintf(CRITICAL,"Error: The MPP pin number is unavailable\n");  
  18.          return;}  
  19.          /* set the MPP mode as AIN */  
  20.          val =(MPP_MODE_AIN <<Q_REG_MODE_SEL_SHIFT)\  
  21.                    |(0x1<<Q_REG_OUT_INVERT_SHIFT)\  
  22.                    |(0x0<<Q_REG_SRC_SEL_SHIFT);  
  23.          REG_WRITE((MPP_REG_BASE +mpp_num *MPP_REG_RANGE +Q_REG_MODE_CTL),val);  
  24.          /* Enable the MPP */  
  25.          val =(MPP_MASTER_ENABLE <<Q_REG_MASTER_EN_SHIFT);  
  26.          REG_WRITE((MPP_REG_BASE +mpp_num *MPP_REG_RANGE +Q_REG_EN_CTL),val);  
  27.          /* AIN route to AMUX8 */  
  28.          val =(0x1<<Q_REG_AIN_ROUTE_SHIFT);//AMUX1  
  29.          REG_WRITE((MPP_REG_BASE +mpp_num *MPP_REG_RANGE +Q_REG_AIN_CTL),val);  
  30. }  
Pm8x41_adc.h (dev\pmic\pm8x41\include)
  1. #define MPP_2_CHAN_ID                   33