曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 6801|回复: 0
打印 上一主题 下一主题

[2410] set_gpio_ctrl(x) 宏解析

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34395
跳转到指定楼层
楼主
发表于 2009-11-2 18:51:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
set_gpio_ctrl(x) 宏的具体定义如下
#define set_gpio_ctrl(x)
({
           GPCON(GRAB_PORT((x))) &= ~(0x3 << (GRAB_OFS((x))*2));
           GPCON(GRAB_PORT(x)) |= (GRAB_MODE(x) << (GRAB_OFS((x))*2));
           GPUP(GRAB_PORT((x))) &= ~(1 << GRAB_OFS((x)));
           GPUP(GRAB_PORT((x))) |= (GRAB_PULLUP((x)) << GRAB_OFS((x)));
})

http://www.groad.net/bbs/read.php?tid-1324.html
http://www.groad.net/bbs/read.php?tid-1325.html
http://www.groad.net/bbs/read.php?tid-1326.html
http://www.groad.net/bbs/read.php?tid-1328.html
已经对 GPCON() ,  GRAB_PORT() , write_gpio_bit(x,v) 以及更底层的 __REG() __REGP() 宏的分析。在 set_gpio_ctrl() 中比之前多了 GRAB_MODE(x) 和 GRAB_PULLUP(x) 两个宏。
GRAB_MODE(x) 和 GRAB_PULLUP(x) 的作用分别是从参数 x 中解析出 IO 口的模式和使能/屏蔽此端口的上拉电阻。值得注意的是,set_gpio_ctrl() 的参数不仅仅表示 GPIO 端口号,其高 16 位还带有模式状态和上拉电阻的控制信息,参数 x 的结构如下图:

低 16 位为前面所述的 GPIO 端口号,高 16 位中的 R 字段用来屏蔽/使能 I/O 的上拉电阻功能。
R=0,使能上拉电阻;
R=1,上拉电阻失效。

M 字段用来设置 IO 口的工作模式。
M=0, IO口为输入口;
M=1, IO口为输出口;
M=2, 可选功能 1;
M=3, 可选功能2。

set_gpio_ctrl() 宏就是通过写相应 GPIO 所在组的 GPxCON ( x 为 A~H )的相应位来设置 IO 口模式 (GPACON 每一个位控制一个 IO 口,而 GPBCON~GPHCON 都是两个位控制一个 IO 口的模式),通过写 GPxUP (x 为 A~H) 来决定是否启用上拉电阻。典型的 set_gpio_ctrl 调用方式如下:
set_gpio_ctrl(GPIO_MODE_OUT | GPIO_PULLUP_DIS | GPIO_G12);
这条语句将 GPG12 设置成输出模式,并且不使用端口的上拉电阻。

本文参考网上,感谢作者。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-5-4 01:57 , Processed in 0.061457 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表