嵌入式开发之hi3519---GPIO 驱动

在一个嵌入式系统中使用最多的莫过于 通用输入输出 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

偏移地址

这是HI3531的/etc/init.d/rcS的内容,结合HIMM工具,我们分析一下。

#GPIO17 3~6

himm 0x200F0234 0

himm 0x200F0238 0

himm 0x200F023C 0

himm 0x200F0240 0

#GPIO17 DIR

himm 0x20260400 0x20

#GPIO17_5 BUZZER

himm 0x20260080 0x20

ifconfig eth0 192.168.0.140

ifconfig eth1 192.168.1.163

telnetd&

#GPIO17_5 BUZZER

himm 0x20260080 0x0

#GPIO17 3~6

himm 0x200F0234 0

himm 0x200F0238 0

himm 0x200F023C 0

himm 0x200F0240 0

这四行是定义GPIO17的3~6引脚为GPIO1的功能,即用作IO管理用。

地址计算为基地址0X200F0000, 再加上0X234, 定义GP17.3的地址。

#GPIO17 DIR

himm 0x20260400 0x20

这是定义GPIO17.5脚为输出引脚,即方向引脚。记住:0X400都是方向引脚,一个组只有一个寄存器

#GPIO17_5 BUZZER

himm 0x20260080 0x20

这里直接输出17_5的引脚为高电平,引脚为高,蜂鸣器开始响了。 0X20为0B0010_0000,  也就是BIT5, 管脚号是GPIO17_0~GPIO17_7,

这里的0x20260080 的数据寄存器

再加上偏移地址0X080,  计算方法为:  0X20260000 + (1 《  (5 + 2))

其中5为管脚号, 2为右移MASK地址PADDR[9:2]

#GPIO17_5 BUZZER

himm 0x20260080 0x0

在运行了网络配置和TELNET程序后,置GPIO17_5脚为低电平,关掉蜂鸣器。

http://blog.csdn.net/USB_ABC/article/details/51714458

http://blog.csdn.net/xyyangkun/article/details/8485426?reload 驱动

时间: 2024-11-06 08:31:14

嵌入式开发之hi3519---GPIO 驱动的相关文章

嵌入式开发之GCC编译器使用

嵌入式开发之GCC编译器使用 Linux系统下GCC是GNU推出的功能强大的性能优越的多平台编译器,是GNU的代表作之一.GCC 可以在多种硬件平台上编译出可执行程序,其执行效率一般比其他编译器高%20到%30.GCC编译器能将C C++语言程序汇编程序编译,链接成可执行程序.在linux文件没有统一的后缀,系统从文件的属性来区分可执行程序和不可执行程序.  1.1GCC编译程序的四个阶段 预处理(Pre-Processing) 编译(Comping) 汇编(Assembing) 连接(Link

嵌入式开发之zynq---Zynq PS侧sd驱动

http://blog.chinaunix.net/uid-29404121-id-4217026.html http://blog.chinaunix.net/uid-29709984-id-4304978.html http://blog.chinaunix.net/uid-26707720-id-3979376.html http://blog.chinaunix.net/uid-21973366-id-3970069.html http://blog.csdn.net/simonjay2

嵌入式开发之zynq---Zynq PS侧I2C驱动架构

http://blog.chinaunix.net/uid-24148050-id-120532.html http://bbs.csdn.net/topics/390538368?page=1 http://blog.csdn.net/lanyou1900/article/details/41724103 http://blog.csdn.net/lqxandroid2012/article/details/51367376 http://blog.chinaunix.net/uid-2340

嵌入式开发之 STM32自行车码表(图文)

笔者将从以下几个方面逐步深入地讲解STM32F103C8开发板的使用,并在Windows下编写一个简单的自行车码表程序: 元器件 环境搭建 电路连接 一个简单的LED闪烁程序 自行车码表 准备工作之 元器件 准备工作之 电路连接 准备工作之 环境搭建 CubeMX配置 KeilST-LINK下载程序调试程序 下载并注册安装Keil Keil安装程序及注册机 用keil打开CubeMX生成的工程文件 build keilST-LINK下载和调试以blink为例 出错误了 解决方法一 解决方法二 连

嵌入式开发之davinci--- 8127 中camer 和 capture link 的区别

(1)camera link (2)capture link (3)两者区别 (1)camera link 走的是isp iss link采集的得到的数据,适用于ipnc 框架 (2)capture link 走的是vpss 里面的vip0 a,b vip1 a,b.适用于dvr,底层内核驱动是v4l2,在ti81xx_vpss.c中有代码,路径:\\192.168.0.144\Share\opt\exp_ipnc3.5\Source\ti_tools\ipnc_psp_arago\kernel

嵌入式开发之davinci--- 8148/8168/8127 中的High-DefinitionVideo Processing Subsystem (HDVPSS)

High-DefinitionVideo Processing Subsystem (HDVPSS) 这一章介绍了高清视频处理子系统(HDVPSS). 2.1导论 2.1.1 简介 HDVPSS 使用TI开发的算法,灵活的复合和融合引擎,各种高质量外部视频接口,实现视频/图像显示和采集处理功能.   2.1.3 缩略语 名称 定义 COMP Compositor 复合器 DEI De-Interlacer 去隔行 DEIH High quality De-Interlacer 高质量去隔行 DV

嵌入式开发之davinci--- DVRRDK, EZSDK和DVSDK这三者有什么区别

下载的时候选择信息要避免security类型的产品,这个是要审查的. DVRRDK是专门针对DVR的开发包是非公开的,针对安防的客户定制的,效率要高. EZSDK是开放的版本架构上使用openmax可以为android提供支持 DVSDK是老的版本名称使用codec engine架构,现在新的芯片DM8xxx都是EZSDK了 三种不同的软件框架,使用不同的方法来利用dsp工作. http://blog.csdn.net/zhouzhuan2008/article/details/8512128

嵌入式开发之hi3519---spi nor flash启动

author:pkf qq:1327706646 1.官方hi3519默认是硬件3byte 地址模式,配置完ddr始终后,sdkv100.020是可以支持正常启动,用到低位16Mflash内存 2.如果要换成emmc启动,由于emcc的环境变量和分区信息,要在start.s 中跳过960个字节 3.无论nand  or nor flash.emmc.或者bootrom启动,都要先有片内bootrom引导 加载到ram内存中,先uboot的第一阶段,然后第二阶段 4.最终烧录的uboot是带64B

嵌入式开发之davinci--- mcfw框架介绍

整体上mcfw框架如下图 从中可见其层次是清楚的,link实在基本的驱动之上的,而mcfw是在link之上的api,是通过link来实现相应的功能.可见link是框架中承上启下的层次,通过link来实现具体的功能,所以对link进行深入的学习和了解,对于理解mcfw以及扩展其功能是至关重要的. link的主要功能包括视频的输入输出,视频的编解码,以及dsp算法等. ezsdk与dvrrdk 要看你的应用了,如果是DVR.NVR,建议使用DVR RDK,里面去掉了OpenMax,改用专门针对多通道