- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
S3C2410GPIO及AD转换
第5章 嵌入式系统输入/输出设备接口;5.1 GPIO(通用输入/输出接口);5.1.1 GPIO原理与结构;图5.1.1 双向GPIO功能逻辑图;DDR设置端口的方向。如果DDR的输出为1,则GPIO端口为输出形式;如果DDR的输出为零,则GPIO端口为输入形式。写入WR—DDR信号能够改变DDR的输出状态。DDR在微控制器地址空间中是一个映射单元。这种情况下,如果需要改变DDR,则需要将恰当的值置于数据总线的第0位(即D0),同时激活WR—DDR信号。读DDR,就能得到DDR的状态,同时激活RD—DDR信号。
如果设置PORT引脚端为输出,则PORT寄存器控制着该引脚端状态。如果将PORT引脚端设置为输入,则此输入引脚端的状态由引脚端上的逻辑电路层来实现对它的控制。对PORT寄存器的写操作,需要激活WR—PORT信号。PORT寄存器也映射到微控制器的地址空间。需指出,即使当端口设置为输入时,如果对PORT寄存器进行写操作,并不会对该引脚产生影响。但从PORT寄存器的读出,不管端口是什么方向,总会影响该引脚端的状态。;5.1.2 S3C2410A输入/输出端口编程实例;下面介绍一个通过G口的控制发光二极管LED1和LED2轮流闪烁I/O口编程实例[徐英慧]。
对I/O口的操作是通过对相关各个寄存器的读/写实现的。要对寄存器进行读/写操作,首先要对寄存器进行定义。有关I/O口相关寄存器的宏定义代码如下:
//Port A控制寄存器
#definerGPACON (*(volatile unsigned*)0
//Port A数据寄存器
#definerGPADAT (*(volati1e unsigned*)0
//Port B控制寄存器
#definerGPBCON (*(volatile unsigned*)0
//Port B数据寄存器
#definerGPBDAT (*(volatile unsigned*)0
//Port B上拉电阻禁止寄存器
#definerGPBUP (*(volatile unsigned*)0;//Port C控制寄存器
#definerGPCCON (*(volatile unsigned*)0
//Port C数据寄存器
#definerGPCDAT (*(volatile unsigned*)0
//Port C上拉电阻禁止寄存器
#definerGPCUP (*(volatile unsigned*)0
//Port D控制寄存器
#definerGPDCON (*(volatile unsigned*)0
//Port D数据寄存器
#definerGPDDAT (*(volatile unsigned*)0
//Port D上拉电阻禁止寄存器
#definerGPDUP (*(volatile unsigned*)0;//Port E控制寄存器
#definerGPECON (*(volatile unsigned*)0
//Port E数据寄存器
#definerGPEDAT (*(volatile unsigned*)0
//Port E上拉电阻禁止寄存器
#definerGPEUP (*(volatile unsigned*)0
//Port F控制寄存器
#definerGPFCON (*(volatile unsigned*)0
//Port F数据寄存器
#definerGPFDAT (*(volatile unsigned*)0
//Port F上拉电阻禁止寄存器
#definerGPFUP (*(volatile unsigned*)0;//Port G控制寄存器
#definerGPGCON (*(volati1e unsigned*)0
//Port G数据寄存器
#definerGPGDAT (*(volatile unsigned*)0
//Port G上拉电阻禁止寄存器
#definerGPGUP (*(volatile unsigned*)0
//Port H控制寄存器
#definerGPHCON (*(volatile unsigned*)
文档评论(0)