<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          Stm32時鐘分析

          作者: 時間:2016-11-28 來源:網(wǎng)絡 收藏

          本文引用地址:http://www.ex-cimer.com/article/201611/322683.htm

          RCC->CFGR=0X00000400; //APB1/2=DIV2;APB2=DIV1;AHB=DIV1;查詢中文手冊可知,

          apb1最大為36MHZ所以這里要對其分頻,因為經(jīng)過這番設置PLLMUL輸出后為72MHZ所以為,這里要讓APB1/2=DIV2是36MHZ。

          PLL-=2;//抵消2個單位

          RCC->CFGR|=PLL<<18;//設置PLL值2~16設置PLL為9倍頻

          RCC->CFGR|=1<<16; //PLLSRC ON設置HSE為輸入時鐘,因為第cfgr的17位也為0,所以HSE輸入到PLLSRC的就是8M

          此時hse為8MHZ顯然經(jīng)過上面的9倍頻,經(jīng)分析可知輸出到AHB的SYSCLK為72MHZ。因為前面設置AHB不分頻,所以AHB輸出也是72MHZ。apb1因為前面分頻了所以輸出后為36MHZ。apb2為72MHZ

          第七步:

          FLASH->ACR|=0x32; //FLASH 2個延時周期

          第八步:

          RCC->CIR = 0x00000000;//關閉所有中斷

          第九步:

          //配置向量表

          #ifdefVECT_TAB_RAM

          MY_NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);

          #else

          MY_NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);//這里用到的就是flash啟動

          #endif

          第十步:

          RCC->CR|=0x00010000;//外部高速時鐘使能HSEON,注意使能hseon之前外部時鐘不能直接或間接的為系統(tǒng)時鐘,也就是說cfgr中的SW位先為0,因為在第五步已經(jīng)設為0了,所以這里無需顧慮。

          while(!(RCC->CR>>17));//等待外部時鐘就緒

          第十一步:打開PLL,

          RCC->CR|=0x01000000;//PLLON

          while(!(RCC->CR>>25));//等待PLL鎖定

          第十二步:

          RCC->CFGR|=0x00000002;//PLL作為系統(tǒng)時鐘

          while(temp!=0x02)//等待PLL作為系統(tǒng)時鐘設置成功

          {

          temp=RCC->CFGR>>2;

          temp&=0x03;

          }

          結合Stm32_Clock_Init()時鐘配置過程,我總結時鐘配置就是大致如下步驟:

          關所有外設時鐘,
          (1)使能HSI并關閉HSE,PLL,CSS,配置分頻寄存器,并且在crgr中將系統(tǒng)時鐘設為HSI。
          (2)關所有中斷。
          (3)配置向量表。
          (4)使能HSE,CR中等待設置完畢。
          (5)打開PLL,CR中等待PLL開啟。
          (6)在cfgr中sws位等待PLL成為系統(tǒng)時鐘。


          結合上述方式,我改寫的代碼如下:
          void Stm32_Clock_Init111(u8 PLL)
          {

          unsigned char temp=0;
          RCC->APB1RSTR = 0x00000000;//復位結束
          RCC->APB2RSTR = 0x00000000;

          RCC->AHBENR = 0x00000014;//睡眠模式閃存和SRAM時鐘使能.其他關閉.
          RCC->APB2ENR = 0x00000000; //外設時鐘關閉.
          RCC->APB1ENR = 0x00000000;

          RCC->CR &= 0xFEF2FFFF;//該步的主要作用是開啟內(nèi)部HSION,且關閉HSE,CSS,PLLON

          RCC->CFGR=0X00000400; //APB1=DIV2;APB2=DIV1;AHB=DIV1; HSE設置為不分頻,CFGR的主要作用是配置分頻,分頻之前當然要把cr中HSE時鐘全關閉只開啟HSI時鐘。當然還有一個重要的作用是,設置當前是誰作為系統(tǒng)時鐘,就是SW位。


          PLL-=2;//抵消2個單位
          RCC->CFGR|=PLL<<18;//設置PLL值 2~16
          RCC->CFGR|=1<<16;//PLLSRC ON

          FLASH->ACR|=0x32;//FLASH 2個延時周期

          RCC->CIR = 0x00000000;//關閉所有中斷
          //配置向量表
          #ifdefVECT_TAB_RAM
          MY_NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);
          #else
          MY_NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);//這里用到的就是flash啟動
          #endif

          RCC->CR|=0x00010000;//外部高速時鐘使能HSEON
          while(!(RCC->CR>>17));//等待外部時鐘就緒
          RCC->CR|=0x01000000;//PLLON
          while(!(RCC->CR>>25));//等待PLL鎖定
          RCC->CFGR|=0x00000002;//PLL作為系統(tǒng)時鐘
          while(temp!=0x02)//等待PLL作為系統(tǒng)時鐘設置成功
          {
          temp=RCC->CFGR>>2;
          temp&=0x03;
          }

          }



          上一頁 1 2 3 下一頁

          關鍵詞: Stm32時鐘分

          評論


          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();