0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MM32F0040的时钟安全系统有什么作用

科技绿洲 来源:灵动MM32 作者:灵动MM32 2022-05-07 14:32 次阅读

MM32F0040 是一款搭载高性能 Arm® Cortex®-M0 作为内核的 32 位微控制器,最高工作频率可达到72MHz,提供 32KB FLASH 和 4KB SRAM。MM32F0040 系列 MCU 适用于多种应用场合,如工业物联网设备、PC外设、电子门锁控制、医疗和保健设备、手持设备、电机控制、电梯呼叫面板、游戏娱乐以及 8/16 位 MCU 升级替换。

我们对客户经常问到的问题进行一一解答。

MM32F0040 的时钟源有哪些?

分析案例

MM32F00040有四个系统时钟源:

高速内部时钟(HSI 上电后默认),频率为 8MHz,全温全压范围时钟精度 ±2.5%

高速外部时钟(HSE),有源晶振频率范围是 2MHz ~ 32MHz ,无源晶振频率范围是 4MHz ~ 24MHz

锁相环(PLL):当 HSI(或 HSE)作为 PLL 时钟源时, HSI(或 HSE)不可关闭

低速内部时钟(LSI)

poYBAGJ2EhuAImUNAACU9ifjZ_Q235.png

参考建议

MCU 时钟输出(MCO)允许时钟输出到外部 MCO 引脚上。相应 GPIO 端口的配置寄存器必须被配置为相应功能。可以选择以下 6 个时钟信号中的一个作为 MCO 时钟:

pYYBAGJ2EiiAZopcAAAv9OQ9Au0903.png

用户可以通过 MCU 时钟输出确认配置的时钟,受限于 MCU 的 IO 的速度,建议 MCO 输出频率小于 24M,配置如下:

poYBAGJ2EjaAF5keAABKGrx4CAY329.png

案例十

MM32F0040 的时钟安全系统有什么作用?要怎么使用?

分析案例

时钟安全系统可以监测HSE时钟是否失效,一旦发现 HSE 时钟失效,将自动切换系统时钟源到 HSI,并引发NMI 中断,在 NMI 中断中对时钟做处理,从而确保时钟系统的稳定性和可靠性。

用户可以根据实际的需求选择是否使能时钟安全系统,一旦启用 CSS,如果 HSE 时钟发生故障,CSS 中断发生,并自动生成 NMI 中断。除非 CSS 中断挂起位被清除,否则 NMI 将被不停地执行。因此,在 NMI 的处理程序中,用户必须通过设置时钟中断寄存器(RCC_CIR)的 CSSC 位为 1 来清除 CSS 中断。

时钟安全系统启用的步骤如下:

配置控制状态寄存器 (RCC_CSR)的 LSION 位为 1 和 LSI_OEN_LV 位为 1,使能 LSI

等待控制状态寄存器 (RCC_CSR) 中的 LSIRDY 位被置位为 1,表示 LSI 稳定,可输出有效时钟

配置时钟控制寄存器(RCC_CR)中的 CSSON 位为 1 ,时钟安全系统使能

案例十一

MM32F0040 有 SysTick 吗?如何配置?

分析案例

SysTick 系统定时器是属于 ARM-M 内核中的一个外设。系统定时器是一个 24bit 的向下递减的计数器,RCC 通过 AHB 时钟 8 分频后供给 CPU 系统定时器的(SysTick)外部时钟。当重装载数值寄存器的值递减到 0 的时候,系统定时器就产生一次中断,将从RELOAD 寄存器中自动重装载定时初值,开始新一轮计数,以此循环往复。只要不把它在 SysTick 控制及状态寄存器中的使能位清除,就永不停息。

SysTick定时器位于在NVIC中,用于产生SysTick异常,并且SysTick中断的优先级也可以设置。

参考建议

SysTick有四个寄存器,分别为CTRL(控制与状态寄存器)、LOAD(自动重装载值寄存器)、VAL(当前值寄存器)、CALIB(校准值寄存器)。配置参考链接:

