[STM32H7] systick计数器时钟源选择不起作用

[复制链接]
1280|6
 楼主| sddzycnq 发表于 2019-11-29 14:15 | 显示全部楼层 |阅读模式
请各位大侠帮忙指点迷津。
问题描述:
1. 同样的代码在两块不同的STM32H743VIT6芯片上运行,systick时钟源分别设置为SYSTICK_CLKSOURCE_HCLK_DIV8,和SYSTICK_CLKSOURCE_HCLK。一个可以设置有效。另一个设置后无效(均为400MHz)。
2. 对比两片芯片,systick的calibration value register中TENMS值不同,可以设置成功的芯片值为0x3E8(与参考手册描述一致)。另一片芯片的该寄存器值为0X493E(这个值与STM32F407的参考手册上描述的一致),不知该寄存器的值意义是什么。因为在STM32H7参考手册中看到该值是用来计算reload的值。但实测直接clock source除以1000就能得到时基1ms的定时中断。
3.以下是我的时钟设置部分代码:
  1. /* SysTick configuration */
  2. void systick_config(void)
  3. {
  4.     HAL_SYSTICK_Config(SystemCoreClock / 1000);
  5.     HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK_DIV8);//8分频,50MHz
  6. //    HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);//使用400MHz
  7.     HAL_NVIC_SetPriority(SysTick_IRQn, 0XF, 0);
  8. }

  9. /**
  10.   * [url=home.php?mod=space&uid=247401]@brief[/url] System Clock Configuration
  11.   * @retval None
  12.   */
  13. void SystemClock_Config(void)
  14. {
  15.   RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  16.   RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  17.   RCC_PeriphCLKInitTypeDef PeriphClkInitStruct = {0};

  18.   /** Supply configuration update enable
  19.   */
  20.   MODIFY_REG(PWR->CR3, PWR_CR3_SCUEN, 0);
  21.   /** Configure the main internal regulator output voltage
  22.   */
  23.   __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);

  24.   while ((PWR->D3CR & (PWR_D3CR_VOSRDY)) != PWR_D3CR_VOSRDY)
  25.   {
  26.    
  27.   }
  28.   /** Configure LSE Drive Capability
  29.   */
  30.   HAL_PWR_EnableBkUpAccess();
  31.   __HAL_RCC_LSEDRIVE_CONFIG(RCC_LSEDRIVE_LOW);
  32.   /** Macro to configure the PLL clock source
  33.   */
  34.   __HAL_RCC_PLL_PLLSOURCE_CONFIG(RCC_PLLSOURCE_HSE);
  35.   /** Initializes the CPU, AHB and APB busses clocks
  36.   */
  37.   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE|RCC_OSCILLATORTYPE_LSE;
  38.   RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  39.   RCC_OscInitStruct.LSEState = RCC_LSE_ON;
  40.   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  41.   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  42.   RCC_OscInitStruct.PLL.PLLM = 3;//5;
  43.   RCC_OscInitStruct.PLL.PLLN = 200;//160;
  44.   RCC_OscInitStruct.PLL.PLLP = 2;
  45.   RCC_OscInitStruct.PLL.PLLQ = 4;//2;
  46.   RCC_OscInitStruct.PLL.PLLR = 2;//4;
  47.   RCC_OscInitStruct.PLL.PLLRGE = RCC_PLL1VCIRANGE_2;
  48.   RCC_OscInitStruct.PLL.PLLVCOSEL = RCC_PLL1VCOWIDE;
  49.   RCC_OscInitStruct.PLL.PLLFRACN = 0;
  50.   if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  51.   {
  52.     Error_Handler();
  53.   }
  54.   /** Initializes the CPU, AHB and APB busses clocks
  55.   */
  56.   RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  57.                               |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2
  58.                               |RCC_CLOCKTYPE_D3PCLK1|RCC_CLOCKTYPE_D1PCLK1;
  59.   RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  60.   RCC_ClkInitStruct.SYSCLKDivider = RCC_SYSCLK_DIV1;
  61.   RCC_ClkInitStruct.AHBCLKDivider = RCC_HCLK_DIV2;
  62.   RCC_ClkInitStruct.APB3CLKDivider = RCC_APB3_DIV2;
  63.   RCC_ClkInitStruct.APB1CLKDivider = RCC_APB1_DIV2;
  64.   RCC_ClkInitStruct.APB2CLKDivider = RCC_APB2_DIV2;
  65.   RCC_ClkInitStruct.APB4CLKDivider = RCC_APB4_DIV2;

  66.   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  67.   {
  68.     Error_Handler();
  69.   }
  70.   PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_RTC|RCC_PERIPHCLK_USART2
  71.                               |RCC_PERIPHCLK_USART1|RCC_PERIPHCLK_SPI3
  72.                               |RCC_PERIPHCLK_SPI2|RCC_PERIPHCLK_ADC
  73.                               |RCC_PERIPHCLK_FMC;
  74.   PeriphClkInitStruct.PLL2.PLL2M = 3;//1;
  75.   PeriphClkInitStruct.PLL2.PLL2N = 200;//13;
  76.   PeriphClkInitStruct.PLL2.PLL2P = 4;//12;
  77.   PeriphClkInitStruct.PLL2.PLL2Q = 2;
  78.   PeriphClkInitStruct.PLL2.PLL2R = 2;
  79.   PeriphClkInitStruct.PLL2.PLL2RGE = RCC_PLL2VCIRANGE_3;
  80.   PeriphClkInitStruct.PLL2.PLL2VCOSEL = RCC_PLL2VCOMEDIUM;
  81.   PeriphClkInitStruct.PLL2.PLL2FRACN = 0;
  82.   PeriphClkInitStruct.FmcClockSelection = RCC_FMCCLKSOURCE_D1HCLK;
  83.   PeriphClkInitStruct.Spi123ClockSelection = RCC_SPI123CLKSOURCE_PLL;
  84.   PeriphClkInitStruct.Usart234578ClockSelection = RCC_USART234578CLKSOURCE_D2PCLK1;
  85.   PeriphClkInitStruct.Usart16ClockSelection = RCC_USART16CLKSOURCE_D2PCLK2;
  86.   PeriphClkInitStruct.AdcClockSelection = RCC_ADCCLKSOURCE_PLL2;
  87.   PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSE;
  88.   if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct) != HAL_OK)
  89.   {
  90.     Error_Handler();
  91.   }
  92. }
xinpian101 发表于 2019-11-29 21:25 | 显示全部楼层
配置前后要解锁吧
guanjiaer 发表于 2019-12-11 14:08 | 显示全部楼层
用的哪个时钟源啊
观海 发表于 2019-12-11 14:11 | 显示全部楼层
怎么会锁上的呢
八层楼 发表于 2019-12-11 14:13 | 显示全部楼层
看代码看不出来
晓伍 发表于 2019-12-11 14:16 | 显示全部楼层
用cube配置然后生成代码试试看
磨砂 发表于 2019-12-11 14:17 | 显示全部楼层
io的时钟都使能了吗
您需要登录后才可以回帖 登录 | 注册

本版积分规则

6

主题

80

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部