搜索
bottom↓
回复: 14

(经验分享)转帖 飞思卡尔IMX6处理器的GPIO配置方式

[复制链接]

出0入0汤圆

发表于 2014-3-4 10:22:48 | 显示全部楼层 |阅读模式
在linux或android系统中,假如我们要配置飞思卡尔IMX6处理器的GPIO管脚,比如是GPIO_19这个管脚,那么要像这样:

#define MX6Q_PAD_GPIO_19__GPIO_4_5                              \

                                (_MX6Q_PAD_GPIO_19__GPIO_4_5| MUX_PAD_CTRL(NO_PAD_CTRL))

其中_MX6Q_PAD_GPIO_19__GPIO_4_5定义为:

  #define _MX6Q_PAD_GPIO_19__GPIO_4_5         \  

         IOMUX_PAD(0x0624, 0x0254, 5, 0x0000, 0, 0)

这个IOMUX_PAD宏是定义GPIO的关键宏,其原型为:

#define IOMUX_PAD(_pad_ctrl_ofs, _mux_ctrl_ofs, _mux_mode, _sel_input_ofs,   

       _sel_input, _pad_ctrl)

IOMUX_PAD宏有6个参数,每个参数的意思是:
_pad_ctrl_ofs     控制寄存器的偏移地址(16进制)
_mux_ctrl_ofs    MUX控制寄存器的偏移地址(16进制), 用于选择引脚的功能
_mux_mode      MUX模式,bit0~3,范围0~7
_select_input_ofs   SELECT_INPUT寄存器偏移地址(16进制)          
_select_input     Daisy Chain模式, bit0~1,范围0~3
_pad_ctrl         bits to be set in register _pad_ctrl_ofs for  configuration selection

具体的含义要结合IMX6数据手册【Chapter 36 IMOUX Controller(IOMUXC)】的内容。

以下就GPIO_19这个管脚的配置进行说明:

1、_pad_ctrl_ofs

找到数据手册:

从上图可知:_pad_ctrl_ofs = 0x624

2、_mux_ctrl_ofs、_mux_mode

找到数据手册的内容:

如上

图,

_mux_ctrl_ofs取值为0x254,_mux_mode范围为000~110

只有_mux_mode = 0时,_select_input_ofs和_select_input才有效,其余时候_select_input_ofs和_select_input 都为0。

3、_select_input_of、_select_input

当_mux_mode = 0时,_select_input_ofs 的取值需参考数据手册:


此时_select_input_ofs=0x8e8,_select_input=0x1

4、_pad_ctrl

_pad_ctrl一般取值为0

综上所述,GPIO_19的配置宏定义如下:

  #define _MX6Q_PAD_GPIO_19__KPP_COL_5            \  

         IOMUX_PAD(0x0624, 0x0254, 0, 0x08E8, 1, 0)  

#define _MX6Q_PAD_GPIO_19__ENET_1588_EVENT0_OUT     \  

         IOMUX_PAD(0x0624, 0x0254, 1, 0x0000, 0, 0)  

  #define _MX6Q_PAD_GPIO_19__SPDIF_OUT1           \  

         IOMUX_PAD(0x0624, 0x0254, 2, 0x0000, 0, 0)  

  #define _MX6Q_PAD_GPIO_19__CCM_CLKO         \  

         IOMUX_PAD(0x0624, 0x0254, 3, 0x0000, 0, 0)  

  #define _MX6Q_PAD_GPIO_19__ECSPI1_RDY           \  

         IOMUX_PAD(0x0624, 0x0254, 4, 0x0000, 0, 0)  

  #define _MX6Q_PAD_GPIO_19__GPIO_4_5         \  

         IOMUX_PAD(0x0624, 0x0254, 5, 0x0000, 0, 0)  

  #define _MX6Q_PAD_GPIO_19__ENET_TX_ER           \  

         IOMUX_PAD(0x0624, 0x0254, 6, 0x0000, 0, 0)  

  #define _MX6Q_PAD_GPIO_19__SRC_INT_BOOT         \  

         IOMUX_PAD(0x0624, 0x0254, 7, 0x0000, 0, 0)

以上的宏定义来自imx6的linux源码的arm/arch/palt-mxc/include/mach/iomux-mx6q.h
希望对大家有帮助~~

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2014-3-4 10:26:04 | 显示全部楼层
这个不错

出0入0汤圆

发表于 2014-3-4 10:28:39 | 显示全部楼层
学习一下,谢谢分享!!

出0入0汤圆

 楼主| 发表于 2014-3-4 10:56:52 | 显示全部楼层

感谢您的支持~~

出0入0汤圆

发表于 2014-9-3 09:09:35 | 显示全部楼层
这个挺不错的呀

出0入0汤圆

 楼主| 发表于 2014-9-3 18:11:26 | 显示全部楼层
wangkdd 发表于 2014-9-3 09:09
这个挺不错的呀

希望对大家有帮助~~

出0入0汤圆

发表于 2014-9-4 08:45:48 | 显示全部楼层
  一定有帮助的呀

出0入0汤圆

 楼主| 发表于 2014-9-4 09:13:37 | 显示全部楼层
wangkdd 发表于 2014-9-4 08:45
一定有帮助的呀

哈哈,感谢大家的支持和关注哈,我们再接再厉

出0入8汤圆

发表于 2014-9-4 16:05:11 | 显示全部楼层
支持,很详细。

出0入0汤圆

发表于 2014-9-4 16:20:08 | 显示全部楼层
不错~~!!

出0入0汤圆

 楼主| 发表于 2014-9-4 16:33:07 | 显示全部楼层
非常感谢大家的关注和支持,欢迎有问题在本论坛中交流和学习~~

出0入0汤圆

发表于 2014-9-4 17:02:53 | 显示全部楼层
linux对我来说来很遥远啊,先弄懂资源再说

出0入0汤圆

 楼主| 发表于 2014-9-5 17:13:07 | 显示全部楼层
fbestwish 发表于 2014-9-4 17:02
linux对我来说来很遥远啊,先弄懂资源再说

慢慢来,接触多了就好了。

出0入0汤圆

发表于 2015-1-10 10:40:30 | 显示全部楼层
虽然在用imx283也了解下6

出0入0汤圆

发表于 2015-1-10 10:48:50 | 显示全部楼层
不错的资料 ,IMX6高大上的板子 。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-3-29 16:53

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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