新手,问一个时钟配置的问题

2019-07-14 23:36发布

请问    RCC->CR |= 0X00010000; //使能外部高速时钟HSEON           while(!(RCC->CR>>17));  //将RCC_CR寄存器的值右移17位,等待HSERDY就绪,即外部时钟就绪
         这两句话应该怎么理解?

我的理解是第一句话让外部时钟(HSEON)置1,第二句话使寄存器右移17位,等到寄存器31位为1时跳出while循环
是这样吗,这样可以跳出循环吗?
纠结了

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
5条回答
jeansonm
1楼-- · 2019-07-15 07:47
wizardli 发表于 2014-5-30 10:39
请问只要HSEON那一位只要被置1过就可以了吗?不需要一直为1是吗?

打开HSE时钟后 ,等到标志位置位就说明HSE准备就绪了 ,需要等到HSE正常工作后继续下面任务才能保证正常,不然可能会出现错误的
wizardli
2楼-- · 2019-07-15 09:58
 精彩回答 2  元偷偷看……
jeansonm
3楼-- · 2019-07-15 11:18
wizardli 发表于 2014-5-30 12:08
谢谢您,其实我还有一个问题,希望您可以解答一下
主要是不能理解为什么while(!(RCC->CR>>17)),这样能 ...

就是判断当第17位为1后跳出循环
wizardli
4楼-- · 2019-07-15 11:54
jeansonm 发表于 2014-5-30 12:59
就是判断当第17位为1后跳出循环

明白了,谢谢您的指导
wizardli
5楼-- · 2019-07-15 15:19
jeansonm 发表于 2014-5-30 12:59
就是判断当第17位为1后跳出循环

您好,我有一个新疑问,请帮我解答一下可以吗

#include "main.h"
#include "rcc.h"

void RCC_init()          //我们单独列出来一个RCC_init()来管理时钟初始化工作
{
          /***** 以下是关于RCC时钟 详细请见《STM32F10XXX参考手册》6.3节RCC寄存器描述 *******/
           unsigned char sws = 0;
           RCC->CR |= 0X00010000; //使能外部高速时钟HSEON
           while(!(RCC->CR>>17));  //将RCC_CR寄存器的值右移17位,等待HSERDY就绪,即外部时钟就绪
         
          /* 因为手册有要求APB1时钟频率不超过36MHZ,而在STM32中最大为72MHZ */
          /* 为了保证最大速度,我们这里设置成2分频 */
          /* 设置寄存器CFGR里的8-10位的值为100 */
           RCC->CFGR = 0x00000400;   

          /* 寄存器CFGR的18-21四个bit位配置成以下值,则PLL就会设置成对应的值:
                0000:PLL 2倍频输出          1000:PLL 10倍频输出
                0001:PLL 3倍频输出          1001:PLL 11倍频输出
                0010:PLL 4倍频输出          1010:PLL 12倍频输出
                0011:PLL 5倍频输出          1011:PLL 13倍频输出
                0100:PLL 6倍频输出          1100:PLL 14倍频输出
                0101:PLL 7倍频输出          1101:PLL 15倍频输出
                0110:PLL 8倍频输出          1110:PLL 16倍频输出
                0111:PLL 9倍频输出          1111:PLL 16倍频输出         
                我们在这里,因为STM32神舟I号上的晶振是8MHZ的,配置成9倍输出就能达到STM32最大72MHZ工作频率*/
               
                RCC->CFGR |= 7<<18; //本例程希望设置成40MHZ的工作频率,我们在这里尝试一下
                                    //2右移动18位,即0011使得PLL获得5倍频输出,外部晶振是8MHZ
                                                        //乘以4就是40MHZ了
                RCC->CFGR |= 1<<16; //PLLSRC设置成1,使得HSE时钟作为PLL输入时钟
                FLASH->ACR|=0x32;          //FLASH 2个延时周期
                RCC->CR |= 1<<24; //将PLL使能

                while(!(RCC->CR>>25)); //监控寄存器CR的PLLRDY位,等待PLL时钟就绪

                RCC->CFGR |= 1<<1;  //将时钟切换寄存器配置成用PLL输出作为系统时钟

            while(sws != 0x2)         //等待CFGR寄存器的2,3位为10,系统正式切换到了PLL输出作为时钟
                {
                        sws = RCC->CFGR>>2;         // 将CFGR寄存器右移2位,将2,3位SWS状态移出来,
                                             // 详情请见《STM32F10XXX参考手册》54页
                        sws &= 0x3;                         //这里的0x3为二进制的11,这个whlie循环设计的一个算法,为了判断sws是不是为10
                }
}



红 {MOD}部分的算法是如何实现的呢?逻辑看不大懂

一周热门 更多>