imx6 gpio分析

时间:2022-10-23 09:55:53
本文主要介绍如何配置IOMUX寄存器,设置IO复用寄存器,配置为GPIO功能。
参考:
  http://www.jianshu.com/p/3c2053508342
  http://www.embest-tech.com/community/index.php?topic=2822.0 查看板级文件
kernel/arch/arm/mach-mx6/board_mx6q_sabresd.c MACHINE_START(MX6Q_SABRESD, "Freescale i.MX 6Quad/DualLite/Solo Sabre-SD Board")
/* Maintainer: Freescale Semiconductor, Inc. */
.boot_params = MX6_PHYS_OFFSET + 0x100,
.fixup = fixup_mxc_board,
.map_io = mx6_map_io,
.init_irq = mx6_init_irq,
.init_machine = mx6_sabresd_board_init,    //-------------------------------->>> mx6_sabresd_board_init
.timer = &mx6_sabresd_timer,
.reserve = mx6q_sabresd_reserve,
MACHINE_END static void __init mx6_sabresd_board_init(void)  //<<<-------------------------------- mx6_sabresd_board_init
{
... ...
//这里这里已经将大部分寄存器都进行了配置。
if (cpu_is_mx6q())
mxc_iomux_v3_setup_multiple_pads(mx6q_sabresd_pads,    // ------------------>>> mxc_iomux_v3_setup_multiple_pads
ARRAY_SIZE(mx6q_sabresd_pads));             // ----------------->>> mx6q_sabresd_pads
else if (cpu_is_mx6dl()) {
mxc_iomux_v3_setup_multiple_pads(mx6dl_sabresd_pads,
ARRAY_SIZE(mx6dl_sabresd_pads));
}
... ...
}

mx6q_sabresd_pads结构体。
kernel/arch/arm/mach-mx6/board_mx6q_sabresd.h
static iomux_v3_cfg_t mx6q_sabresd_pads[] = {          // <<<--------------------- mx6q_sabresd_pads
/* AUDMUX */
MX6Q_PAD_CSI0_DAT4__AUDMUX_AUD3_TXC,
MX6Q_PAD_CSI0_DAT5__AUDMUX_AUD3_TXD,
MX6Q_PAD_CSI0_DAT6__AUDMUX_AUD3_TXFS,
MX6Q_PAD_CSI0_DAT7__AUDMUX_AUD3_RXD, MX6Q_PAD_SD1_DAT1__GPIO_1_17, /* FT5X06 RESET */ MX6Q_PAD_NANDF_CS3__GPIO_6_16, //FT5X06_INT
... ...
}

文件:kernel/arch/arm/plat-mxc/include/mach/iomux-mx6q.h
以MX6Q_PAD_SD1_DAT1__GPIO_1_17举例。
//MX6Q_PAD_SD1_DAT1表示寄存器,表示IOMUXC_IOMUXC_SW_MUX_CTL_PAD_SD1_DAT1。芯片手册2160页。
//后面的GPIO_1_17表示将该引脚复用为GPIO17.
//0x0724,0x003c表示寄存器地址的偏移量。具体查看上面的参考链接和芯片手册。
#define MX6Q_PAD_SD1_DAT1__GPIO_1_17 \
(_MX6Q_PAD_SD1_DAT1__GPIO_1_17 | MUX_PAD_CTRL(MX6Q_HIGH_DRV))
#define _MX6Q_PAD_SD1_DAT1__GPIO_1_17 \
IOMUX_PAD(0x0724, 0x033C, , 0x0000, , )
#define MUX_PAD_CTRL(x) ((iomux_v3_cfg_t)(x) << MUX_PAD_CTRL_SHIFT)

