热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

STM32F时钟设置

HSE8MHz。配置前将所有RCC重置为初始值RCC_DeInit();*这里选择外部晶振(HSE)作为时钟源,因此首先打开外部晶振*RC

HSE = 8MHz。
/配置前将所有RCC重置为初始值/

RCC_DeInit();/*这里选择 外部晶振(HSE)作为 时钟源,因此首先打开外部晶振*/RCC_HSEConfig(RCC_HSE_ON);/*等待外部晶振进入稳定状态*/while( RCC_WaitForHSEStartUp() != SUCCESS );/* 到这一步为止,已有 HSE_VALUE = 8 MHz.PLL_VCO input clock = (HSE_VALUE or HSI_VALUE / PLL_M),根据文档,这个值被建议在 1~2MHz,因此我们令 PLL_M = 8,即 PLL_VCO input clock = 1MHz */PLL_M = 8; /* 到这一步为止,已有 PLL_VCO input clock = 1 MHz.PLL_VCO output clock = (PLL_VCO input clock) * PLL_N,这个值要用来计算系统时钟,我们 令 PLL_N = 336,即 PLL_VCO output clock = 336 MHz.*/ PLL_N = 336;/* 到这一步为止,已有 PLL_VCO output clock = 336 MHz.System Clock = (PLL_VCO output clock)/PLL_P ,因为我们要 SystemClock = 168 Mhz,因此令 PLL_P = 2.*/PLL_P = 2;/*这个系数用来配置SD卡读写,USB等功能,暂时不用,根据文档,暂时先设为7*/PLL_Q = 7;/* 配置PLL并将其使能,获得 168Mhz 的 System Clock 时钟*/RCC_PLLConfig(RCC_PLLSource_HSE, PLL_M, PLL_N, PLL_P, PLL_Q);RCC_PLLCmd(ENABLE);/*到了这一步,我们已经配置好了PLL时钟。下面我们配置Syetem Clock*//*选择PLL时钟作为系统时钟源*/RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

/到了这一步,我们已经配置好了系统时钟,频率为 168MHz. 下面我们可以对 AHB,APB,外设等的 时钟进行配置/

/*时钟的结构请参考用户手册*//*首先配置 AHB时钟(HCLK). 为了获得较高的频率,我们对 SYSCLK 1分频,得到HCLK*/RCC_HCLKConfig(RCC_HCLK_Div1);/*APBx时钟(PCLK)由AHB时钟(HCLK)分频得到,下面我们配置 PCLK*//*APB1时钟配置. 4分频,即 PCLK1 = 42 MHz*/RCC_PCLK1Config(RCC_HCLK_Div4);/*APB2时钟配置. 2分频,即 PCLK2 = 84 MHz*/RCC_PCLK2Config(RCC_HCLK_Div2);

/函数结束*/

/以上函数可以大体上说明这些库函数的作用/

}

/**


  • @brief Configures the main PLL clock source, multiplication and division factors.

@简介 配置主PLL时钟源,以及分频因子 (PLL不止一个,还有一个用来为音频处理提供高质量时钟)


  • @note This function must be used only when the main PLL is disabled.

  • @注意 这个函数只能在主PLL失能时才能使用

  • @param RCC_PLLSource: specifies the PLL entry clock source.

@参数 RCC_PLLSource:选择PLL时钟源


  • This parameter can be one of the following values:

这个参数可以是如下值:


  • @arg RCC_PLLSource_HSI: HSI oscillator clock selected as PLL clock entry

选择HSI作为PLL时钟源


  • @arg RCC_PLLSource_HSE: HSE oscillator clock selected as PLL clock entry

选择HSE作为PLL时钟源


  • @note This clock source (RCC_PLLSource) is common for the main PLL and PLLI2S.

  • @param PLLM: specifies the division factor for PLL VCO input clock

@参数 PLLM:设置 PLL VCO 输入时钟的 除法因子(division factor)


  • This parameter must be a number between 0 and 63.

这个参数 范围是 0 ~ 63


  • @note You have to set the PLLM parameter correctly to ensure that the VCO input

  • frequency ranges from 1 to 2 MHz. It is recommended to select a frequency

  • of 2 MHz to limit PLL jitter.

  • @注意 你需要正确选择 PLLM的值, 使得 VCO输入频率 介于 1~2MHz.

建议选择 2MHz 来限制PLL震荡(jitter?)


  • @param PLLN: specifies the multiplication factor for PLL VCO output clock

  • This parameter must be a number between 192 and 432.

@参数 PLLN 选择 PLL VCO输出时钟的 乘法因子(multiplication factor )

这个参数的值 介于 192 ~432

  • @note You have to set the PLLN parameter correctly to ensure that the VCO

  • output frequency is between 192 and 432 MHz.

  • @注意 你学要正确选PLLN的大小,以保证VCO输出时钟介于 192 ~432MHz

  • @param PLLP: specifies the division factor for main system clock (SYSCLK)

  • This parameter must be a number in the range {2, 4, 6, or 8}.

@参数 PLLP 选择 系统时钟SYSCLK 的除法因子(division factor ),这个

值可以是2,4,6,8

  • @note You have to set the PLLP parameter correctly to not exceed 168 MHz on

  • the System clock frequency.

  • @注意 你需要正确设置PLLP,确保系统时钟SYSCLK不超过168MHz

  • @param PLLQ: specifies the division factor for OTG FS, SDIO and RNG clocks

  • This parameter must be a number between 4 and 15.

@参数 PLLQ 选择给 OTG FS(USB), SDIO(SD卡读写), RNG(随机数发生器)

时钟的除法因子,其值介于4~15

  • @note If the USB OTG FS is used in your application, you have to set the

  • PLLQ parameter correctly to have 48 MHz clock for the USB. However,

  • the SDIO and RNG need a frequency lower than or equal to 48 MHz to work

  • correctly.

  • @注意 如果在你的程序中用到 USB OTG FS,你需要正确设置PLLQ,确保USB有

    48MHz的时钟。但是对于SDIO,RNG需要一个小于或等于48MHz的时钟


推荐阅读
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 本文讨论了如何根据特定条件动态显示或隐藏文件上传控件中的默认文本(如“未选择文件”)。通过结合CSS和JavaScript,可以实现更灵活的用户界面。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
author-avatar
工商领域LW
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有