STM32学习笔记 —— 1.1 什么是寄存器(概念分析)
问题引入:
用一句话回答以下问题:
- 什么是寄存器?
- 什么是寄存器映射?
- 什么是存储器映射?
(本章重点在 1.1.3 和 1.1.4)
1.1 STM32芯片实物图
(图)
- 学会看丝印图
- 芯片型号、内核提供商等其他信息
- 学会辨别正方向(芯片上的小圆点与PCB上的小圆点对应)
- 以小圆点为基础,逆时针旋转,从1号引脚开始递增(图)
- 如果芯片上没有小圆点,那么就把丝印图正对着自己,左上角的引脚为1号引脚,同样逆时针旋转递增。
- 所有芯片的引脚排列都是逆时针的,无论是LQFP还是DIP封装的。
1.2 STM32芯片架构简图
(图)
芯片主要是由内核和外设组成。
内核(主控制器):
- Cortex - M4内核(由Arm公司设计)用于控制外设。
外设(从控制器):
- Flash、Sram、USART、GPIO、IIC、SPI等(由Soc公司设计)
总线:
内核与外设通过总线连接,其分为:I(指令)、S(系统)、D(数据)总线。
几个总线同时访问某个外设或者内核,产生竞争的时候,总线矩阵会使用调度算法进行仲裁。
STM32F42xx的总线接口
(图)
- 黄色为主控制器,红色为从控制器。
- 指令总线主要访问Flash,程序可以从内置Flash、外置Flash和Sram中启动。
- 总线交叉处有圆点,说明可以连接,例如:程序只能存储在Sram1中,不能存储在Sram2中。
- 数据总线主要用于取常量。常量的存储区域和程序的存储区域是一样的。
- 系统总线主要访问Sram和寄存器。
1.3 存储器映射
存储器本身是不具有地址信息的,地址信息是由用户或者厂商分配的,为存储器重新分配地址的过程即为存储器映射。
Cortex - M4内核是32位的,可以寻址2的32次方,也就是4GB(0x0000 0000 - 0xFFFF FFFF)的内存空间,
这4GB的内存空间被分成了8个Block,每个Block都有特定的功能,每个Block大小为512MB。(教程里有每个Block的功能划分)
Block0用于设计Flash,429IGT6只用了1MB。
Block1用于设计Sram,用于存储变量,429IGT6用了256KB,被分成了三个部分:Sram1为112KB,Sram2为16KB,Sram3为64KB。
Block2用于设计片上外设。外设根据速度不同被分成四条总线进行控制:AHB1、AHB2、APB2、APB1。
(图)
Block3是FMC的bank1 - bank2,用于扩展外部存储,一个bank为256MB,板上拓展了一个大小为8MB的Sram。
Block4是FMC的bank3 - bank4
- 四个bank通过一个片选信号控制四片拓展芯片 。
Block5用于FMC
Block6用于FMC
Block7为Cortex - M4的内部外设,是由Arm公司设计的,如:NVIC等。
通过地址和偏移量间接访寄存器。
1.4 寄存器映射
问题引入:
- 如何通过控制寄存器的方法,让GPIOH的16个引脚均输出高电平?
通过绝对地址访问内存单元:
//GPIO端口全部输出高电平
*(unsigned int *)(0x40021C14) = 0xFFFF;
0x40021C14是输出数据寄存器OCR的地址,如何找到?
- 在《STM32中文参考手册》2.3.1 嵌入式SRAM这节中,可以查到GPIOH外设的起始地址为0x4002 1c00。
- 在 7.4.6 GPIO端口输出数据寄存器这节中,可以查到偏移地址为0x14。
(unsigned int *)的作用是什么?
- 0x4002 1c14是我们人为理解的地址,但是直接写在程序中,只是一串十六进制常量,需要将其强制类型转换为指针类型,才能使用间接访问运算符访问该地址内存的数据。
通过寄存器别名方式访问内存单元:
#define GPIOH_ODR *(unsigned int *)(0x40021C13)
GPIOH_ODR = 0XFF;
什么是寄存器?
- 给具有特定功能的内存单元取一个别名,这个别名就是寄存器,给已经分配好地址的特定内存单元取别名的过程叫做寄存器映射。
什么是存储器映射?
- 给存储器分配地址的过程叫做存储器映射,再分配一个地址的过程叫做重映射。
STM32学习笔记 —— 1.1 什么是寄存器(概念分析)的更多相关文章
- STM32学习笔记——点亮LED
STM32学习笔记——点亮LED 本人学习STM32是直接通过操作stm32的寄存器,使用的开发板是野火ISO-V2版本: 先简单的介绍一下stm32的GPIO: stm32的GPIO有多种模式: 1 ...
- STM32学习笔记(四)——串口控制LED(中断方式)
目录: 一.时钟使能,包括GPIO的时钟和串口的时钟使能 二.设置引脚复用映射 三.GPIO的初始化配置,注意要设置为复用模式 四.串口参数初始化配置 五.中断分组和中断优先级配置 六.设置串口中断类 ...
- STM32学习笔记-NVIC中断知识点
STM32学习笔记-NVIC中断知识点总结 中断优先级设置步骤 1. 系统运行后先设置中断优先级分组 函数:void NVIC_PriorityGroupConfig(uint32_tNVIC_Pri ...
- STM32学习笔记——OLED屏
STM32学习笔记--OLED屏 OLED屏的特点: 1. 模块有单色和双色可选,单色为纯蓝色,双色为黄蓝双色(本人选用双色): 2. 显示尺寸为0.96寸 3. 分辨率为128*64 4. ...
- stm32学习笔记----双串口同时打开时的printf()问题
stm32学习笔记----双串口同时打开时的printf()问题 最近因为要使用串口2外接PN532芯片实现通信,另一方面,要使用串口1来将一些提示信息输出到上位机,于是重定义了printf(),使其 ...
- stm32学习笔记——外部中断的使用
stm32学习笔记——外部中断的使用 基本概念 stm32中,每一个GPIO都可以触发一个外部中断,但是,GPIO的中断是以组为一个单位的,同组间的外部中断同一时间只能使用一个.比如说,PA0,PB0 ...
- STM32学习笔记之一(初窥STM32)
怎么做好学习笔记? 答:自我感知-->学习知识-->归纳总结-->自我升华(真正属于自己的知识是,抛开书本,运用时,你还能记得的思想) 自我感知--看到知识概念,先自我感觉那应该是个 ...
- STM32学习笔记(一)——点亮一个LED
引言 最近报名了2017全国大学生电子设计竞赛,我们学校是第一次参加这个比赛,由于8/9月份就要比赛了,所以现在准备是比较晚的了,指导老师说只能做控制类的题目了,让我们学习一下STM32单片机,51到 ...
- STM32学习笔记(二) 基于STM32-GPIO的流水灯实现
学会了如何新建一个工程模板,下面就要开始动手实践了.像c/c++中经典的入门代码"hello world"一样,流水灯作为最简单的硬件设备在单片机领域也是入门首推.如果你已经有了一 ...
随机推荐
- Linux 系统管理——系统安全及应用
chagen -d 0 ____用户名:下次登录时必须修改密码 ctrl+R:查看历史记录 history:查看历史记录 清除历史记录: >.bash _history echo“”>.b ...
- Linux 系统管理——进程和计划任务管理
一. 程序和进程关系 1.程序 保存硬盘.光盘等介质中的可执行代码和数据 静态保存的代码 2.进程 在CPU及内存运行的程序代码 动态执行的代码 父.子进程:每一个进程可以创建一个或多个进程 二.静 ...
- Fluent的summary功能
在Fluent计算当中,出现错误,大家经常在求助的时候问得很笼统和宽泛,这里介绍一下Fluent的summary功能,大家可以在求助的时候附上生成的文件,这样更加便于别人帮助你发现问题 然后在算例目录 ...
- Excel多表头设置二级联动选择
1.初始准备 2.全选,然后开始 -> 查找和选择 -> 定位条件 3.公式 -> 根据所选内容创建 因为一级联动数据在第一行,所以选首行 4.因为学校信息与联动数据不在同一个she ...
- mysql左连接查询结果不准确
现有四张表 表(1)res_resource_catalog 表(2)res_catalog_classify 表(3)res_resource_classify 表(4)res_resource_m ...
- 苹果手机微信浏览器select标签选择完成之后页面不会自动回到原位
说明: html默认select选择框控件在IOS的浏览器中 是底部弹出下拉选择. 这样到时页面位置错位,选择结束后对应不少元素的点击事件不响应. 这样看起来问题不大,但是选择完成之后点击确定提交弹出 ...
- dubbo源码分析- 集群容错之Cluster(一)
1.集群容错的配置项 failover - 失败自动切换,当出现失败,重试其他服务器(缺省),通常用于读操作,但重试会带来更长的延时. failfast - 快速失效,只发起一次调用,失败立即报错.通 ...
- pom.xml activatedProperties --spring.profiles.active=uat 对应
<profiles> <profile> <id>dev</id> <properties> <!-- 环境标识,需要与配置文件的名称 ...
- SwiftUI or Flutter ?
看到这篇好文,忍不住想分享一下 本文转自https://juejin.im/post/5d05b45bf265da1bcc193ff4 版权归原文所有 ------------------------ ...
- 【小实现】css after+border实现标签半菱形
<!DOCTYPE html> <html lang="en"> <head> <style> .span-line-begin { ...