STM32F4 programming manual_1

1. 处理器模式与特权等级

处理器模式分为以下两种:

  • 线程模式:

    用来执行应用软件;

    处理器从reset出来时,进入线程模式;

    CONTROL寄存器控制软件的执行状态时特权的还是非特权的。

  • 处理模式:

    用来处理异常;

    完成异常处理后,进入线程模式;

    该模式下,软件运行在特权等级上。

特权等级有以下两种:

  • 非特权:

    对于MSR、MRS指令受限的权限,不能使用CPS指令;

    不能使用系统定时器、NVIC、系统控制块;

    对于部分内存和外设的访问受限

    必须使用SVC指令来执行超级访问者调用以控制特权等级的软件

  • 特权:

    可以使用所有指令,访问所有资源。

    可以写CONTROL寄存器来改变软件执行的特权等级。

2. 栈

处理器使用向下增长的栈,这意味着栈指针指向栈内存的最后一个成员。当处理器将数据压入栈时,首先将栈指针减小相应的字节数,然后将数据写入栈指针所指的内存地址。处理器使用了两个的栈main stackprocess stack,他俩拥有栈指针的独立拷贝。

在线程模式下,CONTROL寄存器控制处理器使用哪个栈(main stack or process stack)。在处理模式下,处理器总是使用 main stack。

处理器模式 用途 特权等级
线程模式 运行应用 特权 或 非特权 main stack or process stack
处理模式 处理异常 总是特权 main stack

3. 核心寄存器

  • 通用寄存器

    R0-R12 是32位通用寄存器,其中R0-R3四个寄存器可用于参数传递与结果返回。

  • 栈指针SP

    R13用于存储栈指针,在线程模式下,CONTROL寄存器的bit[1]表示使用哪个栈(main stack or process stack)。

    bit[1] = 0: 使用主栈main stack pointor(MSP), 这是reset时设置的值,也就是默认值。

    bit[1] = 1:使用process stack pointor(PSP)

    reset时,MSP被装载0x00000000.

  • 链接寄存器LR

    R14用于存储链接指针,主要是在发生函数调用的场合,LR寄存器存储子函数的返回地址。发生指令跳转时,如BL指令,首先将PC中地址存入LR寄存器中,然后将跳转目的地址存到PC中。

    reset时,该值被置为0xFFFFFFFFF.

  • 程序计数器PC

    R15用于存储当前程序地址,reset时该寄存器装载reset向量的地址,这在地址 0x00000004的位置。

    reset时,bit[0]的值被装载到EPSR的T位,而且必须为1。

  • 程序状态寄存器PSR,该寄存器内存在几个互斥的位域可分别用以下寄存器表示。(同一个物理地址,几个不同名字)

    应用程序状态寄存器 APSR

    中断程序状态寄存器 IPSR

    异常程序状态寄存器 EPSR

  • CONTROL 寄存器

    该寄存器控制在线程模式下使用哪个栈以及软件运行的特权等级

    指示FPU状态是否激活

处理模式下,处理器总是使用MSP的,因此处理器会忽略对寄存器bit[1]的写入操作。

在OS环境中,建议线程运行在线程模式下使用PSP(process stack);kernel和异常处理使用MSP(main stack)。

默认情况下,线程模式使用MSP(main stack)。可以通过下面两种方式将栈指针切换到PSP。

  • 使用MSR指令,将CONTROL寄存器的bit[1]设置为1
  • 异常返回到线程模式时,使用一个合适的EXC_RETURN值。

当改变栈指针时,软件必须在使用MSR指令后,立即使用ISB指令。这保证了ISB指令之后的指令使用新的栈指针。

ISR指令是指令同步屏障(instruction synchronization barrier),它刷新了处理器的管道线,导致该指令之后的指令都要重新fetch。这条指令不会改变标志位。

The Cortex microcontroller software interface standard (CMSIS)

该标准定义了如下内容

  • 访问外设的方式
  • 定义异常向量的方式
  • 核心外设寄存器的名字
  • 核心异常向量的名字
  • 使用RTOS内核的设备无关接口,包括调试模式

CMSIS包含了Cortex-M4处理器核心外设的地址和数据结构定义

简化了软件开发过程

本文图表引用自《PM0214: STM32F3, STM32F4 and STM32L4 Series Cortex®-M4 programming manual》

本文参考ST官方文档《PM0214: STM32F3, STM32F4 and STM32L4 Series Cortex®-M4 programming manual》

