/*********************************************************************************************************************
* CH32V307VCT6 Opensourec Library 即(CH32V307VCT6 开源库)是一个基于官方 SDK 接口的第三方开源库
* Copyright (c) 2022 SEEKFREE 逐飞科技
*
* 本文件是CH32V307VCT6 开源库的一部分
*
* CH32V307VCT6 开源库 是免费软件
* 您可以根据自由软件基金会发布的 GPL(GNU General Public License,即 GNU通用公共许可证)的条款
* 即 GPL 的第3版(即 GPL3.0)或(您选择的)任何后来的版本,重新发布和/或修改它
*
* 本开源库的发布是希望它能发挥作用,但并未对其作任何的保证
* 甚至没有隐含的适销性或适合特定用途的保证
* 更多细节请参见 GPL
*
* 您应该在收到本开源库的同时收到一份 GPL 的副本
* 如果没有,请参阅
*
* 额外注明:
* 本开源库使用 GPL3.0 开源许可证协议 以上许可申明为译文版本
* 许可申明英文版在 libraries/doc 文件夹下的 GPL3_permission_statement.txt 文件中
* 许可证副本在 libraries 文件夹下 即该文件夹下的 LICENSE 文件
* 欢迎各位使用并传播本程序 但修改内容时必须保留逐飞科技的版权声明(即本声明)
*
* 文件名称 zf_driver_adc
* 公司名称 成都逐飞科技有限公司
* 版本信息 查看 libraries/doc 文件夹内 version 文件 版本说明
* 开发环境 MounRiver Studio V1.8.1
* 适用平台 CH32V307VCT6
* 店铺链接 https://seekfree.taobao.com/
*
* 修改记录
* 日期 作者 备注
* 2022-09-15 大W first version
********************************************************************************************************************/
#include "ch32v30x.h"
#include "ch32v30x_adc.h"
#include "zf_driver_adc.h"
#include "zf_driver_gpio.h"
#include "zf_common_debug.h"
static ADC_TypeDef *adc_index[2] = {ADC1, ADC2};
static uint8 adc_resolution[2] = {ADC_12BIT, ADC_12BIT};
//-------------------------------------------------------------------------------------------------------------------
// 函数简介 ADC转换一次
// 参数说明 ch 选择ADC通道
// 参数说明 resolution 分辨率(8位 10位 12位)
// 返回参数 void
// 使用示例 adc_convert(ADC_IN0_A0, ADC_8BIT); //采集A0端口返回8位分辨率的AD值
//-------------------------------------------------------------------------------------------------------------------
uint16 adc_convert (adc_channel_enum ch)
{
uint8 adc = ((ch & 0xF000) >> 12);
uint8 adc_ch = (uint8)(ch >> 8) & 0xF;
ADC_RegularChannelConfig(adc_index[adc], adc_ch, 1, ADC_SampleTime_41Cycles5); // 使能对应通道
ADC_SoftwareStartConvCmd(adc_index[adc], ENABLE); // 开始数据转换
while(!ADC_GetFlagStatus(adc_index[adc], ADC_FLAG_EOC )); // 等待数据转换完成
return ((adc_index[adc]->RDATAR) >> adc_resolution[adc]); // 读取数据
}
//-------------------------------------------------------------------------------------------------------------------
// 函数简介 ADC转换N次,平均值滤波
// 参数说明 ch 选择ADC通道
// 参数说明 resolution 分辨率(8位 10位 12位)
// 参数说明 count 转换次数
// 返回参数 void
// 使用示例 adc_mean_filter(ADC_IN0_A0, ADC_8BIT,5); //采集A0端口返回8位分辨率的AD值,采集五次取平均值
//-------------------------------------------------------------------------------------------------------------------
uint16 adc_mean_filter_convert (adc_channel_enum ch, const uint8 count)
{
uint8 i;
uint32 sum;
zf_assert(count);//断言次数不能为0
sum = 0;
for(i=0; i> 12);
gpio_init(ch&0xFF, GPI, 0, GPI_ANAOG_IN); // GPIO初始化
if(adc == 0)
{
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 , ENABLE ); // 使能ADC1通道时钟
}
else if(adc == 1)
{
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC2 , ENABLE ); // 使能ADC2通道时钟
}
RCC_ADCCLKConfig(RCC_PCLK2_Div8);
// if(system_clock > 84000000) RCC_ADCCLKConfig(RCC_PCLK2_Div8); // 设置ADC分频因子,ADC最大速率不能超过14M
// else RCC_ADCCLKConfig(RCC_PCLK2_Div6);
ADC_DeInit(adc_index[adc]);
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; // ADC工作模式:ADC1工作在独立模式
ADC_InitStructure.ADC_ScanConvMode = DISABLE; // 模数转换工作在单通道模式
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; // 模数转换工作在单次转换模式
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; // 转换由软件而不是外部触发启动
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; // ADC数据右对齐
ADC_InitStructure.ADC_NbrOfChannel = 1; // 顺序进行规则转换的ADC通道的数目
ADC_Init(adc_index[adc], &ADC_InitStructure); // 根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器
ADC_Cmd(adc_index[adc], ENABLE); // 使能指定的ADC1
ADC_BufferCmd(adc_index[adc], DISABLE); // disable buffer
ADC_ResetCalibration(adc_index[adc]); // 使能复位校准
while(ADC_GetResetCalibrationStatus(adc_index[adc])); // 等待复位校准结束
ADC_StartCalibration(adc_index[adc]); // 开启AD校准
while(ADC_GetCalibrationStatus(adc_index[adc])); // 等待校准结束
//ADC_BufferCmd(ADC1, ENABLE); // enable buffer
adc_resolution[adc] = resolution; // 记录ADC精度 将在采集时使用
}