久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 5762|回復(fù): 0
收起左側(cè)

STM32F302的TIM1時(shí)鐘問(wèn)題,用8MHz內(nèi)部HSI老是設(shè)置不到72MHz作為T(mén)IM1的計(jì)數(shù)頻率值

[復(fù)制鏈接]
ID:96313 發(fā)表于 2018-8-30 20:52 | 顯示全部樓層 |閱讀模式
我看了STM32F10x系列的數(shù)據(jù)手冊(cè),一樣的,用內(nèi)部HSI是沒(méi)有辦法到達(dá)72MHz。因?yàn)樵赗CC配置寄存器中
Bit 16 PLLSRC: PLL entry clock source
Set and cleared by software to select PLL clock source. This bit can be written only when
PLL is disabled.
0: HSI/2 selected as PLL input clock
1: HSE/PREDIV selected as PLL input clock (refer to Section 8.4.12: Clock configuration
register 2 (RCC_CFGR2) on page 115


只能選著0啊,對(duì)吧!
8MHz/2=4MHz作為PLCC的輸入,然后倍頻最大值16倍 , 4MHz * 16 = 64MHz作為系統(tǒng)時(shí)鐘,給AHB下面的APB1和APB2用。

給一張時(shí)鐘樹(shù)的圖就秒懂了,我就是沒(méi)看,還在網(wǎng)上瞎找,謹(jǐn)以此帖,記錄苦逼的我,希望大家仔細(xì)看數(shù)據(jù)手冊(cè)。
stm32_CLOCK_tree.png


1.when the HSI is used as a pll clock input,the maximum system clock frequency that can be achieved is 64MHz.
就是這句話。

再附上程序配置段:
  1. //*系統(tǒng)時(shí)鐘配置**************************************************************
  2. static void SetSysClock(void)
  3. {
  4.   __IO uint32_t StartUpCounter = 0, HSIStatus = 0;

  5. /******************************************************************************/
  6. /*            PLL (clocked by HSI) used as System clock source                */
  7. /******************************************************************************/

  8.   /* SYSCLK, HCLK, PCLK2 and PCLK1 configuration -----------*/
  9.   /* Enable HSI */
  10.   RCC->CR |= ((uint32_t)RCC_CR_HSION);

  11.   /* Wait till HSE is ready and if Time out is reached exit */
  12.   do
  13.   {
  14.     HSIStatus = RCC->CR & RCC_CR_HSIRDY;
  15.     StartUpCounter++;
  16.   } while((HSIStatus == 0) && (StartUpCounter != HSI_STARTUP_TIMEOUT));

  17.   if ((RCC->CR & RCC_CR_HSIRDY) != RESET)
  18.   {
  19.     HSIStatus = (uint32_t)0x01;
  20.   }
  21.   else
  22.   {
  23.     HSIStatus = (uint32_t)0x00;
  24.   }

  25.   if (HSIStatus == (uint32_t)0x01)
  26.   {
  27.     /* Enable Prefetch Buffer and set Flash Latency */
  28.     FLASH->ACR = FLASH_ACR_PRFTBE | (uint32_t)FLASH_ACR_LATENCY_1;

  29.      /* HCLK = SYSCLK / 1 */
  30.      RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;

  31.      /* PCLK2 = HCLK / 1 */
  32.      RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE2_DIV1;

  33.      /* PCLK1 = HCLK / 2 */
  34.      RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE1_DIV1;

  35.     /* PLL configuration */
  36.     /*SYSCLK = HSI/2 * RCC_CFGR_PLLMULL16  = 64MHz*/
  37.     RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_PLLMULL | RCC_CFGR_PPRE1 | RCC_CFGR_PPRE2));
  38.     RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLMULL16 | RCC_CFGR_PPRE1_DIV1 | RCC_CFGR_PPRE2_DIV1);

  39.     /* Enable PLL */
  40.     RCC->CR |= RCC_CR_PLLON;

  41.     /* Wait till PLL is ready */
  42.     while((RCC->CR & RCC_CR_PLLRDY) == 0)
  43.     {
  44.                         
  45.     }

  46.     /* Select PLL as system clock source */
  47.     RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
  48.     RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;

  49.     /* Wait till PLL is used as system clock source */
  50.     while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)RCC_CFGR_SWS_PLL)
  51.     {
  52.                         
  53.     }
  54.   }
  55.   else
  56.   { /* If HSE fails to start-up, the application will have wrong clock
  57.          configuration. User can add here some code to deal with this error */
  58.   }
  59. }



  60. //*定時(shí)器 1 和 15 配置***********************************************************************

  61. void TIM1_Init()
  62. {
  63.         /**?????¨ê±?÷*********************************/
  64.         TIM_TimeBaseInitTypeDef   TIM_TimeBaseStructure;
  65.         GPIO_InitTypeDef          GPIO_InitStructure;
  66.         TIM_OCInitTypeDef         TIM_OCInitStructure;
  67.       
  68.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1 | RCC_APB2Periph_TIM15, ENABLE);
  69.         RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA | RCC_AHBPeriph_GPIOB , ENABLE);

  70.         //**????????±?ê1?üIOòy?? PB0*************************************
  71.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
  72.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  73.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  74.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  75.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  76.   GPIO_Init(GPIOB, &GPIO_InitStructure);
  77.         GPIO_SetBits(GPIOB,GPIO_Pin_0);
  78.       
  79.         /**????ê?3?òy?? GPIO******************************************/
  80.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_12;
  81.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
  82.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  83.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  84.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  85.   GPIO_Init(GPIOA, &GPIO_InitStructure);

  86.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_13 | GPIO_Pin_14 | GPIO_Pin_15;
  87.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
  88.   GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  89.   GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  90.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  91.   GPIO_Init(GPIOB, &GPIO_InitStructure);
  92. //PA9 PA12 PA8 PB13    PB14 PB15 PA10 P
  93.         /**????GPIO?′ó?1|?ü*****************************/
  94.         GPIO_PinAFConfig(GPIOA, GPIO_PinSource8,  GPIO_AF_6);
  95.         GPIO_PinAFConfig(GPIOA, GPIO_PinSource9,  GPIO_AF_6);
  96.         GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_6);
  97.         GPIO_PinAFConfig(GPIOA, GPIO_PinSource12, GPIO_AF_6);
  98.         GPIO_PinAFConfig(GPIOB, GPIO_PinSource1,  GPIO_AF_6);
  99.         GPIO_PinAFConfig(GPIOB, GPIO_PinSource13, GPIO_AF_6);
  100.         GPIO_PinAFConfig(GPIOB, GPIO_PinSource14, GPIO_AF_1);
  101.         GPIO_PinAFConfig(GPIOB, GPIO_PinSource15, GPIO_AF_2);
  102.         //*TIM1*?¨ê±?÷????**********************************/
  103.         TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
  104.         TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
  105.         TIM_TimeBaseStructure.TIM_Period = 2560;
  106.         TIM_TimeBaseStructure.TIM_Prescaler = TIM_CKD_DIV1;
  107.         TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
  108.         TIM_TimeBaseInit(TIM1,&TIM_TimeBaseStructure);
  109.          
  110.         //*TIM15*?¨ê±?÷????**********************************/
  111.         TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
  112.         TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
  113.         TIM_TimeBaseStructure.TIM_Period = 2560;
  114.         TIM_TimeBaseStructure.TIM_Prescaler = TIM_CKD_DIV1;
  115.         TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
  116.         TIM_TimeBaseInit(TIM15,&TIM_TimeBaseStructure);
  117.          
  118.                
  119.         /**?????¨ê±?÷PWM CH1????*PA8*********************************************/
  120.         TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
  121.         TIM_OCInitStructure.TIM_Pulse = 0;
  122.         TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  123.         TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  124.         TIM_OCInitStructure.TIM_OCIdleState=TIM_OCIdleState_Reset;
  125.         /**?????¨ê±?÷PWM CH1N????*PB13******************************************************/
  126.         TIM_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_Low;
  127.         TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;
  128.         TIM_OCInitStructure.TIM_OCNIdleState =TIM_OCNIdleState_Reset;
  129.         TIM_OC1Init(TIM1, &TIM_OCInitStructure);  
  130.         TIM_OC1PreloadConfig(TIM1, TIM_OCPreload_Enable);  
  131.       
  132.         /**?????¨ê±?÷PWM CH2????*PA9*********************************************/
  133.         TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
  134.         TIM_OCInitStructure.TIM_Pulse = 0;
  135.         TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  136.         TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  137.         TIM_OCInitStructure.TIM_OCIdleState=TIM_OCIdleState_Reset;
  138.         /**?????¨ê±?÷PWM CH2N????*PA12******************************************************/
  139.         TIM_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_Low;
  140.         TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;
  141.         TIM_OCInitStructure.TIM_OCNIdleState =TIM_OCNIdleState_Reset;
  142.         TIM_OC2Init(TIM1, &TIM_OCInitStructure);  
  143.         TIM_OC2PreloadConfig(TIM1, TIM_OCPreload_Enable);  
  144.       
  145.         /**?????¨ê±?÷PWM CH3????*PA10*********************************************/
  146.         TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
  147.         TIM_OCInitStructure.TIM_Pulse = 0;
  148.         TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  149.         TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  150.         TIM_OCInitStructure.TIM_OCIdleState=TIM_OCIdleState_Reset;
  151.         /**?????¨ê±?÷PWM CH3N????*PB1******************************************************/
  152.         TIM_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_Low;
  153.         TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;
  154.         TIM_OCInitStructure.TIM_OCNIdleState =TIM_OCNIdleState_Reset;
  155.         TIM_OC3Init(TIM1, &TIM_OCInitStructure);  
  156.         TIM_OC3PreloadConfig(TIM1, TIM_OCPreload_Enable);  
  157.       
  158.       
  159.         /*TIM15*?????¨ê±?÷PWM CH1????*PB14*********************************************/
  160.         TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
  161.         TIM_OCInitStructure.TIM_Pulse = 0;
  162.         TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  163.         TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  164.         TIM_OCInitStructure.TIM_OCIdleState=TIM_OCIdleState_Reset;
  165.         /*TIM15*?????¨ê±?÷PWM CH1N????*PB15******************************************************/
  166.         TIM_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_Low;
  167.         TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;
  168.         TIM_OCInitStructure.TIM_OCNIdleState =TIM_OCNIdleState_Reset;
  169.         TIM_OC1Init(TIM15, &TIM_OCInitStructure);  
  170.         TIM_OC1PreloadConfig(TIM15, TIM_OCPreload_Enable);  
  171.       
  172.         /*?????¨ê±?÷*/
  173.         TIM_CtrlPWMOutputs(TIM15,ENABLE);        
  174.         TIM_CtrlPWMOutputs(TIM1,ENABLE);        
  175.         TIM_Cmd(TIM1,ENABLE);
  176.         TIM_Cmd(TIM15,ENABLE);
  177. }
