在离开复位状态后,CM3 做的第一件事就是读取下列两个32 位整数的值:
从地址 0x0000,0000 处取出MSP 的初始值。
从地址 0x0000,0004 处取出PC 的初始值——这个值是复位向量,LSB 必须是1。然后从这个值所对应的地址处取指。

请注意,这与传统的ARM 架构不同——其实也和绝大多数的其它单片机不同。传统的ARM 架构总是从0 地址开始执行第一条指令。它们的0 地址处总是一条跳转指令。在CM3
中,0 地址处提供MSP 的初始值,然后就是向量表(向量表在以后还可以被移至其它位置)。向量表中的数值是32 位的地址,而不是跳转指令。向量表的第一个条目指向复位后应执行的第一条指令。

因为CM3 使用的是向下生长的满栈,所以MSP 的初始值必须是堆栈内存的末地址加1。举例来说,如果你的堆栈区域在0x20007C00‐0x20007FFF 之间,那么MSP 的初始值就必须是0x20008000。向量表跟随在MSP 的初始值之后——也就是第2 个表目。要注意因为CM3 是在Thumb态下执行,所以向量表中的每个数值都必须把LSB 置1(也就是奇数)。正是因为这个原因,图3.18 中使用0x101 来表达地址0x100。当0x100 处的指令得到执行后,就正式开始了程序的执行。在此之前初始化MSP 是必需的,因为可能第1 条指令还没执行就会被NMI 或是其它fault 打断。MSP 初始化好后就已经为它们的服务例程准备好了堆栈。

Cortex-M3复位序列相关推荐

  1. Cortex M3 NVIC与中断控制

    Cortex M3 NVIC与中断控制 宗旨:技术的学习是有限的,分享的精神是无限的. 一.NVIC概览 --嵌套中断向量表控制器 NVIC 的寄存器以存储器映射的方式来访问,除了包含控制寄存器和中断 ...

  2. Cortex M3内核架构

    CortexM3内核架构 宗旨:技术的学习是有限的,分享的精神是无限的. 1.ARMCortex-M3处理器 Cortex-M3处理器内核是单片机的中央处理单元( CPU). 完整的基于CM3的MCU ...

  3. Cortex M3 Bit-banding简介

    http://blog.csdn.net/shevsten/article/details/7676397 Cortex M3 Bit-banding简介 分类: ARM MCU2012-06-19 ...

  4. cortex m3 开源_开源增强现实耳机,Steam的125M有效帐户等

    cortex m3 开源 您好,开放游戏迷! 在本周的版本中,我们将了解Steam的1.25亿活跃帐户和Game Developers Conference,这是一个开源增强现实头戴设备,Linux游 ...

  5. cortex m3的操作模式和状态

    1.操作状态(operation state): debug state:处理器在调试器发起halt或匹配到断点时,会进入debug state并停止执行指令. thumb state:处理器正在运行 ...

  6. cortex m3/m4处理器的复位设计

    cortex m3/m4处理器在复位层面总体上可以划分为core和debug logic两部分.core部分包括处理器内核(core)以及NVIC,BUS Matrix,MPU的非debug部分.de ...

  7. Cortex、ARMv8、arm架构、ARM指令集、soc?Cortex A8、A9都是ARMv7a 架构;Cortex M3、M4是ARMv7m架构;前者是处理器(内核)后者是指令集的架构(架构)

    架构组成元素的指令集状态或者语法thumb指令集与arm指令集的区别例如thumb指令集是什么_thumb指令集与arm指令集的区别以及thumb-2的关系在下一文中介绍,本文暂时不讨论 有粉丝问我到 ...

  8. stm32 cortex M3 汇编指令集 英文详解

    这是cortex M3的汇编指令集详解,包含指令执行的周期,如下图示例,可以去Arm公司下载此文档,链接在此https://developer.arm.com/documentation/ddi033 ...

  9. Cortex‐M3的Faults异常究竟是什么?

    关注+星标公众号,不错过精彩内容 作者 | strongerHuang 微信公众号 | strongerHuang 有许多朋友在学习,或者开发STM32时都遇到过HardFault_Handler的情 ...

  10. ARM 架构、ARM7、ARM9、STM32、Cortex M3 M4 、51、AVR 有啥区别

    ARM架构.ARM7.ARM9.STM32.Cortex M3 M4.51.AVR之间有什么区别和联系? ARM架构:由英国ARM公司设计的一系列32位的RISC微处理器架构总称,现有ARMv1~AR ...

最新文章

  1. Ceres非线性优库入门介绍
  2. POJ 2356 (抽屉原理)
  3. 大数据标签获取处理步骤_大数据处理分为哪些步骤
  4. COMMCONFIG进行配置的WIN32 API
  5. Blazor 模板化组件开发指南
  6. *【CodeForces - 1088 ABC】套题比赛,A水题B模拟C构造D交互
  7. c可以 char* 赋值但是c++不可以_雷佳音的妻子完全可以女团C位出道,这么有气质的女人,谁能不爱...
  8. 数据中台必备的4个核心能力,你让数据创造价值了吗?
  9. 开发 问卷调查案例_云南泸沽湖摩梭文化原真性保持与旅游开发协调研究
  10. Android NDK开发如何解决logcat日志打印不全
  11. 如何查看计算机有无无线连接功能,你可能不知道的,电脑自带的WIFI信号发射功能!...
  12. 推荐一个爬虫神器:You-Get,小白也会用
  13. Candence学习篇(5)使用Padstack Editor制作贴片焊盘和通孔焊盘
  14. 携程是如何做React Native优化的
  15. Rust中的channel
  16. 【数据可视化】使用pyecharts制作词云
  17. 企业邮箱Foxmail提示错误421 too many connections
  18. ccsds ldpc matlab,CCSDS标准的LDPC编译码仿真
  19. gdb调试程序时跳进函数和跳出函数
  20. 数据集中度分析(不排序)

热门文章

  1. Qt5.7| C/C++ 超级简单一学就会的仿QQ宠物
  2. fdfs_client.exceptions.DataError: [-] Error: 2, No such file or directory报错问题
  3. gcc编译c文件 python.h 未找到
  4. 华为什么手机用的鸿蒙系统,华为2020年全线启用鸿蒙系统,手机、平板依然Android优先...
  5. r语言c5.0决策树算法参数,决策树算法CART、C5.0的R语言实现——(三)
  6. 微信红包随机数字_微信红包随机算法转载
  7. 搭建IBM z/OS 1.9(ADCD 1.9)
  8. 什么是堆栈?内存中划分出按FIL0方式操作的特殊区域,叫做堆栈
  9. (软件工程复习核心重点)第十二章软件项目管理-第二节:进度计划
  10. Linux系统编程3:基础篇之详解Linux软件包管理器yum