Cortex-M0中断控制和系统控制

案例十二

MM32F0040 有几种看门狗?它们分别有什么作用?

分析案例

MM32 系列 MCU 都有两个看门狗:独立看门狗和窗口看门狗。

独立看门狗:

独立看门狗是一个 12 位的递减计数器,当计数器的值从某个值一直减到 0 的时候,系统就会产生一个复位信号或者中断信号,即 IWDG_RESET或IWDG_IRQ。如果在计数没减到 0 之前,刷新了计数器的值的话,那么就不会产生复位信号,这个动作就是我们经常说的喂狗。

独立看门狗的时钟由独立的 RC 振荡器 LSI 提供,即使主时钟发生故障它仍然有效,有独立的时钟源,可以与内部高速时钟形成相互监督的功能。LSI 的频率一般在 20~80KHz 之间,根据温度和工作场合会有一定的漂移,我们一般取 40KHz,所以独立看门狗的定时时间并不是非常精确,只适用于对时间精度要求比较低的场合。

poYBAGJ2EkeAAIcDAACMLTexP3E373.png

窗口看门狗:

窗口看门狗跟独立看门狗一样,也是一个递减计数器不断的往下递减计数,当减到一个固定值 0x40 时还不喂狗的话,产生复位,这个值叫窗口的下限,是固定的值,不能改变。这个是跟独立看门狗类似的地方,不同的地方是窗口看门狗的计数器的值在减到某一个数之前喂狗的话也会产生复位,这个值叫窗口的上限,上限值由用户独立设置。窗口看门狗计数器的值必须在上窗口和下窗口之间才可以喂狗。

pYYBAGJ2ElCAC39OAABKCi_15F0825.png

参考建议

独立看门狗的设计初衷是为了检测和解决由软件错误所引起的故障,它的原理可简述为:当独立看门狗(IWDG)计数器不断递减到达给定数值时,产生一个系统复位信号使系统复位,从而提高系统整体安全性能。

在 MM32F0040 中,独立看门狗可以配置成不复位系统的外部中断方式,可用于对时钟精度要求不高的短周期低功耗唤醒的应用场景。

硬件看门狗及选项字节操作配置参考链接:

硬件看门狗及选项字节操作

窗口看门狗就是其喂狗时间有上下限范围的(窗口) 看门狗,主要用于检测由外部干扰和可预测的逻辑条件导致程序跑飞所引起的软件问题。

案例十三

MM32F0040 的 I2C 接口有两种速率模式,我们在实际应用中需要注意些什么吗?

分析案例

MM32F0040 的 I2C 支持两种速率模式:

标准模式,数据传输速率为 0~100kbps

快速模式,数据传输速率最大为400kbps

I2C 接口是挂载在 PCLK1 时钟总线上的,为达到标准I2C 的最大频率,要求 PCLK1 的时钟频率必须大于 3MHz;为达到快速 I2C 的最大频率,要求 PCLK1 的时钟频率必须大小 12MHz。

MM32F0040 的 I2C 接口符合标准 I2C 通信协议,但有如下限制:SDA 和 SCK 不是“真”的开漏引脚,当配置为开漏输出时,在引出脚和 VDD 之间的 PMOS 管被关闭,但仍然存在,这个在实际应用电路设计时,需要关注。

案例十四

MM32F0040 的 UART 通讯波特率容忍度如何?

分析案例

在实际项目中使用 UART 接口与其它设备进行通讯交互数据时,由于运行环境等多因素的影响,存在因时钟偏差导致收发双方波特率产生偏差的情况。MM32F0040 为了提高接收端对波特率变化的容忍度,在 STOP 状态时,当三次数据采样完成后,接收端就会开始准备下一帧数据的接收。当收发双方波特率偏差处于 ±3% 以内时,仍然能够保证数据的正确传输。

同时 MM32F0040 支持硬件波特率自适应功能,配置参考链接:

UART硬件波特率自适应

