MCU复位和程序启动那些事

大家好,这篇文章转自电源漫谈,文章从专业的角度说明了MCU复位经过的过程,对大家学习很有帮助。

MCU通常会在工作之前,先经历复位和启动的一个过程,在用户使用过程中往往在这个阶段的工作不是那么的清楚,这里我们就这一话题进行一个讨论。

一.MCU的复位问题

02625a5451ea5ed6a59a15e2961316aa.png

图1 16bit MCU和dsPIC33复位源的种类

一般来说,16位MCU包括dsPIC33的复位源主要包含以上7种,他们都可以对器件产生复位的作用,但是细节有所不同。

0af80053aff90c2805adc8d0c52d5c70.png

图2 复位系统框图

从复位系统框图上看,BOR和POR二者是和VDD电源有关的两种,看门狗和外部复位引脚复位也是比较常见的复位类型。

02d05e3a7faffa34381ff6f52fbb87fa.png

图3 复位寄存器RCON

复位寄存器RCON包含了复位相关的状态,当发生复位时RCON这个寄存器就会更新,以便表征是哪一个复位源发生了复位。除此之外,这个寄存器也包含了WDT及低功耗的特性的状态信息,所以用户可以查看这个寄存器去判断复位原因。

1715c01dd30f24584e7ec3a0e4f720f1.png

图4 复位寄存器内容1

87e118a2c14b4722af343c25288cf71d.png

图5 复位寄存器的内容2

从图示注释中,我们可以看到用户在软件中可以对这些RCON寄存器位置位1,但是这不会导致器件复位。

二.复位和中断的关系

a74b7ac9254fa398c261ba19fff4bf03.png

图6 默认中断的复位

在XC16编译器中,当用户没有提供相应中断源的中断服务程序时,会在中断向量位置放置一个软件复位中断指令SWR,这时如果有一个意外中断发生时,便触发了软件复位使得器件复位。

97329f5fa804884c9dd02bda8594c460.png

图7 默认中断软件复位指令说明

规格书中也有说明,任何未实施的或者未使用的中断向量位置都会放一个默认中断处理程序,它包含一条RESET指令。

三.复位和时钟的关系

当器件复位时,其时钟状态是什么?一般来说它是由芯片配置位决定的。

34e62d650afea897106326c7ca95d9fc.png

图8 配置位中的初始复位时钟选择


b9709932d5a686acbfd4904b24235b26.png

图9 时钟Clock Switch模式

当器件支持Clock Switch模式时,初始时钟由OSCCON寄存器中的COSC决定,切换后的时钟由NOSC决定。

9be52aa74dc522069dda808125d40892.png

图9 双速启动的模式

一般来说,从进入复位到执行第一条指令之间的时间,取决于所使用的振荡器,当使用Primary和Secondary振荡器时,由于需要和外部晶振同步,所以需要在RESET时等待时间较长才能稳定。如果使用内部振荡器的话,就非常快就可以稳定,基于配置位对时钟的选择,在复位时会等待一定的时间,最后在出复位状态前达到时钟稳定。

双速启动的含义就是说,采用FRC振荡器快速启动,然后当Primary振荡器达到稳定后再切换为它,这样可以避免等待外部晶振的同步时间。

四.复位和寄存器及变量状态的关系

9f20ace412c48752c8f79935cd9ca62e.png

图10 复位时的寄存器状态

外设的特殊功能寄存器SFR一般存在RAM中,在复位时可能会被改变,在规格书中会规定各个寄存器SFR在复位时的值。当这个值是u时,就是说它在复位时是不改变,x就是说它在复位时的值是不确定的。当然,有一些寄存器,在POR和BOR时会有不同的值,这个需要注意一下。

值得注意的各种复位源中,只有POR会改变data Memory的内容,而其它则不会改变。

五.程序启动代码的执行

一般来说,C编译器会在执行用户指令前,调用一段启动代码,这段启动代码会在结束复位时执行,这段启动代码的目的就是为运行用户C程序而做的系统准备。典型的启动代码由编译器去提供,他们将改变在复位后的memory内容。

另外,在执行启动代码时,XC16编译器会提供一些前导选项,比如Persistent,允许用户在执行启动代码时不改变某些变量。也有一些编译器会提供更直接的选项,比如在启动代码时,不初始化变量,所以,需要注意编译器的处理方式。

ccdd6f2e84a75c3b9701eb8edaacb115.png

图11 程序执行过程

编译器会把启动代码放在0x200的flash地址位置,用户main程序会放在启动代码后,在系统复位时,程序PC会被芯片硬件强制为0,则程序从0x00开始执行,在0x00处会有一个GOTO指令让代码执行到0x200部分的启动代码,这样就可以跨过中断向量的地址范围。

22c68cd8ba88622aafb68a03a6dea4e8.png

图12 程序执行过程说明

