STM32F系列属于中低端的32位ARM微控制器,该系列芯片是意法半导体(ST)公司出品,其内核是Cortex-M3 [1] 。
该系列芯片按片内Flash的大小可分为三大类:小容量(16K和32K)、中容量(64K和128K)、大容量(256K、384K和512K)。
芯片集成定时器Timer,CAN,ADC,SPI,I2C,USB,UART等多种外设功能。
为了保证CPU执行指令时可正确访问存储单元,需将用户程序中的逻辑地址转换为运行时由机器直接寻址的物理地址,这一过程称为地址映射。

| 数据总线 | 在CPU和RAM之间来回传送需要处理或者是需要储存的数据 |
| 地址总线 | 指定在RAM之中储存的数据的地址 |
| 控制总线 | 将微处理器控制单元的信号传送到周边设备 |
| 扩展总线 | 可连接槽和电脑 |
| 局部总线 | 取代更高速数据传输的扩展总线 |

- 存储器本身不具有地址信息,它的地址是由芯片厂商或用户分配,给存储器分配地址的过程就称为存储器映射。
- 存储器映射→寄存器映射
- 在存储器Block2 这块区域,设计的是片上外设,它们以四个字节为一个单元,共32bit,每一个单元对应不同的功能,当我们控制这些单元时就可以驱动外设工作。我们可以找到每个单元的起始地址,然后通过C 语言指针的操作方式来访问这些单元,如果每次都是通过这种地址的方式来访问,不仅不好记忆还容易出错,这时我们可以根据每个单元功能的不同,以功能为名给这个内存单元取一个别名,这个别名就是我们经常说的寄存器,这个给已经分配好地址的有特定功能的内存单元取别名的过程就叫寄存器映射。

- 补充:如果给存储器再分配一个地址就叫存储器重映射。
| GPIOB_CRL | 0x4001 0C00 |
| GPIOB_CRH | 0x4001 0C04 |
| GPIOB_IDR | 0x4001 0C08 |
| GPIOB_ODR | 0x4001 0C0C |
| GPIOH_BSRR | 0x4001 0C10 |
| GPIOH_BRR | 0x4001 0C14 |
| GPIOH_LCKR | 0x4001 0C18 |
GPIO 是通用输入输出端口的简称,简单来说就是 STM32 可控制的引脚,STM32芯片的GPIO引脚与外部设备连接起来,从而实现与外部通讯、控制以及数据采集的功能。STM32 芯片的GPIO被分成很多组,每组有16个引脚,如型号为 STM32F103VET6型号的芯片有GPIOA、GPIOB、GPIOC至GPIOE共5组GPIO,芯片一共100个引脚,其中GPIO就占了一大部分,所有的GPIO引脚都有基本的输入输出功能。

| 输入类 | 模拟/浮空/上拉/下拉 |
| 输出类 | 推挽/开漏 |
| 复用类 | 推挽/开漏 |
| HSI | 高速内部时钟 | 8MHz |
| HSE | 高速外部时钟 | 4MHz~16MHz |
| LSI | 低速内部时钟 | 40kHz |
| LSE | 低速外部时钟 | 32.768kHz |
| PLL | 锁相环倍频输出 | 输出频率最大不得超过72MHz |
程序刚启动的时候,stm32采用的为内部高速时钟。如果需要采用外部时钟,需要按照如下的方式配置:
1、时钟初始化,即将时钟的寄存器采用默认值。
2、开始外部时钟且外部时钟起震准备就绪。
3、设置PLLXTPRE(只能在关闭PLL时才能写入此位),可选择分频不分频。
4、设置进入PLL的源时钟(只能在关闭PLL时才能写入此位)。因为采用外部时钟所以只有一种设置。
5、设置PLL倍频系数PLLMUL(只有在PLL关闭的情况下才可被写入)。
6、开启PLL,且准备就绪。
7、设置SW,选择时钟源为系统时钟。
8、判断是否是预选的时钟为系统时钟。
在GPIO简介处罗列了输入输出的八种模式,现在对这八种模式进行详细的介绍

| 上拉输入模式 | 在默认状态下(GPIO引脚无输入),读取得的GPIO引脚数据为1,高电平 | 与VDD相连的为上拉电阻。再连接到施密特触发器就把电压信号转化为1的数字信号存储在输入数据寄存器(IDR) |
| 下拉输入模式 | 在默认状态下(GPIO引脚无输入),读取得的GPIO引脚数据为0,低电平 | 与VSS相连的为下拉电阻。再连接到施密特触发器就把电压信号转化为0的数字信号存储在输入数据寄存器(IDR) |
| 浮空输入模式 | 配置成这个模式直接用电压表测量其引脚电压为1点几伏,这是个不确定值 | 没有接上拉,也没有接下拉电阻,经由触发器输入 |
| 模拟输入模式 | 把电压信号传送到片上外设模块,如传送至给ADC模块,由ADC采集电压信号 | 关闭了施密特触发器,不接上、下拉电阻 |
| 普通推挽输出 | 推挽输出的供电平为0伏,高电平为3.3伏 | 在输出高电平时,P-MOS导通,低电平时,N-MOS管导通。两个管子轮流导通,一个负责灌电流,一个负责拉电流,使其负载能力和开关速度都比普通的方式有很大的提高 |
| 普通开漏输出 | 控制输出为0,低电平;若控制输出为1,为高阻态 | 如果我们控制输出为0,低电平,则使N-MOS管导通,使输出接地,若控制输出为1 (无法直接输出高电平),则既不输出高电平,也不输出低电平,为高阻态。 |
| 复用推挽输出 | GPIO的引脚用作串口的输出 | |
| 复用开漏输出 | 用在IC、SMBUS这些需要线与功能的复用场合 |
GPIO的输出速率:GPIO电平每秒切换的最大次数
面包板是由于板子上有很多小插孔,专为电子电路的无焊接实验设计制造的。由于各种电子元器件可根据需要随意插入或拔出,免去了焊接,节省了电路的组装时间,而且元件可以重复使用,所以非常适合电子电路的组装、调试和训练。
3.设计思路


6.实验结果
举报
更多回帖