当前位置: 首页 > news >正文

《Mcal》--MCU模块

一、MCU模块的主要功能

  • 控制系统时钟的产生。
  • 控制系统通用模块,该模块会涉及到Adc、Ftm等外设的配置。
  • 控制外设时钟。
  • 控制MCU运行的模式。
  • 初始化定义RAM Section。

比较重要的是时钟的配置。

二、系统时钟的配置

  1、芯片时钟树

        要想弄明白时钟配置,需要参考芯片手册中的系统时钟树:

图1 系统时钟树

对于时钟树做一个总结,主要是对产生的时钟进行一个分类,并总结他们的来源:

  • PREDIV_SYS_CLK/CORE_CLK/SYS_CLK/BUS_CLK/FLASH_CLK

        SOSC->SPLL_CLK

        FIRC

        SIRC

        SOSC

  • Asynchronous Peripheral Sources

        SPLL

        FIRC

        SIRC

        SOSC

  • CLKOUT

        Asynchronous Peripheral Sources

        SCG_CLKOUT

        HCLK

        BUS_CLK

        .........

  • LPO_CLK

        LPO128K_CLK

        LPO32K_CLK

        LPO1K_CLK

  • RTC_CLKOUT

        RTC_CLK

        LPO1K_CLK

重要的是前两个CLK。

  2、系统晶振配置

与McuFIRCClockConfig、McuSIRCClockConfig、McuSystemPll配置类似。

图2 系统晶振配置

用于配置图1中的OSC,会影响到SPLL_CLK和和SOSC_CLK。

  • SOSC Div1

        图1中SOSCDIV1的值,影响到SOSCDIV1_CLK。

  • SOSC Div1 Frequency

        SOSCDIV1_CLK的值,单位位Hz。

  • SOSC External Reference Select

        选择SOSC_CLK是外部晶振还是内部晶振。

  • SOSC Range Select

        选择系统晶振的范围。

        中频范围是 4 兆赫兹到 8 兆赫兹。

        高频范围是 8 兆赫兹到 32 兆赫兹。

        使用PLL的情况下,只能选择高频范围。

  3、不同模式下的时钟配置

        McuRunClockConfig、McuHsrunClockConfig、McuVlprClockConfig

        主要用于配置芯片在RUN、HSRUN、VLPR三种模式下的第一类CLK的配置。

三、系统通用模块的配置

        系统通用模块的配置主要包括Adc和FTM,将再具体涉及到这些外设的时候进行详细介绍。

图3 系统通用模块的配置

四、外设时钟的配置

图4 外设时钟配置

五、参考时钟配置

图5 参考时钟

有些外设在配置的时候需要有参考时钟,在这里创建,然后引用就可以。

http://www.lryc.cn/news/518830.html

相关文章:

  • C语言:枚举类型
  • spring boot 多数据源集成mysql、postgresql、phoenix、doris等
  • USB基础 -- USB 控制传输(Control Transfer)的重传机制
  • 云计算基础,虚拟化原理
  • 浮点数在C语言开发中为什么不精确?
  • ChatGPT网络错误如何解决
  • Vue3初学之插槽(slot)使用
  • 使用PVE快速创建虚拟机集群并搭建docker环境
  • 带格式 pdf 翻译
  • 【C++】C++11(一)
  • 初学stm32 --- ADC单通道采集
  • 【动态规划篇】欣赏概率论与镜像法融合下,别出心裁探索解答括号序列问题
  • Java(day7)
  • Word 转成pdf及打印的开源方案支持xp
  • LabVIEW软件侵权分析与应对
  • 【redis】centos7下安装redis7
  • [network]回顾:集线器(Hub)
  • 79 Openssl3.0 RSA公钥加密数据
  • EFCore HasDefaultValueSql (续2 HasComputedColumnSql)
  • 阿里巴巴TransmittableThreadLocal使用指南
  • ubuntu20下编译linux1.0 (part1)
  • 欧拉公式和傅里叶变换
  • Jenkins内修改allure报告名称
  • 30天开发操作系统 第 12 天 -- 定时器 v1.0
  • Ubuntu | PostgreSQL | 解决 ERROR: `xmllint` is missing on your system.
  • uniapp使用chooseLocation安卓篇
  • 《PC 上的开源神经网络多模态模型:开启智能交互新时代》
  • Apache JMeter 压力测试使用说明
  • 腾讯云AI代码助手编程挑战赛-知识百科AI
  • 【SpringAOP】Spring AOP 底层逻辑:切点表达式与原理简明阐述