

接着188楼。换个思路,用BHS的办法,ADC 使用了 DMA方式,结果通过串口送出。
结果是相近的,另在输入端接地、接3.3V时,结果是正确的(000和FFF)。
要点(大多数注解byBHS):
void adc_Init (void) {
RCC->APB2ENR|=1<<4; //使能PORTC口时钟
GPIOC->CRL&=0XFFFF0000;//PC0 1 2 3 anolog输入
// enable periperal clock for DMA
//使能DMA时钟
RCC->AHBENR |= (1<<0);
// set channel1 memory address
//设置DMA内存地址,ADC转换结果直接放入该地址
DMA1_Channel1->CMAR = (u32)&ADC_ConvertedValue;
// set channel0 peripheral address
//设置通道1外设地址
DMA1_Channel1->CPAR = (u32)&(ADC1->DR);
// transmit 1 word
//DMA传送1个字
DMA1_Channel1->CNDTR = 1;
// configure DMA channel
DMA1_Channel1->CCR = 0x00002520;
// DMA Channel 1 enable //使能DMA通道
DMA1_Channel1->CCR |= (1 << 0);
// enable periperal clock for ADC1
//使能ADC时钟
RCC->APB2ENR |= (1<<9);
// only one conversion // 只有1个转换通道
ADC1->SQR1 = 0x00000000;
// set sample time channel0 (55,5 cycles)// (3bit)
//通道1采样周期55.5个时钟周期
ADC1->SMPR2 = 0x00000028;
// set channel1 as 1st conversion // (5bit)
//第1个转换通道是1通道
// ADC1->SQR3 = 0x00000000; //这适合CH0
ADC1->SQR3 = 0x0000000B; // CH11
// use independant mode, SCAN mode
//使用独立模式,扫描模式
ADC1->CR1 = 0x00000100;
// use data align right,continuous conversion
//使用数据右对齐,连续转换
ADC1->CR2 = 0x000E0103;
// EXTSEL = SWSTART
// enable ADC, DMA mode, no external Trigger
// start SW conversion
//允许ADC,DMA模式,无需外接触发器
//开始转换
ADC1->CR2 |= 0x00500000;
}

回复
打赏帖 | |
---|---|
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】mcxa156使用低功耗定时器适配硬件RTC框架被打赏26分 | |
【STM32F769】AI之与本地deepseek对接被打赏50分 | |
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 |