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

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

3天内不再提示

中颖M0+内核芯片软件模拟内核复位的方法

jf_pJlTbmA9 来源:中颖电子(作者:余为国 作者:中颖电子(作者: 2023-09-27 15:27 次阅读

1、关于复位

说到复位,我们都不会陌生,对于一个MCU系统,复位电路是必不可少的一部分。复位的种类有很多:上电复位、低电压复位、引脚复位、看门狗复位、软件复位等等。本文说的内核复位是软件复位的一种。

Cortex-M3内核芯片提供了两种软件复位,分别是系统复位和内核复位,而Cortex-M0+内核芯片只提供了系统复位,内核复位不支持,只能软件模拟

2、系统复位和内核复位的区别

内核复位:只复位内核处理器,而不复位外设如GPIO、Timer、UART、Flash等的寄存器

系统复位:既复位内核处理器,又复位外设寄存器。

下面分别是Cortex-M3和Cortex-M0+的应用程序中断及复位控制寄存器(AIRCR)配置图,从图中可以看出,置位AIRCR寄存器中的SYSRESETREQ位(位偏移:2),即可实现系统复位;置位VECTRESET位(位偏移:0),即可实现内核复位。Cortex-M0+中没有VECTRESET的定义,故不支持内核复位。本文会介绍一种软件模拟内核复位的方法。

wKgZomUDzuqANWvTAABV6fXjpz4116.png

wKgaomUDzu2ANPFHAACfwo1-wY8396.png

图1 Cortex-M3应用程序中断及复位控制寄存器(AIRCR)

wKgaomUDzu6AK1MNAABQIeUX0b8085.png

图2 Cortex-M0+应用程序中断及复位控制寄存器(AIRCR)

系统复位在ARM官方的库文件中都有提供相关的函数,用户直接调用即可。官方给出的系统复位函数定义如下所示:

wKgaomUDzvCATXbHAAB4W0yJjhI204.png

wKgZomUDzvGAZR7cAABvr6bWZmk645.png

内核复位在ARM官方的库文件中没有相关的函数,需要用户自行编写。Cortex-M3的内核复位函数编写如下:

wKgZomUDzvKAa-SiAAA44nGzmGY589.png

3、软件模拟内核复位的方法

内核复位在某些特殊应用下,如OTA升级时,往往会被用到。此时,不希望复位外设,只需要程序从头开始跑即可。以中颖M0+内核芯片为例,在启动配置章节有介绍到,用软件模拟内核复位来使运行在引导区的程序改由从用户代码区启动。

中颖M0+内核芯片从复位中退出时,会首先读取向量表中(从地址0x00000000开始,见图3)的头两个字。第一个字为主栈指针(MSP)的初始值,而第二个字则为决定程序执行起始地址(复位处理)的复位向量。该复位流程可以用软件去模拟,图4是软件模拟内核复位的C语言源码。

wKgaomUDzvSAesnDAADAhyWxZMA414.png

图3向量表

wKgaomUDzvWAIXheAABBKuT0aPo097.png

图4软件模拟内核复位的C语言源码

图4源码中,第1行定义了函数指针类型,取名为“FUNC_CALL”;第2,3行申明了两个变量,分别是无符号整型变量main_pgm和函数指针类型变量func;第5~20行定义了一个函数,取名为__NVIC_CoreReset(),该函数可以实现对MSP装载复位初始值,并使程序跳转到复位向量处开始执行,进而模拟了内核复位。

函数__NVIC_CoreReset()中,第9行调用了ARM官方库文件中的函数(见下图),将存储器0x0地址处的值赋给了寄存器MSP,实现了MSP复位初始值的装载;第10行是将存储器0x4地址处的值赋给变量main_pgm;第11行是将变量main_pgm强制转换成函数指针类型并赋给func;第12行调用函数func(),最终使程序跳转到了存储器0x4地址存储的复位向量处运行。

wKgaomUDzvaAOL8QAABFXUR_YRE503.png

用户需要内核复位时,在程序中直接调用图4中定义的函数__NVIC_CoreReset()即可。

4、总结

综上所述,本文提供了一种软件模拟内核复位的方法,通过调用自定义函数__NVIC_CoreReset()即可实现内核复位,给出了该函数的C语言源码,用户直接在自己程序中加载即可使用。该方法弥补了CortexM0+芯片没有自带内核复位功能的不足。

来源:中颖电子(作者:余为国)

免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理


审核编辑 黄宇

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

    关注

    447

    文章

    47821

    浏览量

    409200
  • 寄存器
    +关注

    关注

    30

    文章

    5037

    浏览量

    117765
  • 内核
    +关注

    关注

    3

    文章

    1309

    浏览量

    39862
  • 软件模拟
    +关注

    关注

    0

    文章

    8

    浏览量

    7196
收藏 人收藏

    评论

    相关推荐

    赛元微新推出了大资源高工规的32位M0+内核MCU—SC32F12系列

    赛元微新推出了大资源高工规的32位M0+内核MCU——SC32F12系列,是赛元现有Arm Cortex®-M0+产品组合的向上拓展,能够为您的设计提供三大优势,大资源,高性能和快速开发。
    的头像 发表于 04-26 10:15 121次阅读
    赛元微新推出了大资源高工规的32位<b class='flag-5'>M0+</b><b class='flag-5'>内核</b>MCU—SC32F12系列

    HC32L136 M0+内核在写FLASH时程序会跑飞的原因?

    使用一款华大的HC32L136单片机M0+内核64k的flash,在0x0-0x8000放入bootloader 在0x8000-0xFFFF放入用户代码,在全速 执行用户代码
    发表于 04-18 06:04

    STM32如何用HAL库进行内核复位

    STM32如何用HAL库进行内核复位 普通的系统复位函数如下: / ** 简短的系统重置 详细信息发起系统重置请求以重置MCU。 * / __STATIC_INLINE void
    发表于 04-11 06:49

    PY32C613单片机,高性能 32 位 ARM M0+内核,主频最高48M

    PY32C613单片机是普冉新推出的高性能的 32 位 ARM® Cortex®-M0+ 内核,宽电压工作范围的 MCU。价格在市场上非常有竞争性,外设非常的丰富。PY32C613嵌入高达 64
    发表于 01-19 15:14

    Cortex-M内核软件复位方式

    这里只讨论内核软件复位方式。像STM32的备份域复位里面也有软件复位,则不在本文讨论范围。额外
    的头像 发表于 12-06 16:18 929次阅读
    Cortex-M<b class='flag-5'>内核</b>的<b class='flag-5'>软件</b><b class='flag-5'>复位</b>方式

    怎样对M0+内核下载程序?

    如题,怎样对M0+内核下载程序,使用MDK5
    发表于 11-10 06:35

    国产单片机PY32F002B,32位ARM架构Cortex -M0+内核

    PY32F002B是普冉推出的新一代入门级32位MCU,内核使用 ARM Cortex M0+,主频最高支持到24M,24K FLASH +3K SRAM存储,并支持1.7V~5.5V宽工作电压
    发表于 10-19 14:55

    LPCXpresso54114:Cortex-M4/M0+教程

    本教程面向恩智浦LPCXpresso54114评估板。 Keil支持并使用其他恩智浦处理器制作电路板。 有关更多信息,请访问 www.keil.com/nxp。 除了Cortex-M0M0+之外
    发表于 09-05 07:56

    四维图新旗下杰发科技正式推出第三代M0+内核芯片AC7803x 丰富车规级MCU产品矩阵

    · · · · · · · · · · 四维图新旗下杰发科技近日宣布, 正式推出基于Arm Cortex M0+内核系列的第三代车规级MCU芯片AC7803x ,这是杰发科技在车规级MCU领域实现
    的头像 发表于 08-25 18:45 554次阅读
    四维图新旗下杰发科技正式推出第三代<b class='flag-5'>M0+</b><b class='flag-5'>内核</b><b class='flag-5'>芯片</b>AC7803x 丰富车规级MCU产品矩阵

    XL32F003系列单片机,32位ARM®Cortex®-M0+内核

    XL32F003系列微控制器采用高性能的32位ARM®Cortex®-M0+内核,宽电压工作范围的MCU。嵌入高达64 Kbytes flash和8 Kbytes SRAM存储器,最高工作频率
    发表于 08-11 13:57

    stm32软复位 内核复位和系统复位

    内核复位:它会使STM32内核(Cortex-M)进行复位,而不会影响其外设,如GPIO、TIM、USART、SPI等这些寄存器的复位
    的头像 发表于 08-01 17:21 3342次阅读

    imx8m plus芯片M7内核软件开发有没有开发指南?

    imx8m plus芯片M7内核软件开发有没有开发指南?
    发表于 06-01 08:39

    可以将MCUXpresso用于该设备M7内核软件开发,而不是A53内核,这是否正确?

    我正在考虑将 i.MX8M Plus 用于我们的项目。但我对这些设备的软件开发有点困惑。 您可以将 MCUXpresso 用于该设备 M7 内核
    发表于 05-29 07:41

    32 位 ARM® Cortex®-M0+ 单片机,PY32F002B 系列微控制器

    PY32F002B 系列单片机采用高性能的 32 位 ARM® Cortex®-M0+内核,宽电压工作范围的 MCU。嵌入了24Kbytes Flash 和 3Kbytes SRAM 存储器,最高
    发表于 05-18 16:25