基于ARM的单片机应用及实践课件-第五章.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《基于ARM的单片机应用及实践课件-第五章.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 ARM 单片机 应用 实践 课件 第五
- 资源描述:
-
1、第五章第五章 GPIO及外部中断的使用及外部中断的使用5.1 综述综述通用通用IO复位期间和刚复位后,复用功能未开启,I/O端口被配置成浮空输入模式(CNFx1:0=01b,MODEx1:0=00b)。复位后,JTAG引脚被置于输入上拉或下拉模式:PA15:JTDI置于上拉模式PA14:JTCK置于下拉模式PA13:JTMS置于上拉模式PB4: JNTRST置于上拉模式单独的位设置或位清除单独的位设置或位清除当对GPIOx_ODR的个别位编程时,软件不需要禁止中断:在单次APB2写操作里,可以只更改一个或多个位。这是通过对“置位/复位寄存器”(GPIOx_BSRR,复位是 GPIOx_BRR)
2、中想要更改的位写1来实现的。没被选择的位将不被更改。5.1 综述综述外部中断外部中断/唤醒线唤醒线所有端口都有外部中断能力。为了使用外部中断线,端口必须配置成输入模式。5.1 综述综述软件重新映射软件重新映射I/O复用功能复用功能为了使不同器件封装的外设I/O功能的数量达到最优,可以把一些复用功能重新映射到其他一些脚上。这可以通过软件配置相应的寄存器来完成(参考AFIO寄存器描述)。这时,复用功能就不再映射到它们的原始引脚上了。GPIO锁定机制锁定机制锁定机制允许冻结IO配置。当在一个端口位上执行了所定(LOCK)程序,在下一次复位之前,将不能再更改端口位的配置。5.1 综述综述复用功能复用功
3、能(AF)使用默认复用功能前必须对端口位配置寄存器编程。对于复用的输入功能,端口必须配置成输入模式(浮空、上拉或下拉)且输入管脚必须由外部驱动对于复用输出功能,端口必须配置成复用功能输出模式(推挽或开漏)。对于双向复用功能,端口位必须配置复用功能输出模式(推挽或开漏)。这时,输入驱动器被配置成浮空输入模式。5.1 综述综述输入配置当I/O端口配置为输入时:输出缓冲器被禁止施密特触发输入被激活根据输入配置(上拉,下拉或浮动)的不同,弱上拉和下拉电阻被连接出现在I/O脚上的数据在每个APB2时钟被采样到输入数据寄存器对输入数据寄存器的读访问可得到I/O状态输出配置输出配置当I/O端口被配置为输出时
4、:输出缓冲器被激活施密特触发输入被激活弱上拉和下拉电阻被禁止出现在I/O脚上的数据在每个APB2时钟被采样到输入数据寄存器在开漏模式时,对输入数据寄存器的读访问可得到I/O状态在推挽式模式时,对输出数据寄存器的读访问得到最后一次写的值。5.1 综述综述复用功能配置复用功能配置5.1 综述当I/O端口被配置为复用功能时:在开漏或推挽式配置中,输出缓冲器被打开内置外设的信号驱动输出缓冲器(复用功能输出)密特触发输入被激活弱上拉和下拉电阻被禁止在每个APB2时钟周期,出现在I/O脚上的数据被采样到输入数据寄存器开漏模式时,读输入数据寄存器时可得到I/O口状态在推挽模式时,读输出数据寄存器时可得到最后
5、一次写的值模拟输入配置当I/O端口被配置为模拟输入配置时:输出缓冲器被禁止;禁止施密特触发输入,实现了每个模拟I/O引脚上的零消耗。施密特触发输出值被强置为0;弱上拉和下拉电阻被禁止;读取输入数据寄存器时数值为0。5.1 综述5.2 库函数库函数具体函数用法详情见STM32固件库使用手册5.3 IO端口的外设端口的外设把把OSC32_IN/OSC32_OUT作为作为GPIO 端口端口PC14/PC15当LSE振荡器关闭时,LSE振荡器引脚OSC32_IN/OSC32_OUT可以分别用做GPIO的PC14/PC15,LSE功能始终优先于通用I/O口的功能。把把OSC32_IN/OSC32_OUT
6、作为作为GPIO 端口端口PC14/PC15外部振荡器引脚OSC_IN/OSC_OUT可以用做GPIO的PD0/PD1,通过设置复用重映射和调试I/O配置寄存器(AFIO_MAPR)实现。这个重映射只适用于36、48和64脚的封装(100脚和144脚的封装上有单独的PD0和PD1的引脚,不必重映射)。5.3 IO端口的外设端口的外设5.3 IO端口的外设端口的外设CAN复用功能重映射复用功能重映射CAN信号可以被映射到端口A、端口B或端口D上,如下表所示。对于端口D,在36、48和64脚的封装上没有重映射功能。5.3 IO端口的外设端口的外设JTAG/SWD复用功能重映射复用功能重映射调试接口
7、信号被映射到GPIO端口上,如下表所示。表 调试接口信号5.3 IO端口的外设端口的外设表 调试端口映像5.3 IO端口的外设端口的外设ADC复用功能重映射复用功能重映射ADC1外部触发注入转换复用功能重映射(1)ADC1外部触发规则转换复用功能重映射(1)ADC2外部触发注入转换复用功能重映射(1)5.3 IO端口的外设端口的外设ADC2外部触发规则转换复用功能重映射(1)定时器复用功能重映射定时器复用功能重映射5.3 IO端口的外设端口的外设定时器4的通道1到通道4可以从端口B重映射到端口D。其他定时器的重映射列在下表。参见复用重映射和调试I/O配置寄存器(AFIO_MAPR)定时器5复用
8、功能重映像(1)定时器4复用功能重映像5.3 IO端口的外设端口的外设定时器3复用功能重映像定时器2复用功能重映像定时器1复用功能重映像5.3 IO端口的外设端口的外设5.3 IO端口的外设端口的外设USART复用功能重映射USART3重映像USART2重映像5.3 IO端口的外设端口的外设USART1重映像5.3 IO端口的外设端口的外设I2C 1 复用功能重映射复用功能重映射I2C 1重映像SPI 1复用功能重映射复用功能重映射SPI1重映像5.4 位运算位运算 左移运算符()左移运算符()左移位相当于该数乘以,左移位相当于该数乘以22,152=60,即乘了。但此结论只适用于该数左移时被溢
9、出舍弃的高位中不包含的情况。假设以一个字节(位)存一个整数,若为无符号整型变量,则时,左移一位时溢出的是,而左移位时,溢出的高位中包含。右移运算符右移运算符()右移运算符是a2表示将a的各二进制位右移2位,移到右端的低位被舍弃,对无符号数,高位补0。例如:a=017时:a的值用二进制形式表示为00001111, 舍弃低2位11: a2=00000011右移一位相当于除以2 右移n位相当于除以2n。5.4 位运算位运算5.4 位运算位运算“按位与按位与”运算符()运算符()按位与是指:参加运算的两个数据,按二进制位进行“与”运算。如果两个相应的二进制位都为,则该位的结果值为;否则为。即:,例:并
10、不等于,应该是按位与运算: 00000011(3)& & 00000101(5) 00000001(1) 注意:如果参加如果参加&运算的是负数运算的是负数(如(如-3&-5),则要以补码形式),则要以补码形式表示为二进制数,然后再按位表示为二进制数,然后再按位进行进行“与与”运算。运算。3&5的值得5.4 位运算位运算“按位或按位或”运算符(运算符(|)两个相应的二进制位中只要有一个为,该位的结果值为。即 |,|,|,|例: 060|017,将八进制数60与八进制数17进行按位或运算。 00110000| 00001111 00111111 “取反取反”运算符()运算符() 是一个单目(元)运
11、算符,用来对一个二进制数按位取反,即将变,将变。例如,是对八进制数(即二进制数)按位求反。 0000000000010101() 1111111111101010 (八进制数177752)5.4 位运算位运算“异或异或”运算符(运算符()5.4 位运算位运算异或运算符也称XOR运算符。它的规则是:若参加运算的两个二进制位同号则结果为(假)异号则结果为(真)即:00=0,01=1,10=1, 11=0 00111001 00101010 00010011 即:071052=023 (八进制数)5.5 GPIO控制实例控制实例控制LED闪烁跑马灯按键输入5.6 外部中断和中断控制器外部中断和中断控
展开阅读全文