STM32 的核心Cortex-M3 处理器是一个标准化的微控制器结构,希望思考一下,何为标准化?简言之,Cortex-M3 处理器拥有32 位CPU,并行总线结构,嵌套中断向量控制单元,调试系统以及标准的存储映射。
        嵌套中断向量控制器(Nested Vector Interrupt Controller,简称NVIC)是Cortex-M3 处理器中一个比较关键的组件,它为基于Cortex-M3 的微控制器提供了标准的中断架构和优秀的中断响应能力,为超过240 个中断源提供专门的中断入口,而且可以赋予每个中断源单独的优先级。利用NVIC 从可以达到极快的中断响应速度,从收到中断请求到执行中断服务的第一条
指令仅需12 个周期。这种极快的响应速度一方面得益于Cortex-M3 内核对堆栈的自动处理机制,这种机制是通过固化在CPU 内部的微代码实现的。另一方面,在中断请求连续出现的情况下,NVIC 使用一种称为“尾链”的技术,使连续而来的中断可以在6 个时钟周期内得到服务。在中断的压栈阶段,更高优先级的中断可以不耗费任何额外的CPU 周期就能完成嵌入低优先级中断的动作。具体的细节后面我会继续总结的。用户可以通过设置CPU 自动进入低功耗状态,而使用中断来将其唤醒,CPU 在中断时间来临之前会一直保持睡眠状态。
        Cortex-M3 的CPU 支持两种运行模式:线程模式(Thread Mode)与处理模式(Handler Mode)并且需要注意的是,这两种模式都拥有各自独立的堆栈。这种设计使得开发人员可以进行更为精密的程序设计,对实时操作系统的支持也就更好了。Cortex-M3 处理器还包含了一个24 位可自动重装载定的定时器,可以为内核(RTOS)提供一个周期中断。
        在指令集方面,ARM7 和ARM9 都有两种指令集(32 位指令集和16 位指令集),而Cortex-M3系列处理器支持Thumb-2 指令集。由于Thumb-2 指令集融合了Thumb 指令集和ARM 指令集,使得32 位指令集的性能和16 位指令集的代码密度之间取得了平衡。而且,ARM Thumb-2 专门为C/C++编译器设计,这就意味着Cortex-M3 系列处理器的开发应
用可以全部在C 语言环境中完成。          STM32 微控制器的推出标志着ST 公司在两条产品主线(低价位主线和高性能主线)上迈出了重大一步。STM32 最初发布时有14 个不同型号,分为两个版本:最高CPU 时钟为72MHZ的“增强型”和最高CPU 时钟为36MHZ 的“基本型”。这些不同STM32 型号里内置的Flash 最大可达128KB,SRAM 最大为20KB,在STM32 发布之初,配置更大Flash,RAM 和更复杂外设的版本就已经在规划之中了。不管是什么版本,什么型号的STM32 器件,它们在引脚功能和应用软件上是兼容的。这就使得开发人员在使用STM32 系列微控制器时,不必改动PCB就可以根据需要随意更换器件型号。
         乍一看STM32 的设备配备,与往日熟悉的51 单片机倒有几分相似。一般,STM32 都会配备常见外设,诸如多通道ADC,通用定时器,I2C 总线接口,SPI 总线接口,CAN 总线接口,USB控制器,实时时钟RTC 等。但是,它的每一个外部设备都具有独特之处。例如,12 位精度的ADC 具备多种转换模式,并带有一个内部温度传感器,带有双ADC 的STM32 器件,还可以使两个ADC 同时工作,从而衍生出了更为高级的9 种转换模式;STM32 的每一个定时器都具备4 个捕获比较单元,而且每个定时器都可以和另外的定时器联合工作以生成更为精密的时序;STM32 有专门为电机控制而设的高级定时器,带有6 个死区时间可编程的PWM 输出通道,同时其带有的紧急制动通道可以在异常情况出现时,强迫PWM 信号输出保持在一
个预订好的安全状态;SPI 接口含有一个硬件CRC 单元,支持8 位字节和16 位半字数据的CRC 计算。在对SD 或MMC 等存储介质进行数据存取时相当有用。而且,STM32 还包含了7 个DMA 通道。没恶搞通道都可以用来在设备与内存之间进行8 位,16 位,32 位数据的传输。每个设备都可以向DMA 控制器请求发送或者接收数据。STM32内部总线仲裁器和总线矩阵将CPU 数据接口和DMA 通道之间的连接大大的简化了,这就意味着DMA 通道单元是很灵活的其使用方法简单,足以应付微控制器应用中常见的数据传输要求。
          我们前面说过了,STM32 是低功耗,高性能的微控制器。在低功耗方面,STM32 表现也是不错的。它可以在2V 供电的情况下运行,在所有设备同时打开且运行在满速72MHZ 主频的情况下,也仅消耗36mA 的电流,在与Cortex-M3 内核的低功耗模式结合之后,只有2uA 的电流消耗。即便外部振荡器处在待启动状态,STM32 使用内部8MHZ 的RC 振荡器也可迅速退出低功耗模式。这种快速进出低功耗模式的特性,也进一步降低了微控制器整体的功率消耗,同时使微控制器仍然可以保持器件的整体高性能。在电子领域,对器件的要求精度高是一方面,另一方面,还要求器件稳定性要好,处于可靠性的考虑,STM32 配备了一系列硬件来支持对可靠性的高度要求。这些硬件有:一个低电压检测器,一个时钟安全管理系统和两个看门狗定时器。时钟管理系统可以检测到外部主振荡器的失效,并随即安全的将STM32 内部8MHZ 的RC 振荡器切换为主时钟源。两个看门狗定时器中的一个称为窗口看门狗。窗口看门狗必须在事先定义好的时间上下限到达之前刷新,如果过早或过晚的刷新它,将会触发窗口看门狗复位。第二个看门狗称为独立看门狗。独立看门狗使用外部振荡器驱动,该振荡器与主系统时钟是相互独立的,这样即便STM32 的主系统时钟崩溃,独立看门狗也能“力挽狂澜”。
       在现代电子设计行业中,有一个问题是无法逃避的,那就是你不得不想方设法提高代码的安全性以防止被破解人员盗用。听师傅说,在极难得电子市场,复制一个芯片只需要几分钟。