復(fù)制代碼
注釋有中文,所以亂碼了,別介意。
這個(gè)定時(shí)器是配置了4路互補(bǔ)PWM輸出,我用來(lái)做步進(jìn)電機(jī)驅(qū)動(dòng)器的程序,現(xiàn)在在調(diào)試階段出了這個(gè)問(wèn)題。現(xiàn)在知道問(wèn)題所在可以繼續(xù)往下走了。

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 天天曰天天曰 | 国产精品日韩一区二区 | 亚洲精品99 | 精品一区二区三区四区五区 | 自拍偷拍亚洲视频 | 99这里只有精品 | 国产成人免费在线 | 伊人二区| 午夜影院在线免费观看视频 | 日本精品一区二区三区在线观看视频 | 国产在线播放av | 日本不卡视频 | 午夜噜噜噜 | 亚洲国产一区二区视频 | 欧美日韩一二三区 | 欧美一区二区在线看 | 色婷婷国产精品综合在线观看 | 91精品观看 | 天天操天天摸天天爽 | 欧美一区二区三区在线观看 | 99免费在线 | 国产精品成人在线 | 91pao对白在线播放 | 国产精品永久免费 | 国产亚洲精品精品国产亚洲综合 | 亚洲综合电影 | 99久久婷婷国产综合精品 | 中文成人在线 | 91免费看片| 欧洲成人午夜免费大片 | 亚洲成人综合社区 | 91视频官网 | 久久av一区二区三区 | 一区二区在线免费观看视频 | 亚洲国产精品99久久久久久久久 | 国产精品一区在线观看 | 中文字幕免费 | 欧美一区二区免费 | 久久91精品国产一区二区三区 | 色网站视频 | 97国产一区二区 |