图12中清楚的说明了代码的执行过程,main函数执行之前会有执行Start-up代码的过程。

六.其它复位源的讨论

1bf30e00151c10705e3510e2ae41c03b.png

图13 Trap冲突复位说明

当系统同时发生hardTrap和Soft Trap时,则会发生Trap冲突复位,HardTrap主要是优先级在Level13-15之间的地址错误Trap或者振荡器错误Trap等。

54c9064b66ab490a88df7fb69171169a.png

图14 Soft Trap的类别说明

诸如DMAC错误,或者数学错误,或者堆栈错误等之类的soft Trap发生时,由于他们的优先级会比Hard Trap更高,因此会触发Trap冲突复位。

36da29d71a0a6a56e2c9608e39cead2e.png

图15 非法指令执行复位

当程序尝试去执行非法指令时,则会触发IOPUWR位标志位置位,表示尝试执行非法指令。

比如,用户在Flash中保存常数值,那么会仅仅用低16位的内容去保存数据,高8位设置为0x3F,这就是一个非法指令的示例,这样就可以避免程序去执行这个非法指令以避免去执行保存的数据区域的指令。

另外,W寄存器在复位时会清零,直到它再一次写进去数据,如果使用未进行初始化的W寄存器作为地址指针,则会触发IOPUWR位置位触发复位。

总结,本文对器件复位相关的源进行讨论,同时讨论和复位相关的方面,如寄存器状态,时钟状态,并对程序启动过程做一定介绍。

//关于知识产权:

1.本公众号主要用于个人学习笔记归纳及分享,无任何商业目的。

2.本公众号所发表言论及观点不代表本人现任公司及前任公司,如有错误请不吝指正。

3.欢迎随意分享转发,如需转载公众号内容,请留言告知。

4.有些图片来自网络,如有侵权,请联系删除。

5.有问题可通过公众号关注页添加本人微信或者加入技术讨论群交流。

bd48d14042c6c8d2a44cb3a094390a35.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/464082.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

若有所思

今天出来​逛了下,没有准备文章,刚好一个朋友有一段思考,给大家分享下。深圳动物园是一个值得去的地方​-----佚名海边的夏天,太阳公公当空照,照的大地滚烫,海水湛蓝。人们都躲到树荫下,享受舶风…

第三章 阴阳的工作机制(1)

一、道生一,一生二,二生三,三生万物1.易有太极,是生两仪上面,对阴阳已经讨论了很多,对这个问题已经有所了解。现在我们来讨论"阴阳的工作机制",弄清楚这个以后对理解《伤寒论》的许多…

jquery 操作日期、星期、元素的追加

主要实现日期的显示&#xff0c;获取年月日&#xff0c;时分秒、星期、判断闰年<script language"javascript" >$(document).ready(function(){function show(){var mydatenew Date();var str "" mydate.getFullYear() "年"; …

简单易懂的芯片科普漫画,帮你打开高深的新技术大门

大家好&#xff0c;我是写代码的篮球球痴&#xff0c;今天给大家推荐一本新书&#xff0c;是华为麒麟团队出版的&#xff0c;主要是让大家了解芯片的结构&#xff0c;这对很多人理解计算机是非常有帮助的。希望大家喜欢。喜欢书籍的同学在文章下面评论&#xff0c;我们会选出评…

在STM32上模拟Linux自动初始化过程

Linux中有很多编程思想可以学习&#xff0c;很多大佬把这些思想、机制运用到单片机的编程上&#xff0c;STM32 模拟Linux kernel自动初始化流程。通常我们写程序都是按照这个套路&#xff0c;一个函数一个函数按照顺序逻辑一个一个的执行下去。如果逻辑非常复杂&#xff0c;涉及…

日志配置(springboot、mybatis、Lombok)

Spring Boot在所有内部日志中使用Commons Logging&#xff0c;但是默认配置也提供了对常用日志的支持&#xff0c;如&#xff1a;Java Util Logging&#xff0c;Log4J, Log4J2和Logback。每种Logger都可以通过配置使用控制台或者文件输出日志内容 SLF4J——Simple Logging Faca…

1.6元的蓝牙芯片,你能想得到?

前不久喵了个咪在群里发了一个1.6元的SOP8蓝牙芯片的信息&#xff0c;引起了大家的热烈讨论&#xff0c;我当然也按捺不住鸡冻的心情&#xff0c;立马下单买了几片。淘宝连接&#xff1a;KT6368Ahttps://item.taobao.com/item.htm?spma1z09.2.0.0.74a52e8dTpp1my&id630430…

ADC采样效应及相关影响解剖

在前述文章&#xff0c;BUCK电路模拟补偿器的数字化过程 &#xff0c;我们讨论了模拟补偿器的数字化&#xff0c;事实上&#xff0c;数字化过程的第一个重要的环节就是ADC对反馈量的采样&#xff0c;本文就重点探讨一下由于ADC采样频率带来的一些问题&#xff0c;进而讨论一下相…