#define _MX6Q_PAD_SD2_DAT1__USDHC2_DAT1 \
          IOMUX_PAD(0x0360, 0x004C, 0, 0x0000, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__ECSPI5_SS0 \
         IOMUX_PAD(0x0360, 0x004C, 1, 0x0834, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__WEIM_WEIM_CS_2 \
      IOMUX_PAD(0x0360, 0x004C, 2, 0x0000, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__AUDMUX_AUD4_TXFS \
      IOMUX_PAD(0x0360, 0x004C, 3, 0x07C8, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__KPP_COL_7 \
      IOMUX_PAD(0x0360, 0x004C, 4, 0x08F0, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__GPIO_1_14 \
      IOMUX_PAD(0x0360, 0x004C, 5, 0x0000, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__CCM_WAIT \
      IOMUX_PAD(0x0360, 0x004C, 6, 0x0000, 0, 0)
  #define _MX6Q_PAD_SD2_DAT1__ANATOP_ANATOP_TESTO_0 \
      IOMUX_PAD(0x0360, 0x004C, 7, 0x0000, 0, 0)

文件:kernel/arch/arm/plat-mxc/include/mach/iomux-v3.h
#define IOMUX_PAD(_pad_ctrl_ofs, _mux_ctrl_ofs, _mux_mode, _sel_input_ofs, \
_sel_input, _pad_ctrl) \
(((iomux_v3_cfg_t)(_mux_ctrl_ofs) << MUX_CTRL_OFS_SHIFT) | \
((iomux_v3_cfg_t)(_mux_mode) << MUX_MODE_SHIFT) | \
((iomux_v3_cfg_t)(_pad_ctrl_ofs) << MUX_PAD_CTRL_OFS_SHIFT) | \
((iomux_v3_cfg_t)(_pad_ctrl) << MUX_PAD_CTRL_SHIFT) | \
((iomux_v3_cfg_t)(_sel_input_ofs) << MUX_SEL_INPUT_OFS_SHIFT) | \
((iomux_v3_cfg_t)(_sel_input) << MUX_SEL_INPUT_SHIFT)) int mxc_iomux_v3_setup_multiple_pads(iomux_v3_cfg_t *pad_list, unsigned count)   // <<<-------- mxc_iomux_v3_setup_multiple_pads()
{
iomux_v3_cfg_t *p = pad_list;
int i;
int ret; for (i = ; i < count; i++) {
ret = mxc_iomux_v3_setup_pad(*p);          // ------------------------------>>> mxc_iomux_v3_setup_pad()
if (ret)
return ret;
p++;
}
return ;
}
EXPORT_SYMBOL(mxc_iomux_v3_setup_multiple_pads); /* 将定义的宏解析,提取其中数据,设置到寄存器中 */
int mxc_iomux_v3_setup_pad(iomux_v3_cfg_t pad)       // <<<---------------------------- mxc_iomux_v3_setup_pad()
{
u32 mux_ctrl_ofs = (pad & MUX_CTRL_OFS_MASK) >> MUX_CTRL_OFS_SHIFT;
u32 mux_mode = (pad & MUX_MODE_MASK) >> MUX_MODE_SHIFT;
u32 sel_input_ofs = (pad & MUX_SEL_INPUT_OFS_MASK) >> MUX_SEL_INPUT_OFS_SHIFT;
u32 sel_input = (pad & MUX_SEL_INPUT_MASK) >> MUX_SEL_INPUT_SHIFT;
u32 pad_ctrl_ofs = (pad & MUX_PAD_CTRL_OFS_MASK) >> MUX_PAD_CTRL_OFS_SHIFT;
u32 pad_ctrl = (pad & MUX_PAD_CTRL_MASK) >> MUX_PAD_CTRL_SHIFT; if (mux_ctrl_ofs)
__raw_writel(mux_mode, base + mux_ctrl_ofs); if (sel_input_ofs)
__raw_writel(sel_input, base + sel_input_ofs); if (!(pad_ctrl & NO_PAD_CTRL) && pad_ctrl_ofs)
__raw_writel(pad_ctrl, base + pad_ctrl_ofs); return ;
}
EXPORT_SYMBOL(mxc_iomux_v3_setup_pad);

imx6 gpio分析的更多相关文章

  1. imx6 fec分析

    /***************************************************************************** * imx6 fec分析 * 本文主要分析 ...

  2. imx6 gpio irq

    /***************************************************************** * gpio irq * * 一直以来都没了解过gpio的irq, ...

  3. imx6 framebuffer 分析

    分析imx6 framebuffer设备和驱动的注册过程. Tony Liu, 2016-8-31, Shenzhen 相关文件: arch/arm/mach-mx6/board-mx6q_sabre ...

  4. am335x gpio分析

    /************************************************************************ * am335x_gpio * 本文主要记录am33 ...

  5. imx6 spi分析

    /************************************************************************** *本文主要跟踪imx6 spi设备和驱动的注册过 ...

  6. imx6 i2c分析

    本文主要分析: 1. i2c设备注册 2. i2c驱动注册 3. 上层调用过程参考: http://www.cnblogs.com/helloworldtoyou/p/5126618.html 1. ...

  7. imx6 MfgTool分析

    解析freescale的MfgTool中的脚本,了解imx6, android系统的分区情况. 配置文件 1. cfg.ini [profiles] chip = MX6DL Linux Update ...

  8. imx6 uart分析

    本文主要记录: 1.uart设备注册 2.uart驱动注册 3.上层应用调用有些地方理解的还不是很透彻,希望指正. 1.uart设备注册过程 MACHINE_START(MX6Q_SABRESD, & ...

  9. &lbrack;IMX6&rsqb;Android6&period;0移植和分析

    0. 知识点 中断(设备树) [IMX6]设备树分析--dts 1. 编译 Android6.0内核移植(1):分析编译日志 Android6.0内核移植(2):kernel编译内核 单独烧录kern ...

随机推荐

  1. jQuery使用&period;on&lpar;&rpar;无法绑定hover

    发现好像没有hover这个事件,jQuery的hover事件是一个封装,hover算不得一个事件.他只是将mouseover和mouseout合并了用mouseover和mouseout两个配合效果好 ...

  2. 无法将分支 master 发布到远程 origin,因为远程存储库中已存在具有同一名称的分支

    无法将分支 master 发布到远程 origin,因为远程存储库中已存在具有同一名称的分支.发布此分支将导致远程存储库中的分支发生非快进更新. 第一次用oschina的git设置完远程仓库后提交出现 ...

  3. 转载&colon;python发送HTTP请求

    1. [代码]GET 方法 import httplib #----------------------------- conn = httplib.HTTPConnection("www. ...

  4. 2015年第六届蓝桥杯C&sol;C&plus;&plus;程序设计本科B组决赛

    1.积分之谜(枚举) 2.完美正方形 3.关联账户(并查集) 4.密文搜索 5.居民集会 6.模型染色 1.积分之迷 小明开了个网上商店,卖风铃.共有3个品牌:A,B,C.为了促销,每件商品都会返固定 ...

  5. DC综合环境的一些概念

    DC综合环境的一些概念 启动文件 .synopsys_dc_setup 采用Tcl格式,包含工艺库的路径信息和其他环境变量 不同位置启动顺序 1.Synopsys安装目录 2.用户家目录 3.项目工作 ...

  6. Educational Codeforces Round 35 &lpar;Rated for Div&period; 2&rpar;

    Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...

  7. swiper默认显示三个,中间放大且显示全部图片两边显示部分图片的实现方法

    本页面内容最后的红色部分有惊喜哦! 最近在做一个活动页面,要求触摸切换图片时,默认在可视区域中显示三张图片,其中中间的一张图片比其他两张都大且全部显示,而其他两张图片只显示部分即可,于是就想到了swi ...

  8. 练习angularjs的ng-click的应用

    angular的click事件ng-click. 实现一个小功能计数器,用户可以点击“+”或“-”铵钮,数值每随点击铵钮增长1或减1.使用ng-init设置初始值为0. <div ng-app= ...

  9. Extjs4常见的调试问题

    Extjs4常见的调试问题: 1.fireFn.apply of undefined方法名称对不上 2.新增页面居左解决:页面的宽度和高度需要调整,内容items有问题:或者:layout : 'co ...

  10. SPOJ - COT Count on a tree

    地址:http://www.spoj.com/problems/COT/en/ 题目: COT - Count on a tree #tree You are given a tree with N  ...