OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4120|回复: 2

STM32 F767 ADC时钟问题

[复制链接]

9

主题

27

帖子

0

精华

高级会员

Rank: 4

积分
785
金钱
785
注册时间
2016-3-3
在线时间
28 小时
发表于 2017-3-16 23:42:49 | 显示全部楼层 |阅读模式
5金钱
//时钟设置函数
//Fvco=Fs*(plln/pllm);
//Fsys=Fvco/pllp=Fs*(plln/(pllm*pllp));
//Fusb=Fvco/pllq=Fs*(plln/(pllm*pllq));

//Fvco:VCO频率
//Fsys:系统时钟频率
//Fusb:USB,SDMMC,RNG等的时钟频率
//FsLL输入时钟频率,可以是HSI,HSE等.
//plln:主PLL倍频系数(PLL倍频),取值范围:50~432.
//pllm:主PLL和音频PLL分频系数(PLL之前的分频),取值范围:2~63.
//pllp:系统时钟的主PLL分频系数(PLL之后的分频),取值范围:2,4,6,8.(仅限这4个值!)
//pllq:USB/SDMMC/随机数产生器等的主PLL分频系数(PLL之后的分频),取值范围:2~15.

//外部晶振为25M的时候,推荐值:plln=432,pllm=25,pllp=2,pllq=9.
//得到:Fvco=25*(432/25)=432Mhz
//     Fsys=432/2=216Mhz
//     Fusb=432/9=48Mhz
//返回值:0,成功;1,失败。
u8 Sys_Clock_Set(u32 plln,u32 pllm,u32 pllp,u32 pllq)
{
        u16 retry=0;
        u8 status=0;
        RCC->CR|=1<<16;                                //HSE 开启
        while(((RCC->CR&(1<<17))==0)&&(retry<0X1FFF))retry++;//等待HSE RDY
        if(retry==0X1FFF)status=1;        //HSE无法就绪
        else   
        {
                RCC->APB1ENR|=1<<28;        //电源接口时钟使能
                PWR->CR1|=3<<14;                 //高性能模式,时钟可到180Mhz
                PWR->CR1|=1<<16;                 //使能过驱动,频率可到216Mhz
                PWR->CR1|=1<<17;                 //使能过驱动切换
                RCC->CFGR|=(0<<4)|(5<<10)|(4<<13);//HCLK 不分频;APB1 4分频;APB2 2分频.
                RCC->CR&=~(1<<24);                //关闭主PLL
                RCC->LLCFGR=pllm|(plln<<6)|(((pllp>>1)-1)<<16)|(pllq<<24)|(1<<22);//配置主PLL,PLL时钟源来自HSE
                RCC->CR|=1<<24;                        //打开主PLL
                while((RCC->CR&(1<<25))==0);//等待PLL准备好
                FLASH->ACR|=1<<8;                //指令预取使能.
                FLASH->ACR|=1<<9;                //使能ART Accelerator
                FLASH->ACR|=7<<0;                //8个CPU等待周期.
                RCC->CFGR&=~(3<<0);                //清零
                RCC->CFGR|=2<<0;                //选择主PLL作为系统时钟         
                while((RCC->CFGR&(3<<2))!=(2<<2));//等待主PLL作为系统时钟成功.
        }
        return status;
}  

//初始化ADC
//这里我们仅以规则通道为例
//我们默认仅开启ADC1_CH5                                                                                                                                          
void  Adc_Init(void)
{   
        //先初始化IO口
        RCC->APB2ENR|=1<<8;            //使能ADC1时钟
        RCC->AHB1ENR|=1<<0;            //使能PORTA时钟          
        GPIO_Set(GPIOA,PIN5,GPIO_MODE_AIN,0,0,GPIO_PUPD_PU);        //PA5,模拟输入,下拉   

        RCC->APB2RSTR|=1<<8;           //ADCs复位
        RCC->APB2RSTR&=~(1<<8);        //复位结束         
        ADC->CCR=1<<16;                        //ADCCLK=PCLK2/4=90/4=22.5Mhz,ADC时钟最好不要超过36Mhz
       
        ADC1->CR1=0;                           //CR1设置清零
        ADC1->CR2=0;                           //CR2设置清零
        ADC1->CR1|=0<<24;              //12位模式
        ADC1->CR1|=0<<8;            //非扫描模式       
       
        ADC1->CR2&=~(1<<1);            //单次转换模式
        ADC1->CR2&=~(1<<11);           //右对齐       
        ADC1->CR2|=0<<28;            //软件触发
       
        ADC1->SQR1&=~(0XF<<20);
        ADC1->SQR1|=0<<20;             //1个转换在规则序列中 也就是只转换规则序列1                           
        //设置通道5的采样时间
        ADC1->SMPR2&=~(7<<(3*5));//通道5采样时间清空          
        ADC1->SMPR2|=7<<(3*5);         //通道5  480个周期,提高采样时间可以提高精确度         
        ADC1->CR2|=1<<0;                   //开启AD转换器          
}       

问题:ADC时钟是PCLK2的四分频,但是PCLK2不应该是216M/2=108M吗,ADC初始化中的90M是怎么得来的?是不是官方搞错了?          

最佳答案

查看完整内容[请看2#楼]

90M写错了,估计写成了F429的了,F429的是90M
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2017-3-16 23:42:50 | 显示全部楼层
90M写错了,估计写成了F429的了,F429的是90M
回复

使用道具 举报

9

主题

27

帖子

0

精华

高级会员

Rank: 4

积分
785
金钱
785
注册时间
2016-3-3
在线时间
28 小时
 楼主| 发表于 2017-3-17 19:02:54 | 显示全部楼层
zuozhongkai 发表于 2017-3-17 09:58
90M写错了,估计写成了F429的了,F429的是90M

谢谢你
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-19 06:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表