STM32F4 编程手册学习1_编程模型的更多相关文章

  1. STM32F4编程手册学习2_内存模型

    STM32F4编程手册学习2_内存模型 1. 内存映射 MCU将资源映射到一段固定的4GB可寻址内存上,如下图所示. 内存映射将内存分为几块区域,每一块区域都有一个定义的内存类型,一些区域还有一些附加 ...

  2. 《ASP.NET MVC4 WEB编程》学习笔记------Model模型绑定

    本文转载自haiziguo Asp.net mvc中的模型绑定,或许大家经常用,但是具体说他是怎么一回事,可能还是会有些陌生,那么,本文就带你理解模型绑定.为了理解模型绑定,本文会先给出其定义,然后对 ...

  3. Python学习---网络编程 1217【all】

    OSI七层模型: 物理层, 数据链路层, 网络层,传输层,会话层,表达层,应用层 应用层:TFTP,HTTP,SNMP,FTP,SMTP,DNS,Telnet 等等 传输层:TCP,UDP 网络层:I ...

  4. Java学习疑惑(8)----可视化编程, 对Java中事件驱动模型的理解

    我们编写程序就是为了方便用户使用, 我觉得UI设计的核心就是简洁, 操作过于繁琐的程序让很大一部分用户敬而远之. 即使功能强大, 但是人们更愿意使用易于操作的软件. 近年流行起来的操作手势和逐渐趋于成 ...

  5. pthread多线程编程的学习小结

    pthread多线程编程的学习小结  pthread 同步3种方法: 1 mutex 2 条件变量 3 读写锁:支持多个线程同时读,或者一个线程写     程序员必上的开发者服务平台 —— DevSt ...

  6. 《Linux/Unix系统编程手册》读书笔记8 (文件I/O缓冲)

    <Linux/Unix系统编程手册>读书笔记 目录 第13章 这章主要将了关于文件I/O的缓冲. 系统I/O调用(即内核)和C语言标准库I/O函数(即stdio函数)在对磁盘进行操作的时候 ...

  7. 《Linux/Unix系统编程手册》读书笔记7 (/proc文件的简介和运用)

    <Linux/Unix系统编程手册>读书笔记 目录 第11章 这章主要讲了关于Linux和UNIX的系统资源的限制. 关于限制都存在一个最小值,这些最小值为<limits.h> ...

  8. 《Linux/Unix系统编程手册》读书笔记1

    <Linux/Unix系统编程手册>读书笔记 目录 最近这一个月在看<Linux/Unix系统编程手册>,在学习关于Linux的系统编程.之前学习Linux的时候就打算写关于L ...

  9. 有一定基础的 C++ 学习者该怎样学习 Windows 编程?

    人的心理有个奇异的特性:一项知识一旦学会之后,学习过程中面临的困惑和不解非常快就会忘得干干净净,似乎一切都是自然而然,本来就该这种.因此,关于「怎样入门」这类问题,找顶尖高手来回答,未必能比一个刚入门 ...

随机推荐

  1. 浅谈vue,小程序,react基础绑定值

    最近一直在用react开发项目,碰见的问题千千万,很多,但是都殊途同源,唯一区别大的就是没有像vue的双向绑定,也没有小程序的单向方便,比如: vue   v-modal="msg" ...

  2. 【rabbitmq消息队列配置】

    #erlang语言支持包 #rabbitmq-server安装支持 #添加用户 #删除用户 #用户角色 #启动 #登录 #管理界面 #guest登录不了: Rabbitmq.conf文件添加 #开启管 ...

  3. Hadoop原理之——HDFS原理

    Hadoop 3个核心组件: 分布式文件系统:Hdfs——实现将文件分布式存储在很多的服务器上(hdfs是一个基于Linux本地文件系统上的文件系统) 分布式运算编程框架:Mapreduce——实现在 ...

  4. 网站用户行为分析——HBase的安装与配置

    Hbase介绍 HBase是一个分布式的.面向列的开源数据库,源于Google的一篇论文<BigTable:一个结构化数据的分布式存储系统>.HBase以表的形式存储数据,表有行和列组成, ...

  5. Python学习1——关于变量

    在python中,使用变量之前不需要声明变量的数据类型, 但是,使用变量前,必须要先对变量进行赋值: 例: num01 += 100 print('num01') 上述例子中,表示的意思是 num01 ...

  6. (数据科学学习手札43)Plotly基础内容介绍

    一.简介 Plotly是一个非常著名且强大的开源数据可视化框架,它通过构建基于浏览器显示的web形式的可交互图表来展示信息,可创建多达数十种精美的图表和地图,本文就将以jupyter notebook ...

  7. [AGC011F] Train Service Planning [线段树优化dp+思维]

    思路 模意义 这题真tm有意思 我上下楼梯了半天做出来的qwq 首先,考虑到每K分钟有一辆车,那么可以把所有的操作都放到模$K$意义下进行 这时,我们只需要考虑两边的两辆车就好了. 定义一些称呼: 上 ...

  8. CLR via C#读书笔记二:类型基础

    1.CLR允许将对象转换为它的(实际)类型或者它的任何基类型. 2.is操作符检测对象是否兼容于指定类型,is操作符永远不抛出异常. 3.as操作符返回对同一个对象的非null引用.如果对象不兼容,a ...

  9. JAVA面试中问及HIBERNATE与 MYBATIS的对比

    第一方面:开发速度的对比 就开发速度而言,Hibernate的真正掌握要比Mybatis来得难些.Mybatis框架相对简单很容易上手,但也相对简陋些.个人觉得要用好Mybatis还是首先要先理解好H ...

  10. Altium designer18设置原理图尺寸

    1. AD18版本设置原理图尺寸和以前版本不一样,具体是在界面右侧Properties里面的Sheet Sizes.