讲稿-08 通用输入输出口.pptVIP

  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文档。上传文档
查看更多
S3C2410A的通用I/O简介 在S3C2410A中,共有117个可以作为通用输入输出的引脚。总共分为8组,也就是8个端口。分别是: A组(23位的输出端口) B组(11位的输入输出端口) C组(16位的输入输出端口) D组(16位的输入输出端口) E组(16位的输入输出端口) F组(8位的输入输出端口) G组(16位的输入输出端口) H组(11位的输入输出端口) 这些引脚在硬件中的位置可以参考有关资料。由于不同封装形式对应引脚位置有差别,这里就不详细介绍了。 所有的这些引脚都是复用引脚,也就是每个引脚既可以作为通用引脚,也可以作为专用的,用于特定功能的引脚。而且有的引脚既可以作为输入,也可以作为输出,如何将这些引脚配置成通用输入输出引脚,和将这些引脚配置特定的输入输出方式,需要通过程序进行设置。下面就介绍与此有关的寄存器。 端口相关寄存器的概述 PORT CONFIGURATION REGISTER (GPACON-GPHCON) 端口配置寄存器决定了每个引脚的功能。 PORT DATA REGISTER (GPADAT-GPHDAT) 如果端口被配置为输出,那么可以通过写入写这些寄存器的值来控制相应的输出。 如果端口被配置为输入,那么可以通过读这些寄存器来得到相应的引脚的值。 PORT PULL-UP REGISTER (GPBUP-GPHUP) 端口上拉寄存器决定引脚是否允许上拉。 A组端口寄存器 B组端口寄存器 C组端口寄存器 D组端口寄存器 E组端口寄存器 F组端口寄存器 G组端口寄存器 H组端口寄存器 通用端口的应用举例 时间间隔采用循环语句完成。下面分析代码。 启动汇编代码: ResetEntry mov sp,#0 ;定义堆栈指针 IMPORT Main ;声明主函数Main BL Main ;调用主函数 这段代码非常简单,首先定义栈顶的初始指针。然后调用C语言的主函数Main。因为Main时其它文件定义的,故此需要IMPORT 伪指令。 延时代码 EXPORT delay delay sub r0,r0,#1 ;r0=r0-1 cmp r0,#0x0 ;将r0的值与0相比较 bne delay ;比较的结果不为0(r0不为0),继续调用delay,否则执行下一条语句 mov pc,lr ;返回 这段代码是将r0的内容不断减1,直到它变成0。显然,r0数据越大,延时越长。由于这个函数要被外文件使用,故此要使用EXPORT。 端口寄存器的表示。 #define rGPFCON (*(volatile unsigned *)0 这里定义了一个宏rGPFCON,该宏的表示了一个整型变量,该变量的类型是无符号整型,而该变量的地址是0也就是GPFCON寄存器的地址。 有了这样的宏定义后,可以象操作变量一样的对端口寄存器进行读写操作了。 volatile是一个C语言中的关键字,这里表示了表示对应变量所对应单元是端口,而非内存地址,有可能被意外改变。 #define LED1_ON() (rGPFDAT = ~0x10) 这个宏的作用是将F口的第4脚变为低电平,从而将第1管点亮。为什么不直接用rGPFDAT = ~0x10呢?因为这样做将其它管脚指也改变了。而rGPFDAT = ~0x10只是把第1引脚指改变,其它不变。 #define LED1_OFF() (rGPFDAT |= 0x10) 这个宏的作用是将F口的第4脚变为高电平,从而将第1管熄灭。原理同上。 rGPFCON=0x5500 将F口4,5,6,7脚置为输出脚。 rGPFUP=0xffff 禁止GPF端口的上拉 delay(0x2ffff)。调用了汇编语言的延迟函数。0x2ffff是参数值。根据C和汇编语言的作用机制,一个参数时,参数总是放在r0寄存器中。这样就和前面的汇编程序联系起来了。 程序的整体逻辑非常简单,就不加解释了。 0x5600000c 保留 0保留 未定义 端口数据寄存器 R/W 0GPADAT 0x7fffff 端口A配置寄存器 R/W 0 GPACON 复位值 描述 R/W 寄存器地址 寄存器名 0x5600001c 保留 0 端口B引脚上拉许可寄存器 R/W 0GPBUP 未定义 端口B数据寄存器 R/W 0GPBD

文档评论(0)

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

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

1亿VIP精品文档

相关文档