STM32F4xx学习笔记
STM32F4xx_DSP_StdPeriph_Lib_V1.0.1文件夹里面里面Libraries里面文件介绍:
CMSIS文件夹:主要包含于内核相关的文件
STM32F4xx_StdPeriph_Driver文件夹:STM32F4xx处理器外设相关的底层驱动。
CMSIS里面文件介绍: Device文件夹包含以下文件
stm32f4xx.h:包含了stm32f4的寄存器结构体的定义(类似于c51的reg52.h)
system_stm32f4xx.h:system_stm32f4xx.c的头文件
startup_stm32f4xx.s:是启动文件,是一个汇编文件。作用包括: 1. 设定SP的初始值 2. 设置PC的初始值 3. 设置中断向量表的地址 4. 配置时钟 5. 设置堆栈 6. 调用main等
这个启动文件先调用system_stm32f4xx.c里面的systeminit()在调用main()之前。
core_cm4.h:内核功能的定义,比如NVIC相关寄存器的结构体和Systick配置。
core_cm4_simd.h:包含与编译器相关的处理。 core_cmFunc.h:内核核心功能接口头文件。 core_cmInstr.h:包含一些内核核心专用指令。 SYSCFG(系统配置控制模块)功能模块:
注意:想要操作SYSCFG模块寄存器必须先使能SYSCFG模块时钟,RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE); 这个模块主要有以下功能:
1.利用SYSCFG_EXTILineConfig()函数配置外部中断连接至那个GPIO和该I/O口的那个引脚。
2.当GPIO得速度超过50M的时候就要使用I/O补偿单元以较小I/O的电源噪音只有当供电电压在2.4V-3.6V时才能使用此功能。 即:SYSCFG_CompensationCellCmd(ENABLE)。
3. 利用SYSCFG_MemoryRemapConfig()函数重新定义进入代码区域的存储器即:选择哪种启动模式。 补:启动配置
在STM32F4xx中可以通过BOOT[1:0]引脚选择三种不同启动模式。
在系统复位后,SYSCLK的第4个上升沿,BOOT引脚的值将被锁存。用户可以通过设置BOOT1引脚的状态,来选择在复位后的启动模式。 在启动延迟之后,CPU从地址0x0000 0000获取堆栈顶的地址,并
从启动存储器的0x0000 0004指示的地址开始执行代码。
因为固定的存储器映像,代码区始终从地址0x0000 0000开始(通过ICode和DCode总线访问),而数据区(SRAM)始终从地址0x2000 0000开始(通过系统总线访问)。Cortex-M3的CPU始终从ICode总线获取复位向量,即启动仅适合于从代码区开始(典型地从Flash启动)。根据选定的启动模式,主闪存存储器、系统存储器或SRAM可以按照以下方式访问:
(1)从主闪存存储器启动:主闪存存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的地址(0x0800 0000)访问它,即闪存存储器的内容可以在两个地址区域访问,0x0000 0000或0x0800 0000。
(2) 从系统存储器启动:系统存储器被映射到启动空间(0x0000 0000),但仍然能够在它原有的地址(原有地址为0x1FFF F000)访问它。
(3) 从内置SRAM启动:只能在0x2000 0000开始的地址区访问SRAM。
注意:当从内置SRAM启动,在应用程序的初始化代码中,必须使用NVIC的异常表和偏移寄存器,从新映射向量表之SRAM中。 4.利用SYSCFG_ETH_MediaInterfaceConfig()函数选择ETHERNET media的接口。
STM32F407时钟介绍(RCC) 系统时钟(SYSCLK)的介绍
STM32F407最高层是SYSCLK系统时钟,由其生成了 AHB时钟,再由AHB时钟生成APB时钟。 系统时钟的来源: 系统时钟有三个来源: 1. 内部告诉晶体(16MHZ)。 2. 外部告诉晶体(4-26MHZ)。 3. PLL输出(PLLCLK)。 PLLCLK的时钟来源

