STM32F4xx学习笔记.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
STM32F4xx学习笔记

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:是启动文件,是一个汇编文件。作用包括: 设定SP的初始值 设置PC的初始值 设置中断向量表的地址 配置时钟 设置堆栈 调用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时钟。 系统时钟的来源: 系统时钟有三个来源: 内部告诉晶体(16MHZ)。 外部告诉晶体(4-26MHZ)。 PLL输出(PLLCLK)。 PLLCLK的时钟来源 PLL时钟来源有两个 1.HSI/M 2.HSE/M Fvcoclk=Fpll input×(PLLN/PLLM) Fpll input=(HSE 或者HSI) Fpll generate clk output=Fvcoclk/PLLP F(usb otg fs,sdio,rng clock )=Fvcoclk/PLLQ PLLQ的取值范围:2≤PLLQ≤15 PLLP的取值:2、4、6、8 PLLN的取值:64≤PLLN≤432。 PLLM的取

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档