2012.2.9日晚亚马逊的一个错误链接截图

1现在时间 2 问题链接 http://www.amazon.cn/%E5%81%A5%E8%BA%AB%E5%99%A8%E6%A2%B0/b/refsa_menu_sef7?ieUTF8&node42787071 3 点击后结果 http://www.amazon.cn/gp/product/B0073RWUQA/refs9_hps_bw_g200_ir05?pf_rd_mA1AJ19PSB66TGU&pf_rd_scenter-5&pf_rd_r0…

深漂结束

早上起来看了勇士和凯尔特人的比赛&#xff0c;勇士还不能适应凯尔特人的防守&#xff0c;除了防守之外&#xff0c;凯尔特人这场比赛的三分球着实太高了。说到篮球&#xff0c;突然想起一个刚离开深圳去惠州工作的朋友。上周二中午&#xff0c;吃饭的时候我打开手机&#xff0…

嵌入式软件是这样debug的

【单步调试】【多线程调试】调试过多线程的都懂的。【断点调试】【递归调试】调试过递归代码的都有这种耳鸣目眩的感觉。【老旧代码调试】对于早期已经缝缝补补的庞大软件代码进行调试&#xff0c;还不如推倒重来。【生产中代码调试】【用户等待调试结果】【掩耳盗铃式调试】【…

声音与年龄

大家好&#xff0c;我是写代码的篮球球痴&#xff0c;最近一年一直从事音频相关的工作&#xff0c;今天刚好看到卓老师的一篇和声音相关的文章&#xff0c;分享给大家。摘要&#xff1a;今天布置了这学期信号与系统的小论文作业。有参加了上海中学生的科技节作品评选。他们的一…

系统字体的Regular、Light等几种名称的区别

以苹果系统中的PingFang SC系列字体为例&#xff0c;其中常见的有下面几种类型可以细分如下。 PingFang SC ExtraLight 苹方 特细 PingFang SC Light 苹方 细体 PingFang SC Regular 苹方 常规 PingFang SC Medium 苹方 中等 Pi…

使用 servlet 连接数据库

1.项目工程 web.xml 配置 1 <servlet> 2 <description>This is the description of my J2EE component</description> 3 <display-name>This is the display name of my J2EE component</display-name> 4 <servlet-name>DBSer…

我用涂鸦模块做的报警系统

在上次发的涂鸦的文章之后涂鸦的这套宠物SDK设计&#xff0c;真香最近刚好有一个朋友需要做一个DEMO&#xff0c;这个DEMO是和图像识别相关的&#xff0c;我这个朋友在一个烟火报警的设备&#xff0c;大家都知道我们住的小区里面都会有一个监控系统吧&#xff0c;监控系统里面是…

二叉树的非递归操作

这里涉及到二叉树的非递归操作有&#xff1a;先序遍历、中序遍历、后序遍历数据结构树结点&#xff1a;structNode { chardata; Node *left; Node *right; };标志&#xff1a;enumTag{goLeft, goRight, goBack };goLeft指示访问左子树goLeft指示访问右子树&#xf…

建立公司

最近标哥说有创业的想法&#xff0c;然后我帮忙搜了下关于创办公司的一些文章&#xff0c;晓宇的这篇文章把创业的过程写了个大概&#xff0c;也分享给大家&#xff0c;如果有创业想法的&#xff0c;按照这样的思路去寻找自己的合伙人。 自从17年4月份开始辞职创业&#xff0c;…

第五节 CImage和CBmp(二)

由于这个库主要用于VC MFC下开发应用&#xff0c;因此目前可以下载到版本只支持MFC开发。如果您需要标准Win32的库&#xff0c;可以在回复时留下您的邮箱&#xff0c;或跟我联系。Email&#xff1a;wuchunlei163.comQQ&#xff1a;819543772EasyAnalysis图像分析库测试版以及源…

Linux 新系统易用性向 Windows 看齐

大家好&#xff0c;今天是一年一度的高考&#xff0c;不知道各位在多年以前有没有后悔选择电子专业&#xff0c;如果再给你一次机会&#xff0c;你会选择其他专业吗&#xff1f;以下是内容正文&#xff0c;由黄工整理&#xff01;来源 | 网络嵌入式开发&#xff0c;很多工程师都…

深度剖析SOC高性能实时事件关联分析引擎

【引言】安全管理平台&#xff08;SOC&#xff09; 的一项关键技术就是事件关联分析。借助实时的事件关联分析引擎&#xff0c;安全管理平台能够发掘出复杂的海量安全日志和事件背后隐藏的信息&#xff0c;引导安全管理人员发现外 部***和内部违规行为。作为本系列的第五篇文章…