审核编辑:彭菁
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 微控制器
    +关注

    关注

    48

    文章

    6808

    浏览量

    147612
  • 软件
    +关注

    关注

    67

    文章

    4346

    浏览量

    85616
  • 安全系统
    +关注

    关注

    0

    文章

    404

    浏览量

    66675
  • MM32
    +关注

    关注

    1

    文章

    104

    浏览量

    573
收藏 人收藏

    评论

    相关推荐

    安全系统功能设计怎么实现?

    新的国际标准和法规加速了工业设备对安全系统的需求。功能安全的目标是保护人员和财产免受损害。这可以通过使用针对特定危险的安全功能来实现。安全功能由一系列子
    发表于 08-01 07:17

    安全系统需要保护什么?

    新闻总是乐于报道安全系统遭到攻击的事件:操作系统漏洞、非法入侵***网络、笔记本电脑的*帐户信息被窃等等。安全性不仅仅涉及到笔记本电脑和服务器,嵌入式领域也越来越关注安全性问题,例如交
    发表于 08-06 08:01

    求大坝安全系统监测的labview程序

    毕设要用labview做一个大坝安全系统监测,大神会吗,帮帮忙,谢了
    发表于 05-08 21:39

    如何设计功能安全系统

    如何简化安全系统的设计?
    发表于 01-28 07:29

    未来车载安全系统的主题和目标是什么?

    未来车载安全系统的主题和目标是什么?
    发表于 05-12 06:35

    灵动微MM32F0040替换MM32SPIN05时ADC部分功能有何区别

    灵动微MM32F0040是一款搭载高性能Arm®Cortex®-M0作为内核的32位微控制器,工作频率可高达到72兆赫兹,提供32KB FLASH和4KB SRAM。MM32F0040系列MCU
    的头像 发表于 11-21 17:12 408次阅读

    MM32F0040 产品手册(中文版)

    MM32F0040 产品手册(中文版)
    发表于 02-22 18:52 0次下载
    <b class='flag-5'>MM32F0040</b> 产品手册(中文版)

    MM32F0040 产品手册(英文版)

    MM32F0040 产品手册(英文版)
    发表于 02-22 18:53 0次下载
    <b class='flag-5'>MM32F0040</b> 产品手册(英文版)

    MM32F0040 用户手册(中文版)

    MM32F0040 用户手册(中文版)
    发表于 02-22 18:54 0次下载
    <b class='flag-5'>MM32F0040</b> 用户手册(中文版)

    MM32F0040 用户手册(英文版)

    MM32F0040 用户手册(英文版)
    发表于 02-22 18:54 0次下载
    <b class='flag-5'>MM32F0040</b> 用户手册(英文版)

    MM32F0040 勘误表(中文版)

    MM32F0040 勘误表(中文版)
    发表于 02-22 18:55 0次下载
    <b class='flag-5'>MM32F0040</b> 勘误表(中文版)

    MM32F0040 勘误表(英文版)

    MM32F0040 勘误表(英文版)
    发表于 02-23 18:34 0次下载
    <b class='flag-5'>MM32F0040</b> 勘误表(英文版)

    AN0054 从MM32SPIN05移植到MM32F0040(中文版)

    AN0054 从MM32SPIN05移植到MM32F0040(中文版)
    发表于 02-23 18:35 0次下载
    AN0054 从<b class='flag-5'>MM</b>32SPIN05移植到<b class='flag-5'>MM32F0040</b>(中文版)

    AN0054 从MM32SPIN05移植到MM32F0040(英文版)

    AN0054 从MM32SPIN05移植到MM32F0040(英文版)
    发表于 02-23 18:35 0次下载
    AN0054 从<b class='flag-5'>MM</b>32SPIN05移植到<b class='flag-5'>MM32F0040</b>(英文版)

    工程师笔记——MM32F0040使用总结

    工程师笔记——MM32F0040使用总结
    的头像 发表于 10-26 18:09 302次阅读
    工程师笔记——<b class='flag-5'>MM32F0040</b>使用总结