STM32 可以锁住其内部Flash 使破解人员无法通过调试端口读取其内容。当Flash 的读保护功能开启后,其写保护功能也随之开启。写保护功能常用于防止一些来历不明的代码写入中断向量表。但是,写保护不仅可以保护中断向量表,还可以进一步将其保护范围延伸到整个Flash 中的未被使用区域。另外,STM32 还有一小块电池备份RAM 区,这个RAM 区域对应于一个入侵检测引脚应用,当这个引脚上产生电平变化时,STM32 会认为遭遇了入侵事件,随即自动将电池备份RAM 区的内容全部清除。目前好多开发工具都开始支持Thumb-2 指令集和STM32 系列,即使不支持也没有关系,我们只需要将软件升级一下即可。同时,ST 公司还提供了一个设备驱动固件库和一个USB 开发应用库,以方便调用。对于STM32 来说,一些早期微控制器比如早期的STR7 和STR9 发布的ANSI C 库和源代码都是可移植的。这些程序的接口已经在许多流行的编译工具上得到了整合。相似的,许多开源的或者商用的RTOS,还有一些中间件(比如TCP/IP 栈,文件系统)对以STM32 系列微控制器来说也是可用的。
        Cortex-M3 还带有一个全新调试系统CoreSight。用户可以使用标准的JTAG 接口或者双线串行接口通过调试端口(debug Access Port)实现和CoreSight 系统的对接。除了提供调试运行控制服务之外,STM32 上的CoreSight 还提供断点数据查看功能以及一个指令跟踪器。指令跟踪器可以将用户选择的应用信息上传到调试工具里。从而可以为用户提供额外的调试信息,并且它在软件运行期间同样可以使用。

STM32 的核心Cortex-M3 处理器相关推荐

  1. Cortex M3处理器工作模式及中断过程

    来自::http://blog.csdn.net/ffgamelife/article/details/6947300 1.      工作模式 线程模式(Thread mode):处理器复位或异常退 ...

  2. Cortex M3内核架构

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

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

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

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

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

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

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

  6. ARM 架构、ARM7、ARM9、STM32、Cortex M3 M4 、51、AVR 之间有什么区别和联系?

    本文转自嵌入式资讯精选公众号,特别鸣谢, 编者按:初学习ARM单片机的同学们可能会对ARM的架构定义并不是很明确,形形色色的名词背后到底代表什么含义呢?请听听这位嵌入式工程师的经验总结. ARM架构: ...

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

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

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

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

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

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

最新文章

  1. warnings.filterwarnings(ignore)
  2. Android系统中设置TextView等的行间距
  3. 游戏数学中的数学思想
  4. 评估模型如何建立_建立和评估分类ML模型
  5. LeetCode 687. 最长同值路径(二叉树,递归)
  6. mysql获取当前时间,前一天,后一天
  7. 转载:用图片搜索图片的几个好网站
  8. h5 前端 PHP,十分钟搞定微信H5支付(ThinkPHP5.1)
  9. VUE(11) : 图片点击全屏展示
  10. CS4398 Cirrus Logic的旗舰级音频解码芯片
  11. 初学C语言一些知识点的整理
  12. 面试中问的话题Spring工作原理
  13. 计算机为什么不读500g硬盘,为什么我的500g硬盘的实际容量只有46 5. 1G
  14. 机器学习数学基础九:回归分析
  15. ElasticSearch入门-搜索如此简单
  16. IDEA中Git及可视化工具TortoiseGit简单使用
  17. 利用GAE+WallProxy-plugins搭建个人代理服务器
  18. 免费的系统压力测试方法/工具有哪些?企业如何做好软件压力测试
  19. 尋找《案件取证操作教程EnCase》.ppt。
  20. FAT32,exFAT和NTFS有什么区别?

热门文章

  1. C# IDE SharpDevelop的一些缺陷
  2. 数据库系统概论整理(Part Ⅰ)
  3. 哈佛医生帮你增强记忆力
  4. 几何画板在教学中的作用
  5. MAC下HFS,HFS+,HFSX文件系统 解析
  6. 智慧供水管网监测方案助力水资源高效利用
  7. 2d绘制 c# dx_如何在C#中绘制2D等高线图?
  8. Re: 从0开始的DMD学习
  9. ZYNQ PL中断PS
  10. 【应用多元统计分析】——第三章(1)