一个爱徒步的~IT民工
20205
- 收藏
- 点赞
- 分享
- 举报
3520D 通用GPIO 使用篇(板子3G电源控制脚说明)
本帖最后由 david 于 2015-5-23 20:22 编辑
在一个嵌入式系统中使用最多的莫过于 通用输入输出 GPIO口。看到论坛中经常有朋友问海思为什么没有提供GPIO驱动。其实不然。
在海思SDK xxx/osdrv/tools/board_tools/reg-tools-1.0.0/source/tools/下 提供了himm的读写工具源码。
你也可以根据himm的源码来写一个文件设备操作的驱动。毕竟轮子已经有了,我们就没必要再去造轮子了。
这个工具是用来 配置海思寄存器的。当然可以稍加改造或者在应用直接使用来控制通用寄存器。
根据海思提供资料 ,配置一个通用GPIO需要做如下工作。
1. 参考“管脚复用控制寄存器”配置管脚的相应位,使能需要使用的 GPIO管脚功能。(这块大家自己去查复用寄存器表)
2. 配置寄存器 GPIO_DIR,选择 GPIO是作为输入还是输出。
GPIO用于输入:外部信号通过 GPIO 管脚送进来,此时可通过 GPIO_DATA 寄存器查看输入信号值。
注意:输入的信号会同时送到和 GPIO复用的管脚上。
GPIO用于输出:先向 GPIO_DATA 寄存器写入相应值后,再通过 GPIO输出写入值。
GPIO8 0x201D_0000
GPIO7 0x201C_0000
GPIO6 0x201B_0000
GPIO5 0x201A_0000
GPIO4 0x2019_0000
GPIO3 0x2018_0000
GPIO2 0x2017_0000
GPIO1 0x2016_0000
GPIO0 0x2015_0000
GPIOn对应的寄存器地址为:GPIOn基地址+该寄存器偏移地址。
下面是比较关键的一个问题:我们知道对GPIO_DATA的操作可以控制输出,如果DIR方向是输入,可以读取这个地址的值 。那么怎么进行位操作呢?
海思的手册给出如下解释。海思的DATA寄存器通过 一个10位的地址中的高8位进行位寻址。
比如我要操作
若地址为 0x3FC(0b11_1111_1100) ,则对 GPIO_DATA[7:0]这 8bit操作全部有效。
操作方式: 基地址+偏移地址 0x3FC就为便宜地址,如果对该地址的寄存器操作则对所有8个IO的控制有效。
若地址为 0x200(0b10_0000_0000) ,则仅对 GPIO_DATA[7]的操作有效。
另一个关键寄存器
GPIO_DIR 方向寄存器 偏移地至 0x400
下面举个栗子: (控制开发板3G电源)
比如控制GPIO0_1
基地址 GPIO0_BASE 0x2015_0000
GPIO_DIR = GPIO0_BASE + OFFSET(0x400) 0:输入 1:输出
则数据DATA寄存器地址 0b00_0000_1000 = 0x08
对了别忘了复用:
复用的基地址 0x200F0000 复用偏移地址 0x09c
该寄存器 bit0 控制复用 0 为GPIO 1为功能。
himm 0x200F009C 0
himm 0x20150400 2
himm 0x20150008 0xFF
附图:
3G_RST = RMII_TXD0 功能1 : GPIO0-2
3G_Power = RMII_TXEN 功能1: GPIO0-1
复用寄存器基地址 0x200F 0000
偏移地址
在一个嵌入式系统中使用最多的莫过于 通用输入输出 GPIO口。看到论坛中经常有朋友问海思为什么没有提供GPIO驱动。其实不然。
在海思SDK xxx/osdrv/tools/board_tools/reg-tools-1.0.0/source/tools/下 提供了himm的读写工具源码。
你也可以根据himm的源码来写一个文件设备操作的驱动。毕竟轮子已经有了,我们就没必要再去造轮子了。
这个工具是用来 配置海思寄存器的。当然可以稍加改造或者在应用直接使用来控制通用寄存器。
根据海思提供资料 ,配置一个通用GPIO需要做如下工作。
1. 参考“管脚复用控制寄存器”配置管脚的相应位,使能需要使用的 GPIO管脚功能。(这块大家自己去查复用寄存器表)
2. 配置寄存器 GPIO_DIR,选择 GPIO是作为输入还是输出。
GPIO用于输入:外部信号通过 GPIO 管脚送进来,此时可通过 GPIO_DATA 寄存器查看输入信号值。
注意:输入的信号会同时送到和 GPIO复用的管脚上。
GPIO用于输出:先向 GPIO_DATA 寄存器写入相应值后,再通过 GPIO输出写入值。
GPIO8 0x201D_0000
GPIO7 0x201C_0000
GPIO6 0x201B_0000
GPIO5 0x201A_0000
GPIO4 0x2019_0000
GPIO3 0x2018_0000
GPIO2 0x2017_0000
GPIO1 0x2016_0000
GPIO0 0x2015_0000
GPIOn对应的寄存器地址为:GPIOn基地址+该寄存器偏移地址。
下面是比较关键的一个问题:我们知道对GPIO_DATA的操作可以控制输出,如果DIR方向是输入,可以读取这个地址的值 。那么怎么进行位操作呢?
海思的手册给出如下解释。海思的DATA寄存器通过 一个10位的地址中的高8位进行位寻址。
比如我要操作
若地址为 0x3FC(0b11_1111_1100) ,则对 GPIO_DATA[7:0]这 8bit操作全部有效。
操作方式: 基地址+偏移地址 0x3FC就为便宜地址,如果对该地址的寄存器操作则对所有8个IO的控制有效。
若地址为 0x200(0b10_0000_0000) ,则仅对 GPIO_DATA[7]的操作有效。
另一个关键寄存器
GPIO_DIR 方向寄存器 偏移地至 0x400
下面举个栗子: (控制开发板3G电源)
比如控制GPIO0_1
基地址 GPIO0_BASE 0x2015_0000
GPIO_DIR = GPIO0_BASE + OFFSET(0x400) 0:输入 1:输出
则数据DATA寄存器地址 0b00_0000_1000 = 0x08
对了别忘了复用:
复用的基地址 0x200F0000 复用偏移地址 0x09c
该寄存器 bit0 控制复用 0 为GPIO 1为功能。
himm 0x200F009C 0
himm 0x20150400 2
himm 0x20150008 0xFF
附图:
3G_RST = RMII_TXD0 功能1 : GPIO0-2
3G_Power = RMII_TXEN 功能1: GPIO0-1
复用寄存器基地址 0x200F 0000
偏移地址
我来回答
回答41个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
加载中···
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2015-06-17 14:15:17
-
2015-04-15 12:54:13
-
2016-03-08 14:04:13
-
2018-09-07 15:46:13
-
2015-09-05 16:13:48
-
2015-04-28 14:56:11
-
102015-06-02 09:32:52
-
12013-12-26 15:49:27
-
2015-05-06 12:57:57
-
2016-03-27 17:06:06
-
2017-06-20 14:40:44
-
2016-03-10 03:00:21
-
02016-05-03 13:49:00
-
2017-07-14 20:01:42
-
2015-04-15 11:48:33
-
2015-09-07 18:12:32
-
2015-08-27 18:33:39
-
2016-08-30 20:00:07
-
2019-01-16 17:36:49
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5Hi3516CV610 如何使用SD卡升级固件
-
5cat /dev/logmpp 报错 <3>[ vi] [func]:vi_send_frame_node [line]:99 [info]:vi pic queue is full!
-
50如何获取vpss chn的图像修改后发送至vo
-
5FPGA通过Bt1120传YUV422数据过来,vi接收不到数据——3516dv500
-
50SS928 运行PQtools 拼接 推到设备里有一半画面会异常
-
53536AV100的sample_vdec输出到CVBS显示
-
10海思板子mpp怎么在vi阶段改变视频数据尺寸
-
10HI3559AV100 多摄像头同步模式
-
9海思ss928单路摄像头vio中加入opencv处理并显示
-
10EB-RV1126-BC-191板子运行自己编码的程序
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认