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,一经查实,立即删除!

相关文章

逆波兰表达式[栈 C 语言 实现]

逆波兰表达式 逆波兰表达式又叫做后缀表达式。在通常的表达式中,二元运算符总是置于与之相关的两个运算对象之间,这种表示法也称为中缀表示。波兰逻辑学家J.Lukasiewicz于1929年提出了另一种表示表达式的方法,按此方法,每一运算符…

FireFox不支持cursor:hand

这个在IE/Firefox下都支持可以使用cursor:pointer;转载于:https://www.cnblogs.com/kaixin110/archive/2007/08/22/865287.html

Red Hat 6.0 Installation Steps

1) 注册和下载 - 需要一个公司email地址来接收RH的确认邮件 https://cn.redhat.com/products/enterprise-linux/server/download.html 下载免费红帽企业 Linux 30 天评估版 - 注册完毕转入下载页面 https://access.redhat.com/downloads/ -选择免费评估版本, 收到确认邮件, 找到…

若有所思

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

HDU 4383 To The Moon 解题报告

HDU 4383 To The Moon 题意翻译 已知一个长为\(n\)的序列\(a\),你需要进行下面的四种操作。 C l r d 将区间\([l,r]\)中的数加上\(d\),同时时间加\(1\) Q l r 查询当前时间区间\([l,r]\)中所有数的和 H l r t 查询时间为\(t\)时区间\([l,r]\)中所有数的和 B t 将当前…

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

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

tcp窗口滑动以及拥塞控制

转自:http://blog.chinaunix.net/uid-26275986-id-4109679.html TCP协议作为一个可靠的面向流的传输协议,其可靠性和流量控制由滑动窗口协议保证,而拥塞控制则由控制窗口结合一系列的控制算法实现。 一、滑动窗口协议 关于这部分自己不…

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

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

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

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

UDT协议详细分析

UDT协议的主要特性有哪些&#xff1f; 基于UDP的应用层协议&#xff1a; 有基本网络知识的朋友都知道TCP和UDP的区别和使用场景&#xff0c;但是有没有一种协议能同时兼顾TCP协议的安全可靠和UDP协议的高效&#xff0c;那么UDT就是一种。 面向连接的协议&#xff1a;面向连接…

书摘---创业36条军规1:创业是怎么回事

这本书是电子版&#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…

先知

他这样说爱情&#xff1a;Love gives naught but itself and takes naught but from itself.Love possesses not nor would it be possessed.For love is sufficient unto love.转载于:https://www.cnblogs.com/belial/archive/2007/09/23/903433.html

TCP与UDP的选择--结合QQ来说明

TCP与UDP的选择如果比较UDP包和TCP包的结构&#xff0c;很明显UDP包不具备TCP包复杂的可靠性与控制机制。与TCP协议相同&#xff0c;UDP的源端口数和目的端口数也都支持一台 主机上的多个应用。一个16位的UDP包包含了一个字节长的头部和数据的长度&#xff0c;校验码域使其可以…

Xampp修改数据库默认用户root的密码

Xampp数据库默认用户root&#xff0c;密码为空&#xff0c;修改密码的位置&#xff1a;xampp/passwords.txt转载于:https://www.cnblogs.com/testlife/archive/2012/02/08/2342438.html

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

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

pyplot交互地画多个plot

下面的代码&#xff0c;可以无阻碍地show 5个figure&#xff0c;相当于开启了ipython的interactive 模式 具体参见stackoverflow: in matplotlib, is there a way to pop up a figure asynchronously? 1 #!/usr/bin/python2 import pylab as plb3 import matplotlib.pyplot as…

又是一年中秋节,好想举杯邀明月

世事一场大梦&#xff0c;人生几度新凉。夜来风叶已鸣廊&#xff0c;看取眉间鬓上。 酒贱常愁客少&#xff0c;月明多被云妨。中秋谁与共孤光&#xff0c;把盏凄然北望。 简策写虚名&#xff0c; 蝼蚁侵枯骨。千古光阴一霎时&#xff0c;且进杯中物。 二十四年过去&#xff…

UDT内部代码分析

一. 报文发送 1.CSndQueue::worker中调用CChannel::sendto发送数据报文。 2.CSndQueue::sendto中调用CChannel::sendto发送其他报文, 种类较多主要有: 1)CUDT::connect中调用CSndQueue::sendto发送建立连接请求。 2) CUDT::sendCtrl中调用CSndQueue::sendto发送控制报文。 …