接着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;
}
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |