ARM知识分享-i.MX6Q GPIO复用修改方法

原创 2017-09-21 14:40:00 ARM i.MX6Q GPIO复用

平台:OKMX6Q-S2

系统:Linux

内核版本:Linux-3.0.35

 

 i.MX6Q GPIO复用修改方法,验证平台为飞凌嵌入式OKMX6Q-S2开发板,基于ARM Corte-A9 架构,i.MX6Q四核处理器,其它平台可参考使用。本次修改将原SD卡功能占用的部分引脚释放,复用为GPIO。具体的GPIO号需要参考i.MX6 CPU手册(IMX6DQRM.pdf)的第四章,Chapter 4 External Signals and Pin Multiplexing。

i.MX6 CPU手册路径:飞凌嵌入式OKMX6Q-S2、OKMX6DL-S2用户资料(A)/硬件/Datasheet/i.MX6/IMX6DQRM.pdf

 

1、修改流程

修改文件arch/arm/mach-mx6/board-mx6q_sabresd.h,在其中增加如下定义:

        /*GPIO*/

       MX6Q_PAD_SD3_CLK__GPIO_7_3,

       MX6Q_PAD_SD3_CMD__GPIO_7_2,

       MX6Q_PAD_SD3_DAT2__GPIO_7_6,

       MX6Q_PAD_SD3_DAT3__GPIO_7_7,

       MX6Q_PAD_SD3_DAT4__GPIO_7_1,

       MX6Q_PAD_SD3_DAT5__GPIO_7_0,

       MX6Q_PAD_SD3_DAT6__GPIO_6_18,

       MX6Q_PAD_SD3_DAT7__GPIO_6_17,

       MX6Q_PAD_NANDF_D1__GPIO_2_1,

       MX6Q_PAD_NANDF_D0__GPIO_2_0,

将原来的SD卡的功能注释掉

/* USDHC3 */

/*      MX6Q_PAD_SD3_CLK__USDHC3_CLK_50MHZ,

        MX6Q_PAD_SD3_CMD__USDHC3_CMD_50MHZ,

        MX6Q_PAD_SD3_DAT0__USDHC3_DAT0_50MHZ,

        MX6Q_PAD_SD3_DAT1__USDHC3_DAT1_50MHZ,

        MX6Q_PAD_SD3_DAT2__USDHC3_DAT2_50MHZ,

        MX6Q_PAD_SD3_DAT3__USDHC3_DAT3_50MHZ,

        MX6Q_PAD_SD3_DAT4__USDHC3_DAT4_50MHZ,

        MX6Q_PAD_SD3_DAT5__USDHC3_DAT5_50MHZ,

        MX6Q_PAD_SD3_DAT6__USDHC3_DAT6_50MHZ,

        MX6Q_PAD_SD3_DAT7__USDHC3_DAT7_50MHZ,

        MX6Q_PAD_NANDF_D0__GPIO_2_0,         

        MX6Q_PAD_NANDF_D1__GPIO_2_1,            */

 

注:Linux-3.0.35版本的内核将引脚功能定义在arch/arm/plat-mxc/include/mach/iomux-mx6q.h文件中,其中对每个引脚的全部复用功能进行了定义,有兴趣可以看一下。

 

2、测试

GPIO

球号      定义                                               GPIO号

89        MX6Q_PAD_SD3_CLK__GPIO_7_3        195

91        MX6Q_PAD_SD3_CMD__GPIO_7_2        194

94        MX6Q_PAD_SD3_DAT2__GPIO_7_6       198

93        MX6Q_PAD_SD3_DAT3__GPIO_7_7       199

92        MX6Q_PAD_SD3_DAT4__GPIO_7_1       193

90        MX6Q_PAD_SD3_DAT5__GPIO_7_0       192

88        MX6Q_PAD_SD3_DAT6__GPIO_6_18      178

87        MX6Q_PAD_SD3_DAT7__GPIO_6_17      177

83        MX6Q_PAD_NANDF_D1__GPIO_2_1       33

84        MX6Q_PAD_NANDF_D0__GPIO_2_0       32

GPIO_M_N到GPIOX的算法,GPIOX=(M-1)*32+N,例如 GPIO_4_28=(4-1)*32+28=124

 

测试命令

echo 33 > /sys/class/gpio/export

echo out > /sys/class/gpio/gpio33/direction

echo 1 > /sys/class/gpio/gpio33/value

cat /sys/class/gpio/gpio33/value


相关产品 >

  • FETMX6Q-C核心板

    i.MX6Q核心板板层出不穷,要如何选择?飞凌解读i.mx6Q芯片强性能为您推荐四核A9架构的i.MX6Q产品精选,包含iMX6Q 核心板、i.MX6Q 核心板、iMX6Q工业级核心板,欢迎采购。  i.MX6Q核心板基于NXP(原Freescale)Cortex-A9架构的i.MX6Q四核处理器设计,核心板小尺寸核心板搭配独特的薄款连接器,让设计随心所欲!

    了解详情
    FETMX6Q-C核心板
  • OKMX6Q-C开发板

    双千兆飞凌嵌入式iMX6Q开发板,板对板连接器,纤薄之际,次底板支持iMX6Q和iMX6DL核心板。i.MX6Q开发板与i.MX6DL开发板资源丰富,原理图、PCB、软件资源、硬件资源下载,技术支持等。欢迎选购

    了解详情
    OKMX6Q-C开发板
  • FETMX6Q-S核心板

    NXP iMX6Quad系列具有四个内核,运行频率达1.2 GHz,带有1 MB L2缓存和64位DDR3或2通道、32位LPDDR2支持。飞凌提供商业级iMX6Q核心板,工业级iMX6Q核心板,兼容一同底板。具有抗震,抗氧化,抗干扰,更快速升级产品等优势。保定飞凌嵌入式专注imx6,imx6开发板,飞思卡尔imx6等ARM嵌入式核心控制系统研发、设计和生产,是imx6,imx6开发板,飞思卡尔imx6提供者,imx6系列产品现已畅销全国,欢迎咨询!
    了解详情
    FETMX6Q-S核心板
  • OKMX6Q-S3开发板

    飞凌嵌入式提供iMX6Q开发板,iMX6解决方案,iMX6Q核心板,i.MX6Q开发板解决方案。iMX6Q稳定、快速、性价比高,欢迎选购 NXP iMX6系列芯片全支持,升级简配无忧替换。 了解详情
    OKMX6Q-S3开发板

推荐阅读 换一批 换一批