Chinaunix首页 | 论坛 | 博客
  • 博客访问: 127507
  • 博文数量: 153
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 882
  • 用 户 组: 普通用户
  • 注册时间: 2022-03-12 10:39
个人简介

不积小流,无以成江海。

文章分类

全部博文(153)

文章存档

2023年(50)

2022年(90)

我的朋友

分类: 嵌入式

2022-07-05 15:32:47

原文地址:
https://blog.csdn.net/Aresqing/article/details/47055755?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-47055755-blog-113838159.pc_relevant_aa&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-47055755-blog-113838159.pc_relevant_aa&utm_relevant_index=1

这些基础知识,搜了半天调用的地方也没有找到!
原来是汇编里面指定的。
无奈地转载了,以学习。

这个也挺好的。

STM32踩坑:关于 USARTx_IRQHandler() 函数的调用问题

https://blog.csdn.net/qq_36553707/article/details/113838159?spm=1001.2101.3001.6650.1&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-113838159-blog-94409599.pc_relevant_aa2&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-113838159-blog-94409599.pc_relevant_aa2&utm_relevant_index=2

比较好的部分:
在启动文件startup_stm32f10x_md.s中有这样一段代码,汇编
DCD USART1_IRQHandler
其中DCD是一条数据定义伪指令,用于分配一片连续的字存储单元并用指定的数据初始化。
还有一些如PUBWEAK USART1_IRQHandler等,具体意思不是很清楚。
库里定义 #define USART1 ((USART_TypeDef *) USART1_BASE)
同时 #define USART1_BASE (APB2PERIPH_BASE + 0x3800)
我个人的理解是,当配置好USART1的控制寄存器中断使能时,当发生中断(异常)时,该异常被Cortex-M3内核接受,对应的异常Handler就会执行。而这个响应过程都是硬件来完成的,当然为了决定Handler的入口地址,Cortex-M3使用了“向量表查表机制”。startup_stm32f10x_md.s启动文件已经为USART1_IRQHandler赋予了该地址。所以在异常发生后,CPU进入异常模式,同时程序计数器PC自动指向异常入口地址,也就是USART1_IRQHandler,进而执行中断服务函数中的应用。
————————————————
版权声明:本文为CSDN博主「Aresqing」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Aresqing/article/details/47055755




阅读(328) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~