pinctrl-mt7623.c (0337966d121ebebf73a1c346123e8112796e684e) | pinctrl-mt7623.c (e7507f57a93a194012e889aead13ea2bdc2e4889) |
---|---|
1// SPDX-License-Identifier: GPL-2.0 |
|
1/* | 2/* |
2 * Copyright (c) 2016 John Crispin <john@phrozen.org> | 3 * The MT7623 driver based on Linux generic pinctrl binding. |
3 * | 4 * |
4 * This program is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU General Public License version 2 as 6 * published by the Free Software Foundation. 7 * 8 * This program is distributed in the hope that it will be useful, 9 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11 * GNU General Public License for more details. | 5 * Copyright (C) 2015 - 2018 MediaTek Inc. 6 * Author: Biao Huang <biao.huang@mediatek.com> 7 * Ryder Lee <ryder.lee@mediatek.com> 8 * Sean Wang <sean.wang@mediatek.com> |
12 */ 13 | 9 */ 10 |
14#include <dt-bindings/pinctrl/mt65xx.h> 15#include <linux/module.h> 16#include <linux/of.h> 17#include <linux/of_device.h> 18#include <linux/platform_device.h> 19#include <linux/pinctrl/pinctrl.h> 20#include <linux/regmap.h> | 11#include "pinctrl-moore.h" |
21 | 12 |
22#include "pinctrl-mtk-common.h" 23#include "pinctrl-mtk-mt7623.h" | 13#define PIN_BOND_REG0 0xb10 14#define PIN_BOND_REG1 0xf20 15#define PIN_BOND_REG2 0xef0 16#define BOND_PCIE_CLR (0x77 << 3) 17#define BOND_I2S_CLR 0x3 18#define BOND_MSDC0E_CLR 0x1 |
24 | 19 |
25static const struct mtk_drv_group_desc mt7623_drv_grp[] = { 26 /* 0E4E8SR 4/8/12/16 */ 27 MTK_DRV_GRP(4, 16, 1, 2, 4), 28 /* 0E2E4SR 2/4/6/8 */ 29 MTK_DRV_GRP(2, 8, 1, 2, 2), 30 /* E8E4E2 2/4/6/8/10/12/14/16 */ 31 MTK_DRV_GRP(2, 16, 0, 2, 2) | 20#define PIN_FIELD15(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits) \ 21 PIN_FIELD_CALC(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, \ 22 _x_bits, 15, false) 23 24#define PIN_FIELD16(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits) \ 25 PIN_FIELD_CALC(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, \ 26 _x_bits, 16, 0) 27 28#define PINS_FIELD16(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits)\ 29 PIN_FIELD_CALC(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, \ 30 _x_bits, 16, 1) 31 32#define MT7623_PIN(_number, _name, _eint_n, _drv_grp) \ 33 MTK_PIN(_number, _name, _eint_n, _drv_grp) 34 35static const struct mtk_pin_field_calc mt7623_pin_mode_range[] = { 36 PIN_FIELD15(0, 278, 0x760, 0x10, 0, 3), |
32}; 33 | 37}; 38 |
34#define DRV_SEL0 0xf50 35#define DRV_SEL1 0xf60 36#define DRV_SEL2 0xf70 37#define DRV_SEL3 0xf80 38#define DRV_SEL4 0xf90 39#define DRV_SEL5 0xfa0 40#define DRV_SEL6 0xfb0 41#define DRV_SEL7 0xfe0 42#define DRV_SEL8 0xfd0 43#define DRV_SEL9 0xff0 44#define DRV_SEL10 0xf00 | 39static const struct mtk_pin_field_calc mt7623_pin_dir_range[] = { 40 PIN_FIELD16(0, 175, 0x0, 0x10, 0, 1), 41 PIN_FIELD16(176, 278, 0xc0, 0x10, 0, 1), 42}; |
45 | 43 |
46#define MSDC0_CTRL0 0xcc0 47#define MSDC0_CTRL1 0xcd0 48#define MSDC0_CTRL2 0xce0 49#define MSDC0_CTRL3 0xcf0 50#define MSDC0_CTRL4 0xd00 51#define MSDC0_CTRL5 0xd10 52#define MSDC0_CTRL6 0xd20 53#define MSDC1_CTRL0 0xd30 54#define MSDC1_CTRL1 0xd40 55#define MSDC1_CTRL2 0xd50 56#define MSDC1_CTRL3 0xd60 57#define MSDC1_CTRL4 0xd70 58#define MSDC1_CTRL5 0xd80 59#define MSDC1_CTRL6 0xd90 | 44static const struct mtk_pin_field_calc mt7623_pin_di_range[] = { 45 PIN_FIELD16(0, 278, 0x630, 0x10, 0, 1), 46}; |
60 | 47 |
61#define IES_EN0 0xb20 62#define IES_EN1 0xb30 63#define IES_EN2 0xb40 | 48static const struct mtk_pin_field_calc mt7623_pin_do_range[] = { 49 PIN_FIELD16(0, 278, 0x500, 0x10, 0, 1), 50}; |
64 | 51 |
65#define SMT_EN0 0xb50 66#define SMT_EN1 0xb60 67#define SMT_EN2 0xb70 | 52static const struct mtk_pin_field_calc mt7623_pin_ies_range[] = { 53 PINS_FIELD16(0, 6, 0xb20, 0x10, 0, 1), 54 PINS_FIELD16(7, 9, 0xb20, 0x10, 1, 1), 55 PINS_FIELD16(10, 13, 0xb30, 0x10, 3, 1), 56 PINS_FIELD16(14, 15, 0xb30, 0x10, 13, 1), 57 PINS_FIELD16(16, 17, 0xb40, 0x10, 7, 1), 58 PINS_FIELD16(18, 29, 0xb40, 0x10, 13, 1), 59 PINS_FIELD16(30, 32, 0xb40, 0x10, 7, 1), 60 PINS_FIELD16(33, 37, 0xb40, 0x10, 13, 1), 61 PIN_FIELD16(38, 38, 0xb20, 0x10, 13, 1), 62 PINS_FIELD16(39, 42, 0xb40, 0x10, 13, 1), 63 PINS_FIELD16(43, 45, 0xb20, 0x10, 10, 1), 64 PINS_FIELD16(47, 48, 0xb20, 0x10, 11, 1), 65 PIN_FIELD16(49, 49, 0xb20, 0x10, 12, 1), 66 PINS_FIELD16(50, 52, 0xb20, 0x10, 13, 1), 67 PINS_FIELD16(53, 56, 0xb20, 0x10, 14, 1), 68 PINS_FIELD16(57, 58, 0xb20, 0x10, 15, 1), 69 PIN_FIELD16(59, 59, 0xb30, 0x10, 10, 1), 70 PINS_FIELD16(60, 62, 0xb30, 0x10, 0, 1), 71 PINS_FIELD16(63, 65, 0xb30, 0x10, 1, 1), 72 PINS_FIELD16(66, 71, 0xb30, 0x10, 2, 1), 73 PINS_FIELD16(72, 74, 0xb20, 0x10, 12, 1), 74 PINS_FIELD16(75, 76, 0xb30, 0x10, 3, 1), 75 PINS_FIELD16(77, 78, 0xb30, 0x10, 4, 1), 76 PINS_FIELD16(79, 82, 0xb30, 0x10, 5, 1), 77 PINS_FIELD16(83, 84, 0xb30, 0x10, 2, 1), 78 PIN_FIELD16(85, 85, 0xda0, 0x10, 4, 1), 79 PIN_FIELD16(86, 86, 0xd90, 0x10, 4, 1), 80 PINS_FIELD16(87, 90, 0xdb0, 0x10, 4, 1), 81 PINS_FIELD16(101, 104, 0xb30, 0x10, 6, 1), 82 PIN_FIELD16(105, 105, 0xd40, 0x10, 4, 1), 83 PIN_FIELD16(106, 106, 0xd30, 0x10, 4, 1), 84 PINS_FIELD16(107, 110, 0xd50, 0x10, 4, 1), 85 PINS_FIELD16(111, 115, 0xce0, 0x10, 4, 1), 86 PIN_FIELD16(116, 116, 0xcd0, 0x10, 4, 1), 87 PIN_FIELD16(117, 117, 0xcc0, 0x10, 4, 1), 88 PINS_FIELD16(118, 121, 0xce0, 0x10, 4, 1), 89 PINS_FIELD16(122, 125, 0xb30, 0x10, 7, 1), 90 PIN_FIELD16(126, 126, 0xb20, 0x10, 12, 1), 91 PINS_FIELD16(127, 142, 0xb30, 0x10, 9, 1), 92 PINS_FIELD16(143, 160, 0xb30, 0x10, 10, 1), 93 PINS_FIELD16(161, 168, 0xb30, 0x10, 12, 1), 94 PINS_FIELD16(169, 183, 0xb30, 0x10, 10, 1), 95 PINS_FIELD16(184, 186, 0xb30, 0x10, 9, 1), 96 PIN_FIELD16(187, 187, 0xb30, 0x10, 14, 1), 97 PIN_FIELD16(188, 188, 0xb20, 0x10, 13, 1), 98 PINS_FIELD16(189, 193, 0xb30, 0x10, 15, 1), 99 PINS_FIELD16(194, 198, 0xb40, 0x10, 0, 1), 100 PIN_FIELD16(199, 199, 0xb20, 0x10, 1, 1), 101 PINS_FIELD16(200, 202, 0xb40, 0x10, 1, 1), 102 PINS_FIELD16(203, 207, 0xb40, 0x10, 2, 1), 103 PINS_FIELD16(208, 209, 0xb40, 0x10, 3, 1), 104 PIN_FIELD16(210, 210, 0xb40, 0x10, 4, 1), 105 PINS_FIELD16(211, 235, 0xb40, 0x10, 5, 1), 106 PINS_FIELD16(236, 241, 0xb40, 0x10, 6, 1), 107 PINS_FIELD16(242, 243, 0xb40, 0x10, 7, 1), 108 PINS_FIELD16(244, 247, 0xb40, 0x10, 8, 1), 109 PIN_FIELD16(248, 248, 0xb40, 0x10, 9, 1), 110 PINS_FIELD16(249, 257, 0xfc0, 0x10, 4, 1), 111 PIN_FIELD16(258, 258, 0xcb0, 0x10, 4, 1), 112 PIN_FIELD16(259, 259, 0xc90, 0x10, 4, 1), 113 PIN_FIELD16(260, 260, 0x3a0, 0x10, 4, 1), 114 PIN_FIELD16(261, 261, 0xd50, 0x10, 4, 1), 115 PINS_FIELD16(262, 277, 0xb40, 0x10, 12, 1), 116 PIN_FIELD16(278, 278, 0xb40, 0x10, 13, 1), 117}; |
68 | 118 |
69static const struct mtk_pin_drv_grp mt7623_pin_drv[] = { 70 MTK_PIN_DRV_GRP(0, DRV_SEL0, 0, 1), 71 MTK_PIN_DRV_GRP(1, DRV_SEL0, 0, 1), 72 MTK_PIN_DRV_GRP(2, DRV_SEL0, 0, 1), 73 MTK_PIN_DRV_GRP(3, DRV_SEL0, 0, 1), 74 MTK_PIN_DRV_GRP(4, DRV_SEL0, 0, 1), 75 MTK_PIN_DRV_GRP(5, DRV_SEL0, 0, 1), 76 MTK_PIN_DRV_GRP(6, DRV_SEL0, 0, 1), 77 MTK_PIN_DRV_GRP(7, DRV_SEL0, 4, 1), 78 MTK_PIN_DRV_GRP(8, DRV_SEL0, 4, 1), 79 MTK_PIN_DRV_GRP(9, DRV_SEL0, 4, 1), 80 MTK_PIN_DRV_GRP(10, DRV_SEL0, 8, 1), 81 MTK_PIN_DRV_GRP(11, DRV_SEL0, 8, 1), 82 MTK_PIN_DRV_GRP(12, DRV_SEL0, 8, 1), 83 MTK_PIN_DRV_GRP(13, DRV_SEL0, 8, 1), 84 MTK_PIN_DRV_GRP(14, DRV_SEL0, 12, 0), 85 MTK_PIN_DRV_GRP(15, DRV_SEL0, 12, 0), 86 MTK_PIN_DRV_GRP(18, DRV_SEL1, 4, 0), 87 MTK_PIN_DRV_GRP(19, DRV_SEL1, 4, 0), 88 MTK_PIN_DRV_GRP(20, DRV_SEL1, 4, 0), 89 MTK_PIN_DRV_GRP(21, DRV_SEL1, 4, 0), 90 MTK_PIN_DRV_GRP(22, DRV_SEL1, 8, 0), 91 MTK_PIN_DRV_GRP(23, DRV_SEL1, 8, 0), 92 MTK_PIN_DRV_GRP(24, DRV_SEL1, 8, 0), 93 MTK_PIN_DRV_GRP(25, DRV_SEL1, 8, 0), 94 MTK_PIN_DRV_GRP(26, DRV_SEL1, 8, 0), 95 MTK_PIN_DRV_GRP(27, DRV_SEL1, 12, 0), 96 MTK_PIN_DRV_GRP(28, DRV_SEL1, 12, 0), 97 MTK_PIN_DRV_GRP(29, DRV_SEL1, 12, 0), 98 MTK_PIN_DRV_GRP(33, DRV_SEL2, 0, 0), 99 MTK_PIN_DRV_GRP(34, DRV_SEL2, 0, 0), 100 MTK_PIN_DRV_GRP(35, DRV_SEL2, 0, 0), 101 MTK_PIN_DRV_GRP(36, DRV_SEL2, 0, 0), 102 MTK_PIN_DRV_GRP(37, DRV_SEL2, 0, 0), 103 MTK_PIN_DRV_GRP(39, DRV_SEL2, 8, 1), 104 MTK_PIN_DRV_GRP(40, DRV_SEL2, 8, 1), 105 MTK_PIN_DRV_GRP(41, DRV_SEL2, 8, 1), 106 MTK_PIN_DRV_GRP(42, DRV_SEL2, 8, 1), 107 MTK_PIN_DRV_GRP(43, DRV_SEL2, 12, 0), 108 MTK_PIN_DRV_GRP(44, DRV_SEL2, 12, 0), 109 MTK_PIN_DRV_GRP(45, DRV_SEL2, 12, 0), 110 MTK_PIN_DRV_GRP(47, DRV_SEL3, 0, 0), 111 MTK_PIN_DRV_GRP(48, DRV_SEL3, 0, 0), 112 MTK_PIN_DRV_GRP(49, DRV_SEL3, 4, 0), 113 MTK_PIN_DRV_GRP(53, DRV_SEL3, 12, 0), 114 MTK_PIN_DRV_GRP(54, DRV_SEL3, 12, 0), 115 MTK_PIN_DRV_GRP(55, DRV_SEL3, 12, 0), 116 MTK_PIN_DRV_GRP(56, DRV_SEL3, 12, 0), 117 MTK_PIN_DRV_GRP(60, DRV_SEL4, 8, 1), 118 MTK_PIN_DRV_GRP(61, DRV_SEL4, 8, 1), 119 MTK_PIN_DRV_GRP(62, DRV_SEL4, 8, 1), 120 MTK_PIN_DRV_GRP(63, DRV_SEL4, 12, 1), 121 MTK_PIN_DRV_GRP(64, DRV_SEL4, 12, 1), 122 MTK_PIN_DRV_GRP(65, DRV_SEL4, 12, 1), 123 MTK_PIN_DRV_GRP(66, DRV_SEL5, 0, 1), 124 MTK_PIN_DRV_GRP(67, DRV_SEL5, 0, 1), 125 MTK_PIN_DRV_GRP(68, DRV_SEL5, 0, 1), 126 MTK_PIN_DRV_GRP(69, DRV_SEL5, 0, 1), 127 MTK_PIN_DRV_GRP(70, DRV_SEL5, 0, 1), 128 MTK_PIN_DRV_GRP(71, DRV_SEL5, 0, 1), 129 MTK_PIN_DRV_GRP(72, DRV_SEL3, 4, 0), 130 MTK_PIN_DRV_GRP(73, DRV_SEL3, 4, 0), 131 MTK_PIN_DRV_GRP(74, DRV_SEL3, 4, 0), 132 MTK_PIN_DRV_GRP(83, DRV_SEL5, 0, 1), 133 MTK_PIN_DRV_GRP(84, DRV_SEL5, 0, 1), 134 MTK_PIN_DRV_GRP(105, MSDC1_CTRL1, 0, 1), 135 MTK_PIN_DRV_GRP(106, MSDC1_CTRL0, 0, 1), 136 MTK_PIN_DRV_GRP(107, MSDC1_CTRL2, 0, 1), 137 MTK_PIN_DRV_GRP(108, MSDC1_CTRL2, 0, 1), 138 MTK_PIN_DRV_GRP(109, MSDC1_CTRL2, 0, 1), 139 MTK_PIN_DRV_GRP(110, MSDC1_CTRL2, 0, 1), 140 MTK_PIN_DRV_GRP(111, MSDC0_CTRL2, 0, 1), 141 MTK_PIN_DRV_GRP(112, MSDC0_CTRL2, 0, 1), 142 MTK_PIN_DRV_GRP(113, MSDC0_CTRL2, 0, 1), 143 MTK_PIN_DRV_GRP(114, MSDC0_CTRL2, 0, 1), 144 MTK_PIN_DRV_GRP(115, MSDC0_CTRL2, 0, 1), 145 MTK_PIN_DRV_GRP(116, MSDC0_CTRL1, 0, 1), 146 MTK_PIN_DRV_GRP(117, MSDC0_CTRL0, 0, 1), 147 MTK_PIN_DRV_GRP(118, MSDC0_CTRL2, 0, 1), 148 MTK_PIN_DRV_GRP(119, MSDC0_CTRL2, 0, 1), 149 MTK_PIN_DRV_GRP(120, MSDC0_CTRL2, 0, 1), 150 MTK_PIN_DRV_GRP(121, MSDC0_CTRL2, 0, 1), 151 MTK_PIN_DRV_GRP(126, DRV_SEL3, 4, 0), 152 MTK_PIN_DRV_GRP(199, DRV_SEL0, 4, 1), 153 MTK_PIN_DRV_GRP(200, DRV_SEL8, 0, 0), 154 MTK_PIN_DRV_GRP(201, DRV_SEL8, 0, 0), 155 MTK_PIN_DRV_GRP(203, DRV_SEL8, 4, 0), 156 MTK_PIN_DRV_GRP(204, DRV_SEL8, 4, 0), 157 MTK_PIN_DRV_GRP(205, DRV_SEL8, 4, 0), 158 MTK_PIN_DRV_GRP(206, DRV_SEL8, 4, 0), 159 MTK_PIN_DRV_GRP(207, DRV_SEL8, 4, 0), 160 MTK_PIN_DRV_GRP(208, DRV_SEL8, 8, 0), 161 MTK_PIN_DRV_GRP(209, DRV_SEL8, 8, 0), 162 MTK_PIN_DRV_GRP(236, DRV_SEL9, 4, 0), 163 MTK_PIN_DRV_GRP(237, DRV_SEL9, 4, 0), 164 MTK_PIN_DRV_GRP(238, DRV_SEL9, 4, 0), 165 MTK_PIN_DRV_GRP(239, DRV_SEL9, 4, 0), 166 MTK_PIN_DRV_GRP(240, DRV_SEL9, 4, 0), 167 MTK_PIN_DRV_GRP(241, DRV_SEL9, 4, 0), 168 MTK_PIN_DRV_GRP(242, DRV_SEL9, 8, 0), 169 MTK_PIN_DRV_GRP(243, DRV_SEL9, 8, 0), 170 MTK_PIN_DRV_GRP(257, MSDC0_CTRL2, 0, 1), 171 MTK_PIN_DRV_GRP(261, MSDC1_CTRL2, 0, 1), 172 MTK_PIN_DRV_GRP(262, DRV_SEL10, 8, 0), 173 MTK_PIN_DRV_GRP(263, DRV_SEL10, 8, 0), 174 MTK_PIN_DRV_GRP(264, DRV_SEL10, 8, 0), 175 MTK_PIN_DRV_GRP(265, DRV_SEL10, 8, 0), 176 MTK_PIN_DRV_GRP(266, DRV_SEL10, 8, 0), 177 MTK_PIN_DRV_GRP(267, DRV_SEL10, 8, 0), 178 MTK_PIN_DRV_GRP(268, DRV_SEL10, 8, 0), 179 MTK_PIN_DRV_GRP(269, DRV_SEL10, 8, 0), 180 MTK_PIN_DRV_GRP(270, DRV_SEL10, 8, 0), 181 MTK_PIN_DRV_GRP(271, DRV_SEL10, 8, 0), 182 MTK_PIN_DRV_GRP(272, DRV_SEL10, 8, 0), 183 MTK_PIN_DRV_GRP(274, DRV_SEL10, 8, 0), 184 MTK_PIN_DRV_GRP(275, DRV_SEL10, 8, 0), 185 MTK_PIN_DRV_GRP(276, DRV_SEL10, 8, 0), 186 MTK_PIN_DRV_GRP(278, DRV_SEL2, 8, 1), | 119static const struct mtk_pin_field_calc mt7623_pin_smt_range[] = { 120 PINS_FIELD16(0, 6, 0xb50, 0x10, 0, 1), 121 PINS_FIELD16(7, 9, 0xb50, 0x10, 1, 1), 122 PINS_FIELD16(10, 13, 0xb60, 0x10, 3, 1), 123 PINS_FIELD16(14, 15, 0xb60, 0x10, 13, 1), 124 PINS_FIELD16(16, 17, 0xb70, 0x10, 7, 1), 125 PINS_FIELD16(18, 29, 0xb70, 0x10, 13, 1), 126 PINS_FIELD16(30, 32, 0xb70, 0x10, 7, 1), 127 PINS_FIELD16(33, 37, 0xb70, 0x10, 13, 1), 128 PIN_FIELD16(38, 38, 0xb50, 0x10, 13, 1), 129 PINS_FIELD16(39, 42, 0xb70, 0x10, 13, 1), 130 PINS_FIELD16(43, 45, 0xb50, 0x10, 10, 1), 131 PINS_FIELD16(47, 48, 0xb50, 0x10, 11, 1), 132 PIN_FIELD16(49, 49, 0xb50, 0x10, 12, 1), 133 PINS_FIELD16(50, 52, 0xb50, 0x10, 13, 1), 134 PINS_FIELD16(53, 56, 0xb50, 0x10, 14, 1), 135 PINS_FIELD16(57, 58, 0xb50, 0x10, 15, 1), 136 PIN_FIELD16(59, 59, 0xb60, 0x10, 10, 1), 137 PINS_FIELD16(60, 62, 0xb60, 0x10, 0, 1), 138 PINS_FIELD16(63, 65, 0xb60, 0x10, 1, 1), 139 PINS_FIELD16(66, 71, 0xb60, 0x10, 2, 1), 140 PINS_FIELD16(72, 74, 0xb50, 0x10, 12, 1), 141 PINS_FIELD16(75, 76, 0xb60, 0x10, 3, 1), 142 PINS_FIELD16(77, 78, 0xb60, 0x10, 4, 1), 143 PINS_FIELD16(79, 82, 0xb60, 0x10, 5, 1), 144 PINS_FIELD16(83, 84, 0xb60, 0x10, 2, 1), 145 PIN_FIELD16(85, 85, 0xda0, 0x10, 11, 1), 146 PIN_FIELD16(86, 86, 0xd90, 0x10, 11, 1), 147 PIN_FIELD16(87, 87, 0xdc0, 0x10, 3, 1), 148 PIN_FIELD16(88, 88, 0xdc0, 0x10, 7, 1), 149 PIN_FIELD16(89, 89, 0xdc0, 0x10, 11, 1), 150 PIN_FIELD16(90, 90, 0xdc0, 0x10, 15, 1), 151 PINS_FIELD16(101, 104, 0xb60, 0x10, 6, 1), 152 PIN_FIELD16(105, 105, 0xd40, 0x10, 11, 1), 153 PIN_FIELD16(106, 106, 0xd30, 0x10, 11, 1), 154 PIN_FIELD16(107, 107, 0xd60, 0x10, 3, 1), 155 PIN_FIELD16(108, 108, 0xd60, 0x10, 7, 1), 156 PIN_FIELD16(109, 109, 0xd60, 0x10, 11, 1), 157 PIN_FIELD16(110, 110, 0xd60, 0x10, 15, 1), 158 PIN_FIELD16(111, 111, 0xd00, 0x10, 15, 1), 159 PIN_FIELD16(112, 112, 0xd00, 0x10, 11, 1), 160 PIN_FIELD16(113, 113, 0xd00, 0x10, 7, 1), 161 PIN_FIELD16(114, 114, 0xd00, 0x10, 3, 1), 162 PIN_FIELD16(115, 115, 0xd10, 0x10, 3, 1), 163 PIN_FIELD16(116, 116, 0xcd0, 0x10, 11, 1), 164 PIN_FIELD16(117, 117, 0xcc0, 0x10, 11, 1), 165 PIN_FIELD16(118, 118, 0xcf0, 0x10, 15, 1), 166 PIN_FIELD16(119, 119, 0xcf0, 0x10, 7, 1), 167 PIN_FIELD16(120, 120, 0xcf0, 0x10, 3, 1), 168 PIN_FIELD16(121, 121, 0xcf0, 0x10, 7, 1), 169 PINS_FIELD16(122, 125, 0xb60, 0x10, 7, 1), 170 PIN_FIELD16(126, 126, 0xb50, 0x10, 12, 1), 171 PINS_FIELD16(127, 142, 0xb60, 0x10, 9, 1), 172 PINS_FIELD16(143, 160, 0xb60, 0x10, 10, 1), 173 PINS_FIELD16(161, 168, 0xb60, 0x10, 12, 1), 174 PINS_FIELD16(169, 183, 0xb60, 0x10, 10, 1), 175 PINS_FIELD16(184, 186, 0xb60, 0x10, 9, 1), 176 PIN_FIELD16(187, 187, 0xb60, 0x10, 14, 1), 177 PIN_FIELD16(188, 188, 0xb50, 0x10, 13, 1), 178 PINS_FIELD16(189, 193, 0xb60, 0x10, 15, 1), 179 PINS_FIELD16(194, 198, 0xb70, 0x10, 0, 1), 180 PIN_FIELD16(199, 199, 0xb50, 0x10, 1, 1), 181 PINS_FIELD16(200, 202, 0xb70, 0x10, 1, 1), 182 PINS_FIELD16(203, 207, 0xb70, 0x10, 2, 1), 183 PINS_FIELD16(208, 209, 0xb70, 0x10, 3, 1), 184 PIN_FIELD16(210, 210, 0xb70, 0x10, 4, 1), 185 PINS_FIELD16(211, 235, 0xb70, 0x10, 5, 1), 186 PINS_FIELD16(236, 241, 0xb70, 0x10, 6, 1), 187 PINS_FIELD16(242, 243, 0xb70, 0x10, 7, 1), 188 PINS_FIELD16(244, 247, 0xb70, 0x10, 8, 1), 189 PIN_FIELD16(248, 248, 0xb70, 0x10, 9, 10), 190 PIN_FIELD16(249, 249, 0x140, 0x10, 3, 1), 191 PIN_FIELD16(250, 250, 0x130, 0x10, 15, 1), 192 PIN_FIELD16(251, 251, 0x130, 0x10, 11, 1), 193 PIN_FIELD16(252, 252, 0x130, 0x10, 7, 1), 194 PIN_FIELD16(253, 253, 0x130, 0x10, 3, 1), 195 PIN_FIELD16(254, 254, 0xf40, 0x10, 15, 1), 196 PIN_FIELD16(255, 255, 0xf40, 0x10, 11, 1), 197 PIN_FIELD16(256, 256, 0xf40, 0x10, 7, 1), 198 PIN_FIELD16(257, 257, 0xf40, 0x10, 3, 1), 199 PIN_FIELD16(258, 258, 0xcb0, 0x10, 11, 1), 200 PIN_FIELD16(259, 259, 0xc90, 0x10, 11, 1), 201 PIN_FIELD16(260, 260, 0x3a0, 0x10, 11, 1), 202 PIN_FIELD16(261, 261, 0x0b0, 0x10, 3, 1), 203 PINS_FIELD16(262, 277, 0xb70, 0x10, 12, 1), 204 PIN_FIELD16(278, 278, 0xb70, 0x10, 13, 1), |
187}; 188 | 205}; 206 |
189static const struct mtk_pin_spec_pupd_set_samereg mt7623_spec_pupd[] = { 190 MTK_PIN_PUPD_SPEC_SR(105, MSDC1_CTRL1, 8, 9, 10), 191 MTK_PIN_PUPD_SPEC_SR(106, MSDC1_CTRL0, 8, 9, 10), 192 MTK_PIN_PUPD_SPEC_SR(107, MSDC1_CTRL3, 0, 1, 2), 193 MTK_PIN_PUPD_SPEC_SR(108, MSDC1_CTRL3, 4, 5, 6), 194 MTK_PIN_PUPD_SPEC_SR(109, MSDC1_CTRL3, 8, 9, 10), 195 MTK_PIN_PUPD_SPEC_SR(110, MSDC1_CTRL3, 12, 13, 14), 196 MTK_PIN_PUPD_SPEC_SR(111, MSDC0_CTRL4, 12, 13, 14), 197 MTK_PIN_PUPD_SPEC_SR(112, MSDC0_CTRL4, 8, 9, 10), 198 MTK_PIN_PUPD_SPEC_SR(113, MSDC0_CTRL4, 4, 5, 6), 199 MTK_PIN_PUPD_SPEC_SR(114, MSDC0_CTRL4, 0, 1, 2), 200 MTK_PIN_PUPD_SPEC_SR(115, MSDC0_CTRL5, 0, 1, 2), 201 MTK_PIN_PUPD_SPEC_SR(116, MSDC0_CTRL1, 8, 9, 10), 202 MTK_PIN_PUPD_SPEC_SR(117, MSDC0_CTRL0, 8, 9, 10), 203 MTK_PIN_PUPD_SPEC_SR(118, MSDC0_CTRL3, 12, 13, 14), 204 MTK_PIN_PUPD_SPEC_SR(119, MSDC0_CTRL3, 8, 9, 10), 205 MTK_PIN_PUPD_SPEC_SR(120, MSDC0_CTRL3, 4, 5, 6), 206 MTK_PIN_PUPD_SPEC_SR(121, MSDC0_CTRL3, 0, 1, 2), | 207static const struct mtk_pin_field_calc mt7623_pin_pullen_range[] = { 208 PIN_FIELD16(0, 278, 0x150, 0x10, 0, 1), |
207}; 208 | 209}; 210 |
209static int mt7623_spec_pull_set(struct regmap *regmap, unsigned int pin, 210 unsigned char align, bool isup, unsigned int r1r0) 211{ 212 return mtk_pctrl_spec_pull_set_samereg(regmap, mt7623_spec_pupd, 213 ARRAY_SIZE(mt7623_spec_pupd), pin, align, isup, r1r0); 214} | 211static const struct mtk_pin_field_calc mt7623_pin_pullsel_range[] = { 212 PIN_FIELD16(0, 278, 0x280, 0x10, 0, 1), 213}; |
215 | 214 |
216static const struct mtk_pin_ies_smt_set mt7623_ies_set[] = { 217 MTK_PIN_IES_SMT_SPEC(0, 6, IES_EN0, 0), 218 MTK_PIN_IES_SMT_SPEC(7, 9, IES_EN0, 1), 219 MTK_PIN_IES_SMT_SPEC(10, 13, IES_EN0, 2), 220 MTK_PIN_IES_SMT_SPEC(14, 15, IES_EN0, 3), 221 MTK_PIN_IES_SMT_SPEC(18, 21, IES_EN0, 5), 222 MTK_PIN_IES_SMT_SPEC(22, 26, IES_EN0, 6), 223 MTK_PIN_IES_SMT_SPEC(27, 29, IES_EN0, 7), 224 MTK_PIN_IES_SMT_SPEC(33, 37, IES_EN0, 8), 225 MTK_PIN_IES_SMT_SPEC(39, 42, IES_EN0, 9), 226 MTK_PIN_IES_SMT_SPEC(43, 45, IES_EN0, 10), 227 MTK_PIN_IES_SMT_SPEC(47, 48, IES_EN0, 11), 228 MTK_PIN_IES_SMT_SPEC(49, 49, IES_EN0, 12), 229 MTK_PIN_IES_SMT_SPEC(53, 56, IES_EN0, 14), 230 MTK_PIN_IES_SMT_SPEC(60, 62, IES_EN1, 0), 231 MTK_PIN_IES_SMT_SPEC(63, 65, IES_EN1, 1), 232 MTK_PIN_IES_SMT_SPEC(66, 71, IES_EN1, 2), 233 MTK_PIN_IES_SMT_SPEC(72, 74, IES_EN0, 12), 234 MTK_PIN_IES_SMT_SPEC(75, 76, IES_EN1, 3), 235 MTK_PIN_IES_SMT_SPEC(83, 84, IES_EN1, 2), 236 MTK_PIN_IES_SMT_SPEC(105, 121, MSDC1_CTRL1, 4), 237 MTK_PIN_IES_SMT_SPEC(122, 125, IES_EN1, 7), 238 MTK_PIN_IES_SMT_SPEC(126, 126, IES_EN0, 12), 239 MTK_PIN_IES_SMT_SPEC(199, 201, IES_EN0, 1), 240 MTK_PIN_IES_SMT_SPEC(203, 207, IES_EN2, 2), 241 MTK_PIN_IES_SMT_SPEC(208, 209, IES_EN2, 3), 242 MTK_PIN_IES_SMT_SPEC(236, 241, IES_EN2, 6), 243 MTK_PIN_IES_SMT_SPEC(242, 243, IES_EN2, 7), 244 MTK_PIN_IES_SMT_SPEC(261, 261, MSDC1_CTRL2, 4), 245 MTK_PIN_IES_SMT_SPEC(262, 272, IES_EN2, 12), 246 MTK_PIN_IES_SMT_SPEC(274, 276, IES_EN2, 12), 247 MTK_PIN_IES_SMT_SPEC(278, 278, IES_EN2, 13), | 215static const struct mtk_pin_field_calc mt7623_pin_drv_range[] = { 216 PINS_FIELD16(0, 6, 0xf50, 0x10, 0, 4), 217 PINS_FIELD16(7, 9, 0xf50, 0x10, 4, 4), 218 PINS_FIELD16(10, 13, 0xf50, 0x10, 4, 4), 219 PINS_FIELD16(14, 15, 0xf50, 0x10, 12, 4), 220 PINS_FIELD16(16, 17, 0xf60, 0x10, 0, 4), 221 PINS_FIELD16(18, 21, 0xf60, 0x10, 0, 4), 222 PINS_FIELD16(22, 26, 0xf60, 0x10, 8, 4), 223 PINS_FIELD16(27, 29, 0xf60, 0x10, 12, 4), 224 PINS_FIELD16(30, 32, 0xf60, 0x10, 0, 4), 225 PINS_FIELD16(33, 37, 0xf70, 0x10, 0, 4), 226 PIN_FIELD16(38, 38, 0xf70, 0x10, 4, 4), 227 PINS_FIELD16(39, 42, 0xf70, 0x10, 8, 4), 228 PINS_FIELD16(43, 45, 0xf70, 0x10, 12, 4), 229 PINS_FIELD16(47, 48, 0xf80, 0x10, 0, 4), 230 PIN_FIELD16(49, 49, 0xf80, 0x10, 4, 4), 231 PINS_FIELD16(50, 52, 0xf70, 0x10, 4, 4), 232 PINS_FIELD16(53, 56, 0xf80, 0x10, 12, 4), 233 PINS_FIELD16(60, 62, 0xf90, 0x10, 8, 4), 234 PINS_FIELD16(63, 65, 0xf90, 0x10, 12, 4), 235 PINS_FIELD16(66, 71, 0xfa0, 0x10, 0, 4), 236 PINS_FIELD16(72, 74, 0xf80, 0x10, 4, 4), 237 PIN_FIELD16(85, 85, 0xda0, 0x10, 0, 4), 238 PIN_FIELD16(86, 86, 0xd90, 0x10, 0, 4), 239 PINS_FIELD16(87, 90, 0xdb0, 0x10, 0, 4), 240 PIN_FIELD16(105, 105, 0xd40, 0x10, 0, 4), 241 PIN_FIELD16(106, 106, 0xd30, 0x10, 0, 4), 242 PINS_FIELD16(107, 110, 0xd50, 0x10, 0, 4), 243 PINS_FIELD16(111, 115, 0xce0, 0x10, 0, 4), 244 PIN_FIELD16(116, 116, 0xcd0, 0x10, 0, 4), 245 PIN_FIELD16(117, 117, 0xcc0, 0x10, 0, 4), 246 PINS_FIELD16(118, 121, 0xce0, 0x10, 0, 4), 247 PIN_FIELD16(126, 126, 0xf80, 0x10, 4, 4), 248 PIN_FIELD16(188, 188, 0xf70, 0x10, 4, 4), 249 PINS_FIELD16(189, 193, 0xfe0, 0x10, 8, 4), 250 PINS_FIELD16(194, 198, 0xfe0, 0x10, 12, 4), 251 PIN_FIELD16(199, 199, 0xf50, 0x10, 4, 4), 252 PINS_FIELD16(200, 202, 0xfd0, 0x10, 0, 4), 253 PINS_FIELD16(203, 207, 0xfd0, 0x10, 4, 4), 254 PINS_FIELD16(208, 209, 0xfd0, 0x10, 8, 4), 255 PIN_FIELD16(210, 210, 0xfd0, 0x10, 12, 4), 256 PINS_FIELD16(211, 235, 0xff0, 0x10, 0, 4), 257 PINS_FIELD16(236, 241, 0xff0, 0x10, 4, 4), 258 PINS_FIELD16(242, 243, 0xff0, 0x10, 8, 4), 259 PIN_FIELD16(248, 248, 0xf00, 0x10, 0, 4), 260 PINS_FIELD16(249, 256, 0xfc0, 0x10, 0, 4), 261 PIN_FIELD16(257, 257, 0xce0, 0x10, 0, 4), 262 PIN_FIELD16(258, 258, 0xcb0, 0x10, 0, 4), 263 PIN_FIELD16(259, 259, 0xc90, 0x10, 0, 4), 264 PIN_FIELD16(260, 260, 0x3a0, 0x10, 0, 4), 265 PIN_FIELD16(261, 261, 0xd50, 0x10, 0, 4), 266 PINS_FIELD16(262, 277, 0xf00, 0x10, 8, 4), 267 PIN_FIELD16(278, 278, 0xf70, 0x10, 8, 4), |
248}; 249 | 268}; 269 |
250static const struct mtk_pin_ies_smt_set mt7623_smt_set[] = { 251 MTK_PIN_IES_SMT_SPEC(0, 6, SMT_EN0, 0), 252 MTK_PIN_IES_SMT_SPEC(7, 9, SMT_EN0, 1), 253 MTK_PIN_IES_SMT_SPEC(10, 13, SMT_EN0, 2), 254 MTK_PIN_IES_SMT_SPEC(14, 15, SMT_EN0, 3), 255 MTK_PIN_IES_SMT_SPEC(18, 21, SMT_EN0, 5), 256 MTK_PIN_IES_SMT_SPEC(22, 26, SMT_EN0, 6), 257 MTK_PIN_IES_SMT_SPEC(27, 29, SMT_EN0, 7), 258 MTK_PIN_IES_SMT_SPEC(33, 37, SMT_EN0, 8), 259 MTK_PIN_IES_SMT_SPEC(39, 42, SMT_EN0, 9), 260 MTK_PIN_IES_SMT_SPEC(43, 45, SMT_EN0, 10), 261 MTK_PIN_IES_SMT_SPEC(47, 48, SMT_EN0, 11), 262 MTK_PIN_IES_SMT_SPEC(49, 49, SMT_EN0, 12), 263 MTK_PIN_IES_SMT_SPEC(53, 56, SMT_EN0, 14), 264 MTK_PIN_IES_SMT_SPEC(60, 62, SMT_EN1, 0), 265 MTK_PIN_IES_SMT_SPEC(63, 65, SMT_EN1, 1), 266 MTK_PIN_IES_SMT_SPEC(66, 71, SMT_EN1, 2), 267 MTK_PIN_IES_SMT_SPEC(72, 74, SMT_EN0, 12), 268 MTK_PIN_IES_SMT_SPEC(75, 76, SMT_EN1, 3), 269 MTK_PIN_IES_SMT_SPEC(83, 84, SMT_EN1, 2), 270 MTK_PIN_IES_SMT_SPEC(105, 106, MSDC1_CTRL1, 11), 271 MTK_PIN_IES_SMT_SPEC(107, 107, MSDC1_CTRL3, 3), 272 MTK_PIN_IES_SMT_SPEC(108, 108, MSDC1_CTRL3, 7), 273 MTK_PIN_IES_SMT_SPEC(109, 109, MSDC1_CTRL3, 11), 274 MTK_PIN_IES_SMT_SPEC(110, 111, MSDC1_CTRL3, 15), 275 MTK_PIN_IES_SMT_SPEC(112, 112, MSDC0_CTRL4, 11), 276 MTK_PIN_IES_SMT_SPEC(113, 113, MSDC0_CTRL4, 7), 277 MTK_PIN_IES_SMT_SPEC(114, 115, MSDC0_CTRL4, 3), 278 MTK_PIN_IES_SMT_SPEC(116, 117, MSDC0_CTRL1, 11), 279 MTK_PIN_IES_SMT_SPEC(118, 118, MSDC0_CTRL3, 15), 280 MTK_PIN_IES_SMT_SPEC(119, 119, MSDC0_CTRL3, 11), 281 MTK_PIN_IES_SMT_SPEC(120, 120, MSDC0_CTRL3, 7), 282 MTK_PIN_IES_SMT_SPEC(121, 121, MSDC0_CTRL3, 3), 283 MTK_PIN_IES_SMT_SPEC(122, 125, SMT_EN1, 7), 284 MTK_PIN_IES_SMT_SPEC(126, 126, SMT_EN0, 12), 285 MTK_PIN_IES_SMT_SPEC(199, 201, SMT_EN0, 1), 286 MTK_PIN_IES_SMT_SPEC(203, 207, SMT_EN2, 2), 287 MTK_PIN_IES_SMT_SPEC(208, 209, SMT_EN2, 3), 288 MTK_PIN_IES_SMT_SPEC(236, 241, SMT_EN2, 6), 289 MTK_PIN_IES_SMT_SPEC(242, 243, SMT_EN2, 7), 290 MTK_PIN_IES_SMT_SPEC(261, 261, MSDC1_CTRL6, 3), 291 MTK_PIN_IES_SMT_SPEC(262, 272, SMT_EN2, 12), 292 MTK_PIN_IES_SMT_SPEC(274, 276, SMT_EN2, 12), 293 MTK_PIN_IES_SMT_SPEC(278, 278, SMT_EN2, 13), | 270static const struct mtk_pin_field_calc mt7623_pin_tdsel_range[] = { 271 PINS_FIELD16(262, 276, 0x4c0, 0x10, 0, 4), |
294}; 295 | 272}; 273 |
296static int mt7623_ies_smt_set(struct regmap *regmap, unsigned int pin, 297 unsigned char align, int value, enum pin_config_param arg) 298{ 299 if (arg == PIN_CONFIG_INPUT_ENABLE) 300 return mtk_pconf_spec_set_ies_smt_range(regmap, mt7623_ies_set, 301 ARRAY_SIZE(mt7623_ies_set), pin, align, value); 302 else if (arg == PIN_CONFIG_INPUT_SCHMITT_ENABLE) 303 return mtk_pconf_spec_set_ies_smt_range(regmap, mt7623_smt_set, 304 ARRAY_SIZE(mt7623_smt_set), pin, align, value); 305 return -EINVAL; 306} | 274static const struct mtk_pin_field_calc mt7623_pin_pupd_range[] = { 275 /* MSDC0 */ 276 PIN_FIELD16(111, 111, 0xd00, 0x10, 12, 1), 277 PIN_FIELD16(112, 112, 0xd00, 0x10, 8, 1), 278 PIN_FIELD16(113, 113, 0xd00, 0x10, 4, 1), 279 PIN_FIELD16(114, 114, 0xd00, 0x10, 0, 1), 280 PIN_FIELD16(115, 115, 0xd10, 0x10, 0, 1), 281 PIN_FIELD16(116, 116, 0xcd0, 0x10, 8, 1), 282 PIN_FIELD16(117, 117, 0xcc0, 0x10, 8, 1), 283 PIN_FIELD16(118, 118, 0xcf0, 0x10, 12, 1), 284 PIN_FIELD16(119, 119, 0xcf0, 0x10, 8, 1), 285 PIN_FIELD16(120, 120, 0xcf0, 0x10, 4, 1), 286 PIN_FIELD16(121, 121, 0xcf0, 0x10, 0, 1), 287 /* MSDC1 */ 288 PIN_FIELD16(105, 105, 0xd40, 0x10, 8, 1), 289 PIN_FIELD16(106, 106, 0xd30, 0x10, 8, 1), 290 PIN_FIELD16(107, 107, 0xd60, 0x10, 0, 1), 291 PIN_FIELD16(108, 108, 0xd60, 0x10, 10, 1), 292 PIN_FIELD16(109, 109, 0xd60, 0x10, 4, 1), 293 PIN_FIELD16(110, 110, 0xc60, 0x10, 12, 1), 294 /* MSDC1 */ 295 PIN_FIELD16(85, 85, 0xda0, 0x10, 8, 1), 296 PIN_FIELD16(86, 86, 0xd90, 0x10, 8, 1), 297 PIN_FIELD16(87, 87, 0xdc0, 0x10, 0, 1), 298 PIN_FIELD16(88, 88, 0xdc0, 0x10, 10, 1), 299 PIN_FIELD16(89, 89, 0xdc0, 0x10, 4, 1), 300 PIN_FIELD16(90, 90, 0xdc0, 0x10, 12, 1), 301 /* MSDC0E */ 302 PIN_FIELD16(249, 249, 0x140, 0x10, 0, 1), 303 PIN_FIELD16(250, 250, 0x130, 0x10, 12, 1), 304 PIN_FIELD16(251, 251, 0x130, 0x10, 8, 1), 305 PIN_FIELD16(252, 252, 0x130, 0x10, 4, 1), 306 PIN_FIELD16(253, 253, 0x130, 0x10, 0, 1), 307 PIN_FIELD16(254, 254, 0xf40, 0x10, 12, 1), 308 PIN_FIELD16(255, 255, 0xf40, 0x10, 8, 1), 309 PIN_FIELD16(256, 256, 0xf40, 0x10, 4, 1), 310 PIN_FIELD16(257, 257, 0xf40, 0x10, 0, 1), 311 PIN_FIELD16(258, 258, 0xcb0, 0x10, 8, 1), 312 PIN_FIELD16(259, 259, 0xc90, 0x10, 8, 1), 313 PIN_FIELD16(261, 261, 0x140, 0x10, 8, 1), 314}; |
307 | 315 |
308static const struct mtk_pinctrl_devdata mt7623_pinctrl_data = { 309 .pins = mtk_pins_mt7623, 310 .npins = ARRAY_SIZE(mtk_pins_mt7623), 311 .grp_desc = mt7623_drv_grp, 312 .n_grp_cls = ARRAY_SIZE(mt7623_drv_grp), 313 .pin_drv_grp = mt7623_pin_drv, 314 .n_pin_drv_grps = ARRAY_SIZE(mt7623_pin_drv), 315 .spec_pull_set = mt7623_spec_pull_set, 316 .spec_ies_smt_set = mt7623_ies_smt_set, 317 .dir_offset = 0x0000, 318 .pullen_offset = 0x0150, 319 .pullsel_offset = 0x0280, 320 .dout_offset = 0x0500, 321 .din_offset = 0x0630, 322 .pinmux_offset = 0x0760, 323 .type1_start = 280, 324 .type1_end = 280, 325 .port_shf = 4, 326 .port_mask = 0x1f, 327 .port_align = 4, 328 .eint_offsets = { 329 .name = "mt7623_eint", 330 .stat = 0x000, 331 .ack = 0x040, 332 .mask = 0x080, 333 .mask_set = 0x0c0, 334 .mask_clr = 0x100, 335 .sens = 0x140, 336 .sens_set = 0x180, 337 .sens_clr = 0x1c0, 338 .soft = 0x200, 339 .soft_set = 0x240, 340 .soft_clr = 0x280, 341 .pol = 0x300, 342 .pol_set = 0x340, 343 .pol_clr = 0x380, 344 .dom_en = 0x400, 345 .dbnc_ctrl = 0x500, 346 .dbnc_set = 0x600, 347 .dbnc_clr = 0x700, 348 .port_mask = 6, 349 .ports = 6, 350 }, 351 .ap_num = 169, 352 .db_cnt = 16, | 316static const struct mtk_pin_field_calc mt7623_pin_r1_range[] = { 317 /* MSDC0 */ 318 PIN_FIELD16(111, 111, 0xd00, 0x10, 13, 1), 319 PIN_FIELD16(112, 112, 0xd00, 0x10, 9, 1), 320 PIN_FIELD16(113, 113, 0xd00, 0x10, 5, 1), 321 PIN_FIELD16(114, 114, 0xd00, 0x10, 1, 1), 322 PIN_FIELD16(115, 115, 0xd10, 0x10, 1, 1), 323 PIN_FIELD16(116, 116, 0xcd0, 0x10, 9, 1), 324 PIN_FIELD16(117, 117, 0xcc0, 0x10, 9, 1), 325 PIN_FIELD16(118, 118, 0xcf0, 0x10, 13, 1), 326 PIN_FIELD16(119, 119, 0xcf0, 0x10, 9, 1), 327 PIN_FIELD16(120, 120, 0xcf0, 0x10, 5, 1), 328 PIN_FIELD16(121, 121, 0xcf0, 0x10, 1, 1), 329 /* MSDC1 */ 330 PIN_FIELD16(105, 105, 0xd40, 0x10, 9, 1), 331 PIN_FIELD16(106, 106, 0xd30, 0x10, 9, 1), 332 PIN_FIELD16(107, 107, 0xd60, 0x10, 1, 1), 333 PIN_FIELD16(108, 108, 0xd60, 0x10, 9, 1), 334 PIN_FIELD16(109, 109, 0xd60, 0x10, 5, 1), 335 PIN_FIELD16(110, 110, 0xc60, 0x10, 13, 1), 336 /* MSDC2 */ 337 PIN_FIELD16(85, 85, 0xda0, 0x10, 9, 1), 338 PIN_FIELD16(86, 86, 0xd90, 0x10, 9, 1), 339 PIN_FIELD16(87, 87, 0xdc0, 0x10, 1, 1), 340 PIN_FIELD16(88, 88, 0xdc0, 0x10, 9, 1), 341 PIN_FIELD16(89, 89, 0xdc0, 0x10, 5, 1), 342 PIN_FIELD16(90, 90, 0xdc0, 0x10, 13, 1), 343 /* MSDC0E */ 344 PIN_FIELD16(249, 249, 0x140, 0x10, 1, 1), 345 PIN_FIELD16(250, 250, 0x130, 0x10, 13, 1), 346 PIN_FIELD16(251, 251, 0x130, 0x10, 9, 1), 347 PIN_FIELD16(252, 252, 0x130, 0x10, 5, 1), 348 PIN_FIELD16(253, 253, 0x130, 0x10, 1, 1), 349 PIN_FIELD16(254, 254, 0xf40, 0x10, 13, 1), 350 PIN_FIELD16(255, 255, 0xf40, 0x10, 9, 1), 351 PIN_FIELD16(256, 256, 0xf40, 0x10, 5, 1), 352 PIN_FIELD16(257, 257, 0xf40, 0x10, 1, 1), 353 PIN_FIELD16(258, 258, 0xcb0, 0x10, 9, 1), 354 PIN_FIELD16(259, 259, 0xc90, 0x10, 9, 1), 355 PIN_FIELD16(261, 261, 0x140, 0x10, 9, 1), |
353}; 354 | 356}; 357 |
355static int mt7623_pinctrl_probe(struct platform_device *pdev) | 358static const struct mtk_pin_field_calc mt7623_pin_r0_range[] = { 359 /* MSDC0 */ 360 PIN_FIELD16(111, 111, 0xd00, 0x10, 14, 1), 361 PIN_FIELD16(112, 112, 0xd00, 0x10, 10, 1), 362 PIN_FIELD16(113, 113, 0xd00, 0x10, 6, 1), 363 PIN_FIELD16(114, 114, 0xd00, 0x10, 2, 1), 364 PIN_FIELD16(115, 115, 0xd10, 0x10, 2, 1), 365 PIN_FIELD16(116, 116, 0xcd0, 0x10, 10, 1), 366 PIN_FIELD16(117, 117, 0xcc0, 0x10, 10, 1), 367 PIN_FIELD16(118, 118, 0xcf0, 0x10, 14, 1), 368 PIN_FIELD16(119, 119, 0xcf0, 0x10, 10, 1), 369 PIN_FIELD16(120, 120, 0xcf0, 0x10, 6, 1), 370 PIN_FIELD16(121, 121, 0xcf0, 0x10, 2, 1), 371 /* MSDC1 */ 372 PIN_FIELD16(105, 105, 0xd40, 0x10, 10, 1), 373 PIN_FIELD16(106, 106, 0xd30, 0x10, 10, 1), 374 PIN_FIELD16(107, 107, 0xd60, 0x10, 2, 1), 375 PIN_FIELD16(108, 108, 0xd60, 0x10, 8, 1), 376 PIN_FIELD16(109, 109, 0xd60, 0x10, 6, 1), 377 PIN_FIELD16(110, 110, 0xc60, 0x10, 14, 1), 378 /* MSDC2 */ 379 PIN_FIELD16(85, 85, 0xda0, 0x10, 10, 1), 380 PIN_FIELD16(86, 86, 0xd90, 0x10, 10, 1), 381 PIN_FIELD16(87, 87, 0xdc0, 0x10, 2, 1), 382 PIN_FIELD16(88, 88, 0xdc0, 0x10, 8, 1), 383 PIN_FIELD16(89, 89, 0xdc0, 0x10, 6, 1), 384 PIN_FIELD16(90, 90, 0xdc0, 0x10, 14, 1), 385 /* MSDC0E */ 386 PIN_FIELD16(249, 249, 0x140, 0x10, 2, 1), 387 PIN_FIELD16(250, 250, 0x130, 0x10, 14, 1), 388 PIN_FIELD16(251, 251, 0x130, 0x10, 10, 1), 389 PIN_FIELD16(252, 252, 0x130, 0x10, 6, 1), 390 PIN_FIELD16(253, 253, 0x130, 0x10, 2, 1), 391 PIN_FIELD16(254, 254, 0xf40, 0x10, 14, 1), 392 PIN_FIELD16(255, 255, 0xf40, 0x10, 10, 1), 393 PIN_FIELD16(256, 256, 0xf40, 0x10, 6, 1), 394 PIN_FIELD16(257, 257, 0xf40, 0x10, 5, 1), 395 PIN_FIELD16(258, 258, 0xcb0, 0x10, 10, 1), 396 PIN_FIELD16(259, 259, 0xc90, 0x10, 10, 1), 397 PIN_FIELD16(261, 261, 0x140, 0x10, 10, 1), 398}; 399 400static const struct mtk_pin_reg_calc mt7623_reg_cals[] = { 401 [PINCTRL_PIN_REG_MODE] = MTK_RANGE(mt7623_pin_mode_range), 402 [PINCTRL_PIN_REG_DIR] = MTK_RANGE(mt7623_pin_dir_range), 403 [PINCTRL_PIN_REG_DI] = MTK_RANGE(mt7623_pin_di_range), 404 [PINCTRL_PIN_REG_DO] = MTK_RANGE(mt7623_pin_do_range), 405 [PINCTRL_PIN_REG_SMT] = MTK_RANGE(mt7623_pin_smt_range), 406 [PINCTRL_PIN_REG_PULLSEL] = MTK_RANGE(mt7623_pin_pullsel_range), 407 [PINCTRL_PIN_REG_PULLEN] = MTK_RANGE(mt7623_pin_pullen_range), 408 [PINCTRL_PIN_REG_DRV] = MTK_RANGE(mt7623_pin_drv_range), 409 [PINCTRL_PIN_REG_TDSEL] = MTK_RANGE(mt7623_pin_tdsel_range), 410 [PINCTRL_PIN_REG_IES] = MTK_RANGE(mt7623_pin_ies_range), 411 [PINCTRL_PIN_REG_PUPD] = MTK_RANGE(mt7623_pin_pupd_range), 412 [PINCTRL_PIN_REG_R0] = MTK_RANGE(mt7623_pin_r0_range), 413 [PINCTRL_PIN_REG_R1] = MTK_RANGE(mt7623_pin_r1_range), 414}; 415 416static const struct mtk_pin_desc mt7623_pins[] = { 417 MT7623_PIN(0, "PWRAP_SPI0_MI", 148, DRV_GRP3), 418 MT7623_PIN(1, "PWRAP_SPI0_MO", 149, DRV_GRP3), 419 MT7623_PIN(2, "PWRAP_INT", 150, DRV_GRP3), 420 MT7623_PIN(3, "PWRAP_SPI0_CK", 151, DRV_GRP3), 421 MT7623_PIN(4, "PWRAP_SPI0_CSN", 152, DRV_GRP3), 422 MT7623_PIN(5, "PWRAP_SPI0_CK2", 153, DRV_GRP3), 423 MT7623_PIN(6, "PWRAP_SPI0_CSN2", 154, DRV_GRP3), 424 MT7623_PIN(7, "SPI1_CSN", 155, DRV_GRP3), 425 MT7623_PIN(8, "SPI1_MI", 156, DRV_GRP3), 426 MT7623_PIN(9, "SPI1_MO", 157, DRV_GRP3), 427 MT7623_PIN(10, "RTC32K_CK", 158, DRV_GRP3), 428 MT7623_PIN(11, "WATCHDOG", 159, DRV_GRP3), 429 MT7623_PIN(12, "SRCLKENA", 160, DRV_GRP3), 430 MT7623_PIN(13, "SRCLKENAI", 161, DRV_GRP3), 431 MT7623_PIN(14, "URXD2", 162, DRV_GRP1), 432 MT7623_PIN(15, "UTXD2", 163, DRV_GRP1), 433 MT7623_PIN(16, "I2S5_DATA_IN", 164, DRV_GRP1), 434 MT7623_PIN(17, "I2S5_BCK", 165, DRV_GRP1), 435 MT7623_PIN(18, "PCM_CLK", 166, DRV_GRP1), 436 MT7623_PIN(19, "PCM_SYNC", 167, DRV_GRP1), 437 MT7623_PIN(20, "PCM_RX", EINT_NA, DRV_GRP1), 438 MT7623_PIN(21, "PCM_TX", EINT_NA, DRV_GRP1), 439 MT7623_PIN(22, "EINT0", 0, DRV_GRP1), 440 MT7623_PIN(23, "EINT1", 1, DRV_GRP1), 441 MT7623_PIN(24, "EINT2", 2, DRV_GRP1), 442 MT7623_PIN(25, "EINT3", 3, DRV_GRP1), 443 MT7623_PIN(26, "EINT4", 4, DRV_GRP1), 444 MT7623_PIN(27, "EINT5", 5, DRV_GRP1), 445 MT7623_PIN(28, "EINT6", 6, DRV_GRP1), 446 MT7623_PIN(29, "EINT7", 7, DRV_GRP1), 447 MT7623_PIN(30, "I2S5_LRCK", 12, DRV_GRP1), 448 MT7623_PIN(31, "I2S5_MCLK", 13, DRV_GRP1), 449 MT7623_PIN(32, "I2S5_DATA", 14, DRV_GRP1), 450 MT7623_PIN(33, "I2S1_DATA", 15, DRV_GRP1), 451 MT7623_PIN(34, "I2S1_DATA_IN", 16, DRV_GRP1), 452 MT7623_PIN(35, "I2S1_BCK", 17, DRV_GRP1), 453 MT7623_PIN(36, "I2S1_LRCK", 18, DRV_GRP1), 454 MT7623_PIN(37, "I2S1_MCLK", 19, DRV_GRP1), 455 MT7623_PIN(38, "I2S2_DATA", 20, DRV_GRP1), 456 MT7623_PIN(39, "JTMS", 21, DRV_GRP3), 457 MT7623_PIN(40, "JTCK", 22, DRV_GRP3), 458 MT7623_PIN(41, "JTDI", 23, DRV_GRP3), 459 MT7623_PIN(42, "JTDO", 24, DRV_GRP3), 460 MT7623_PIN(43, "NCLE", 25, DRV_GRP1), 461 MT7623_PIN(44, "NCEB1", 26, DRV_GRP1), 462 MT7623_PIN(45, "NCEB0", 27, DRV_GRP1), 463 MT7623_PIN(46, "IR", 28, DRV_FIXED), 464 MT7623_PIN(47, "NREB", 29, DRV_GRP1), 465 MT7623_PIN(48, "NRNB", 30, DRV_GRP1), 466 MT7623_PIN(49, "I2S0_DATA", 31, DRV_GRP1), 467 MT7623_PIN(50, "I2S2_BCK", 32, DRV_GRP1), 468 MT7623_PIN(51, "I2S2_DATA_IN", 33, DRV_GRP1), 469 MT7623_PIN(52, "I2S2_LRCK", 34, DRV_GRP1), 470 MT7623_PIN(53, "SPI0_CSN", 35, DRV_GRP1), 471 MT7623_PIN(54, "SPI0_CK", 36, DRV_GRP1), 472 MT7623_PIN(55, "SPI0_MI", 37, DRV_GRP1), 473 MT7623_PIN(56, "SPI0_MO", 38, DRV_GRP1), 474 MT7623_PIN(57, "SDA1", 39, DRV_FIXED), 475 MT7623_PIN(58, "SCL1", 40, DRV_FIXED), 476 MT7623_PIN(59, "RAMBUF_I_CLK", EINT_NA, DRV_FIXED), 477 MT7623_PIN(60, "WB_RSTB", 41, DRV_GRP3), 478 MT7623_PIN(61, "F2W_DATA", 42, DRV_GRP3), 479 MT7623_PIN(62, "F2W_CLK", 43, DRV_GRP3), 480 MT7623_PIN(63, "WB_SCLK", 44, DRV_GRP3), 481 MT7623_PIN(64, "WB_SDATA", 45, DRV_GRP3), 482 MT7623_PIN(65, "WB_SEN", 46, DRV_GRP3), 483 MT7623_PIN(66, "WB_CRTL0", 47, DRV_GRP3), 484 MT7623_PIN(67, "WB_CRTL1", 48, DRV_GRP3), 485 MT7623_PIN(68, "WB_CRTL2", 49, DRV_GRP3), 486 MT7623_PIN(69, "WB_CRTL3", 50, DRV_GRP3), 487 MT7623_PIN(70, "WB_CRTL4", 51, DRV_GRP3), 488 MT7623_PIN(71, "WB_CRTL5", 52, DRV_GRP3), 489 MT7623_PIN(72, "I2S0_DATA_IN", 53, DRV_GRP1), 490 MT7623_PIN(73, "I2S0_LRCK", 54, DRV_GRP1), 491 MT7623_PIN(74, "I2S0_BCK", 55, DRV_GRP1), 492 MT7623_PIN(75, "SDA0", 56, DRV_FIXED), 493 MT7623_PIN(76, "SCL0", 57, DRV_FIXED), 494 MT7623_PIN(77, "SDA2", 58, DRV_FIXED), 495 MT7623_PIN(78, "SCL2", 59, DRV_FIXED), 496 MT7623_PIN(79, "URXD0", 60, DRV_FIXED), 497 MT7623_PIN(80, "UTXD0", 61, DRV_FIXED), 498 MT7623_PIN(81, "URXD1", 62, DRV_FIXED), 499 MT7623_PIN(82, "UTXD1", 63, DRV_FIXED), 500 MT7623_PIN(83, "LCM_RST", 64, DRV_FIXED), 501 MT7623_PIN(84, "DSI_TE", 65, DRV_FIXED), 502 MT7623_PIN(85, "MSDC2_CMD", 66, DRV_GRP4), 503 MT7623_PIN(86, "MSDC2_CLK", 67, DRV_GRP4), 504 MT7623_PIN(87, "MSDC2_DAT0", 68, DRV_GRP4), 505 MT7623_PIN(88, "MSDC2_DAT1", 69, DRV_GRP4), 506 MT7623_PIN(89, "MSDC2_DAT2", 70, DRV_GRP4), 507 MT7623_PIN(90, "MSDC2_DAT3", 71, DRV_GRP4), 508 MT7623_PIN(91, "TDN3", EINT_NA, DRV_FIXED), 509 MT7623_PIN(92, "TDP3", EINT_NA, DRV_FIXED), 510 MT7623_PIN(93, "TDN2", EINT_NA, DRV_FIXED), 511 MT7623_PIN(94, "TDP2", EINT_NA, DRV_FIXED), 512 MT7623_PIN(95, "TCN", EINT_NA, DRV_FIXED), 513 MT7623_PIN(96, "TCP", EINT_NA, DRV_FIXED), 514 MT7623_PIN(97, "TDN1", EINT_NA, DRV_FIXED), 515 MT7623_PIN(98, "TDP1", EINT_NA, DRV_FIXED), 516 MT7623_PIN(99, "TDN0", EINT_NA, DRV_FIXED), 517 MT7623_PIN(100, "TDP0", EINT_NA, DRV_FIXED), 518 MT7623_PIN(101, "SPI2_CSN", 74, DRV_FIXED), 519 MT7623_PIN(102, "SPI2_MI", 75, DRV_FIXED), 520 MT7623_PIN(103, "SPI2_MO", 76, DRV_FIXED), 521 MT7623_PIN(104, "SPI2_CLK", 77, DRV_FIXED), 522 MT7623_PIN(105, "MSDC1_CMD", 78, DRV_GRP4), 523 MT7623_PIN(106, "MSDC1_CLK", 79, DRV_GRP4), 524 MT7623_PIN(107, "MSDC1_DAT0", 80, DRV_GRP4), 525 MT7623_PIN(108, "MSDC1_DAT1", 81, DRV_GRP4), 526 MT7623_PIN(109, "MSDC1_DAT2", 82, DRV_GRP4), 527 MT7623_PIN(110, "MSDC1_DAT3", 83, DRV_GRP4), 528 MT7623_PIN(111, "MSDC0_DAT7", 84, DRV_GRP4), 529 MT7623_PIN(112, "MSDC0_DAT6", 85, DRV_GRP4), 530 MT7623_PIN(113, "MSDC0_DAT5", 86, DRV_GRP4), 531 MT7623_PIN(114, "MSDC0_DAT4", 87, DRV_GRP4), 532 MT7623_PIN(115, "MSDC0_RSTB", 88, DRV_GRP4), 533 MT7623_PIN(116, "MSDC0_CMD", 89, DRV_GRP4), 534 MT7623_PIN(117, "MSDC0_CLK", 90, DRV_GRP4), 535 MT7623_PIN(118, "MSDC0_DAT3", 91, DRV_GRP4), 536 MT7623_PIN(119, "MSDC0_DAT2", 92, DRV_GRP4), 537 MT7623_PIN(120, "MSDC0_DAT1", 93, DRV_GRP4), 538 MT7623_PIN(121, "MSDC0_DAT0", 94, DRV_GRP4), 539 MT7623_PIN(122, "CEC", 95, DRV_FIXED), 540 MT7623_PIN(123, "HTPLG", 96, DRV_FIXED), 541 MT7623_PIN(124, "HDMISCK", 97, DRV_FIXED), 542 MT7623_PIN(125, "HDMISD", 98, DRV_FIXED), 543 MT7623_PIN(126, "I2S0_MCLK", 99, DRV_GRP1), 544 MT7623_PIN(127, "RAMBUF_IDATA0", EINT_NA, DRV_FIXED), 545 MT7623_PIN(128, "RAMBUF_IDATA1", EINT_NA, DRV_FIXED), 546 MT7623_PIN(129, "RAMBUF_IDATA2", EINT_NA, DRV_FIXED), 547 MT7623_PIN(130, "RAMBUF_IDATA3", EINT_NA, DRV_FIXED), 548 MT7623_PIN(131, "RAMBUF_IDATA4", EINT_NA, DRV_FIXED), 549 MT7623_PIN(132, "RAMBUF_IDATA5", EINT_NA, DRV_FIXED), 550 MT7623_PIN(133, "RAMBUF_IDATA6", EINT_NA, DRV_FIXED), 551 MT7623_PIN(134, "RAMBUF_IDATA7", EINT_NA, DRV_FIXED), 552 MT7623_PIN(135, "RAMBUF_IDATA8", EINT_NA, DRV_FIXED), 553 MT7623_PIN(136, "RAMBUF_IDATA9", EINT_NA, DRV_FIXED), 554 MT7623_PIN(137, "RAMBUF_IDATA10", EINT_NA, DRV_FIXED), 555 MT7623_PIN(138, "RAMBUF_IDATA11", EINT_NA, DRV_FIXED), 556 MT7623_PIN(139, "RAMBUF_IDATA12", EINT_NA, DRV_FIXED), 557 MT7623_PIN(140, "RAMBUF_IDATA13", EINT_NA, DRV_FIXED), 558 MT7623_PIN(141, "RAMBUF_IDATA14", EINT_NA, DRV_FIXED), 559 MT7623_PIN(142, "RAMBUF_IDATA15", EINT_NA, DRV_FIXED), 560 MT7623_PIN(143, "RAMBUF_ODATA0", EINT_NA, DRV_FIXED), 561 MT7623_PIN(144, "RAMBUF_ODATA1", EINT_NA, DRV_FIXED), 562 MT7623_PIN(145, "RAMBUF_ODATA2", EINT_NA, DRV_FIXED), 563 MT7623_PIN(146, "RAMBUF_ODATA3", EINT_NA, DRV_FIXED), 564 MT7623_PIN(147, "RAMBUF_ODATA4", EINT_NA, DRV_FIXED), 565 MT7623_PIN(148, "RAMBUF_ODATA5", EINT_NA, DRV_FIXED), 566 MT7623_PIN(149, "RAMBUF_ODATA6", EINT_NA, DRV_FIXED), 567 MT7623_PIN(150, "RAMBUF_ODATA7", EINT_NA, DRV_FIXED), 568 MT7623_PIN(151, "RAMBUF_ODATA8", EINT_NA, DRV_FIXED), 569 MT7623_PIN(152, "RAMBUF_ODATA9", EINT_NA, DRV_FIXED), 570 MT7623_PIN(153, "RAMBUF_ODATA10", EINT_NA, DRV_FIXED), 571 MT7623_PIN(154, "RAMBUF_ODATA11", EINT_NA, DRV_FIXED), 572 MT7623_PIN(155, "RAMBUF_ODATA12", EINT_NA, DRV_FIXED), 573 MT7623_PIN(156, "RAMBUF_ODATA13", EINT_NA, DRV_FIXED), 574 MT7623_PIN(157, "RAMBUF_ODATA14", EINT_NA, DRV_FIXED), 575 MT7623_PIN(158, "RAMBUF_ODATA15", EINT_NA, DRV_FIXED), 576 MT7623_PIN(159, "RAMBUF_BE0", EINT_NA, DRV_FIXED), 577 MT7623_PIN(160, "RAMBUF_BE1", EINT_NA, DRV_FIXED), 578 MT7623_PIN(161, "AP2PT_INT", EINT_NA, DRV_FIXED), 579 MT7623_PIN(162, "AP2PT_INT_CLR", EINT_NA, DRV_FIXED), 580 MT7623_PIN(163, "PT2AP_INT", EINT_NA, DRV_FIXED), 581 MT7623_PIN(164, "PT2AP_INT_CLR", EINT_NA, DRV_FIXED), 582 MT7623_PIN(165, "AP2UP_INT", EINT_NA, DRV_FIXED), 583 MT7623_PIN(166, "AP2UP_INT_CLR", EINT_NA, DRV_FIXED), 584 MT7623_PIN(167, "UP2AP_INT", EINT_NA, DRV_FIXED), 585 MT7623_PIN(168, "UP2AP_INT_CLR", EINT_NA, DRV_FIXED), 586 MT7623_PIN(169, "RAMBUF_ADDR0", EINT_NA, DRV_FIXED), 587 MT7623_PIN(170, "RAMBUF_ADDR1", EINT_NA, DRV_FIXED), 588 MT7623_PIN(171, "RAMBUF_ADDR2", EINT_NA, DRV_FIXED), 589 MT7623_PIN(172, "RAMBUF_ADDR3", EINT_NA, DRV_FIXED), 590 MT7623_PIN(173, "RAMBUF_ADDR4", EINT_NA, DRV_FIXED), 591 MT7623_PIN(174, "RAMBUF_ADDR5", EINT_NA, DRV_FIXED), 592 MT7623_PIN(175, "RAMBUF_ADDR6", EINT_NA, DRV_FIXED), 593 MT7623_PIN(176, "RAMBUF_ADDR7", EINT_NA, DRV_FIXED), 594 MT7623_PIN(177, "RAMBUF_ADDR8", EINT_NA, DRV_FIXED), 595 MT7623_PIN(178, "RAMBUF_ADDR9", EINT_NA, DRV_FIXED), 596 MT7623_PIN(179, "RAMBUF_ADDR10", EINT_NA, DRV_FIXED), 597 MT7623_PIN(180, "RAMBUF_RW", EINT_NA, DRV_FIXED), 598 MT7623_PIN(181, "RAMBUF_LAST", EINT_NA, DRV_FIXED), 599 MT7623_PIN(182, "RAMBUF_HP", EINT_NA, DRV_FIXED), 600 MT7623_PIN(183, "RAMBUF_REQ", EINT_NA, DRV_FIXED), 601 MT7623_PIN(184, "RAMBUF_ALE", EINT_NA, DRV_FIXED), 602 MT7623_PIN(185, "RAMBUF_DLE", EINT_NA, DRV_FIXED), 603 MT7623_PIN(186, "RAMBUF_WDLE", EINT_NA, DRV_FIXED), 604 MT7623_PIN(187, "RAMBUF_O_CLK", EINT_NA, DRV_FIXED), 605 MT7623_PIN(188, "I2S2_MCLK", 100, DRV_GRP1), 606 MT7623_PIN(189, "I2S3_DATA", 101, DRV_GRP1), 607 MT7623_PIN(190, "I2S3_DATA_IN", 102, DRV_GRP1), 608 MT7623_PIN(191, "I2S3_BCK", 103, DRV_GRP1), 609 MT7623_PIN(192, "I2S3_LRCK", 104, DRV_GRP1), 610 MT7623_PIN(193, "I2S3_MCLK", 105, DRV_GRP1), 611 MT7623_PIN(194, "I2S4_DATA", 106, DRV_GRP1), 612 MT7623_PIN(195, "I2S4_DATA_IN", 107, DRV_GRP1), 613 MT7623_PIN(196, "I2S4_BCK", 108, DRV_GRP1), 614 MT7623_PIN(197, "I2S4_LRCK", 109, DRV_GRP1), 615 MT7623_PIN(198, "I2S4_MCLK", 110, DRV_GRP1), 616 MT7623_PIN(199, "SPI1_CLK", 111, DRV_GRP3), 617 MT7623_PIN(200, "SPDIF_OUT", 112, DRV_GRP1), 618 MT7623_PIN(201, "SPDIF_IN0", 113, DRV_GRP1), 619 MT7623_PIN(202, "SPDIF_IN1", 114, DRV_GRP1), 620 MT7623_PIN(203, "PWM0", 115, DRV_GRP1), 621 MT7623_PIN(204, "PWM1", 116, DRV_GRP1), 622 MT7623_PIN(205, "PWM2", 117, DRV_GRP1), 623 MT7623_PIN(206, "PWM3", 118, DRV_GRP1), 624 MT7623_PIN(207, "PWM4", 119, DRV_GRP1), 625 MT7623_PIN(208, "AUD_EXT_CK1", 120, DRV_GRP1), 626 MT7623_PIN(209, "AUD_EXT_CK2", 121, DRV_GRP1), 627 MT7623_PIN(210, "AUD_CLOCK", EINT_NA, DRV_GRP3), 628 MT7623_PIN(211, "DVP_RESET", EINT_NA, DRV_GRP3), 629 MT7623_PIN(212, "DVP_CLOCK", EINT_NA, DRV_GRP3), 630 MT7623_PIN(213, "DVP_CS", EINT_NA, DRV_GRP3), 631 MT7623_PIN(214, "DVP_CK", EINT_NA, DRV_GRP3), 632 MT7623_PIN(215, "DVP_DI", EINT_NA, DRV_GRP3), 633 MT7623_PIN(216, "DVP_DO", EINT_NA, DRV_GRP3), 634 MT7623_PIN(217, "AP_CS", EINT_NA, DRV_GRP3), 635 MT7623_PIN(218, "AP_CK", EINT_NA, DRV_GRP3), 636 MT7623_PIN(219, "AP_DI", EINT_NA, DRV_GRP3), 637 MT7623_PIN(220, "AP_DO", EINT_NA, DRV_GRP3), 638 MT7623_PIN(221, "DVD_BCLK", EINT_NA, DRV_GRP3), 639 MT7623_PIN(222, "T8032_CLK", EINT_NA, DRV_GRP3), 640 MT7623_PIN(223, "AP_BCLK", EINT_NA, DRV_GRP3), 641 MT7623_PIN(224, "HOST_CS", EINT_NA, DRV_GRP3), 642 MT7623_PIN(225, "HOST_CK", EINT_NA, DRV_GRP3), 643 MT7623_PIN(226, "HOST_DO0", EINT_NA, DRV_GRP3), 644 MT7623_PIN(227, "HOST_DO1", EINT_NA, DRV_GRP3), 645 MT7623_PIN(228, "SLV_CS", EINT_NA, DRV_GRP3), 646 MT7623_PIN(229, "SLV_CK", EINT_NA, DRV_GRP3), 647 MT7623_PIN(230, "SLV_DI0", EINT_NA, DRV_GRP3), 648 MT7623_PIN(231, "SLV_DI1", EINT_NA, DRV_GRP3), 649 MT7623_PIN(232, "AP2DSP_INT", EINT_NA, DRV_GRP3), 650 MT7623_PIN(233, "AP2DSP_INT_CLR", EINT_NA, DRV_GRP3), 651 MT7623_PIN(234, "DSP2AP_INT", EINT_NA, DRV_GRP3), 652 MT7623_PIN(235, "DSP2AP_INT_CLR", EINT_NA, DRV_GRP3), 653 MT7623_PIN(236, "EXT_SDIO3", 122, DRV_GRP1), 654 MT7623_PIN(237, "EXT_SDIO2", 123, DRV_GRP1), 655 MT7623_PIN(238, "EXT_SDIO1", 124, DRV_GRP1), 656 MT7623_PIN(239, "EXT_SDIO0", 125, DRV_GRP1), 657 MT7623_PIN(240, "EXT_XCS", 126, DRV_GRP1), 658 MT7623_PIN(241, "EXT_SCK", 127, DRV_GRP1), 659 MT7623_PIN(242, "URTS2", 128, DRV_GRP1), 660 MT7623_PIN(243, "UCTS2", 129, DRV_GRP1), 661 MT7623_PIN(244, "HDMI_SDA_RX", 130, DRV_FIXED), 662 MT7623_PIN(245, "HDMI_SCL_RX", 131, DRV_FIXED), 663 MT7623_PIN(246, "MHL_SENCE", 132, DRV_FIXED), 664 MT7623_PIN(247, "HDMI_HPD_CBUS_RX", 69, DRV_FIXED), 665 MT7623_PIN(248, "HDMI_TESTOUTP_RX", 133, DRV_GRP1), 666 MT7623_PIN(249, "MSDC0E_RSTB", 134, DRV_GRP4), 667 MT7623_PIN(250, "MSDC0E_DAT7", 135, DRV_GRP4), 668 MT7623_PIN(251, "MSDC0E_DAT6", 136, DRV_GRP4), 669 MT7623_PIN(252, "MSDC0E_DAT5", 137, DRV_GRP4), 670 MT7623_PIN(253, "MSDC0E_DAT4", 138, DRV_GRP4), 671 MT7623_PIN(254, "MSDC0E_DAT3", 139, DRV_GRP4), 672 MT7623_PIN(255, "MSDC0E_DAT2", 140, DRV_GRP4), 673 MT7623_PIN(256, "MSDC0E_DAT1", 141, DRV_GRP4), 674 MT7623_PIN(257, "MSDC0E_DAT0", 142, DRV_GRP4), 675 MT7623_PIN(258, "MSDC0E_CMD", 143, DRV_GRP4), 676 MT7623_PIN(259, "MSDC0E_CLK", 144, DRV_GRP4), 677 MT7623_PIN(260, "MSDC0E_DSL", 145, DRV_GRP4), 678 MT7623_PIN(261, "MSDC1_INS", 146, DRV_GRP4), 679 MT7623_PIN(262, "G2_TXEN", 8, DRV_GRP1), 680 MT7623_PIN(263, "G2_TXD3", 9, DRV_GRP1), 681 MT7623_PIN(264, "G2_TXD2", 10, DRV_GRP1), 682 MT7623_PIN(265, "G2_TXD1", 11, DRV_GRP1), 683 MT7623_PIN(266, "G2_TXD0", EINT_NA, DRV_GRP1), 684 MT7623_PIN(267, "G2_TXC", EINT_NA, DRV_GRP1), 685 MT7623_PIN(268, "G2_RXC", EINT_NA, DRV_GRP1), 686 MT7623_PIN(269, "G2_RXD0", EINT_NA, DRV_GRP1), 687 MT7623_PIN(270, "G2_RXD1", EINT_NA, DRV_GRP1), 688 MT7623_PIN(271, "G2_RXD2", EINT_NA, DRV_GRP1), 689 MT7623_PIN(272, "G2_RXD3", EINT_NA, DRV_GRP1), 690 MT7623_PIN(273, "ESW_INT", 168, DRV_GRP1), 691 MT7623_PIN(274, "G2_RXDV", EINT_NA, DRV_GRP1), 692 MT7623_PIN(275, "MDC", EINT_NA, DRV_GRP1), 693 MT7623_PIN(276, "MDIO", EINT_NA, DRV_GRP1), 694 MT7623_PIN(277, "ESW_RST", EINT_NA, DRV_GRP1), 695 MT7623_PIN(278, "JTAG_RESET", 147, DRV_GRP3), 696 MT7623_PIN(279, "USB3_RES_BOND", EINT_NA, DRV_GRP1), 697}; 698 699/* List all groups consisting of these pins dedicated to the enablement of 700 * certain hardware block and the corresponding mode for all of the pins. 701 * The hardware probably has multiple combinations of these pinouts. 702 */ 703 704/* AUDIO EXT CLK */ 705static int mt7623_aud_ext_clk0_pins[] = { 208, }; 706static int mt7623_aud_ext_clk0_funcs[] = { 1, }; 707static int mt7623_aud_ext_clk1_pins[] = { 209, }; 708static int mt7623_aud_ext_clk1_funcs[] = { 1, }; 709 710/* DISP PWM */ 711static int mt7623_disp_pwm_0_pins[] = { 72, }; 712static int mt7623_disp_pwm_0_funcs[] = { 5, }; 713static int mt7623_disp_pwm_1_pins[] = { 203, }; 714static int mt7623_disp_pwm_1_funcs[] = { 2, }; 715static int mt7623_disp_pwm_2_pins[] = { 208, }; 716static int mt7623_disp_pwm_2_funcs[] = { 5, }; 717 718/* ESW */ 719static int mt7623_esw_int_pins[] = { 273, }; 720static int mt7623_esw_int_funcs[] = { 1, }; 721static int mt7623_esw_rst_pins[] = { 277, }; 722static int mt7623_esw_rst_funcs[] = { 1, }; 723 724/* EPHY */ 725static int mt7623_ephy_pins[] = { 262, 263, 264, 265, 266, 267, 268, 726 269, 270, 271, 272, 274, }; 727static int mt7623_ephy_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, }; 728 729/* EXT_SDIO */ 730static int mt7623_ext_sdio_pins[] = { 236, 237, 238, 239, 240, 241, }; 731static int mt7623_ext_sdio_funcs[] = { 1, 1, 1, 1, 1, 1, }; 732 733/* HDMI RX */ 734static int mt7623_hdmi_rx_pins[] = { 247, 248, }; 735static int mt7623_hdmi_rx_funcs[] = { 1, 1 }; 736static int mt7623_hdmi_rx_i2c_pins[] = { 244, 245, }; 737static int mt7623_hdmi_rx_i2c_funcs[] = { 1, 1 }; 738 739/* HDMI TX */ 740static int mt7623_hdmi_cec_pins[] = { 122, }; 741static int mt7623_hdmi_cec_funcs[] = { 1, }; 742static int mt7623_hdmi_htplg_pins[] = { 123, }; 743static int mt7623_hdmi_htplg_funcs[] = { 1, }; 744static int mt7623_hdmi_i2c_pins[] = { 124, 125, }; 745static int mt7623_hdmi_i2c_funcs[] = { 1, 1 }; 746 747/* I2C */ 748static int mt7623_i2c0_pins[] = { 75, 76, }; 749static int mt7623_i2c0_funcs[] = { 1, 1, }; 750static int mt7623_i2c1_0_pins[] = { 57, 58, }; 751static int mt7623_i2c1_0_funcs[] = { 1, 1, }; 752static int mt7623_i2c1_1_pins[] = { 242, 243, }; 753static int mt7623_i2c1_1_funcs[] = { 4, 4, }; 754static int mt7623_i2c1_2_pins[] = { 85, 86, }; 755static int mt7623_i2c1_2_funcs[] = { 3, 3, }; 756static int mt7623_i2c1_3_pins[] = { 105, 106, }; 757static int mt7623_i2c1_3_funcs[] = { 3, 3, }; 758static int mt7623_i2c1_4_pins[] = { 124, 125, }; 759static int mt7623_i2c1_4_funcs[] = { 4, 4, }; 760static int mt7623_i2c2_0_pins[] = { 77, 78, }; 761static int mt7623_i2c2_0_funcs[] = { 1, 1, }; 762static int mt7623_i2c2_1_pins[] = { 89, 90, }; 763static int mt7623_i2c2_1_funcs[] = { 3, 3, }; 764static int mt7623_i2c2_2_pins[] = { 109, 110, }; 765static int mt7623_i2c2_2_funcs[] = { 3, 3, }; 766static int mt7623_i2c2_3_pins[] = { 122, 123, }; 767static int mt7623_i2c2_3_funcs[] = { 4, 4, }; 768 769/* I2S */ 770static int mt7623_i2s0_pins[] = { 49, 72, 73, 74, 126, }; 771static int mt7623_i2s0_funcs[] = { 1, 1, 1, 1, 1, }; 772static int mt7623_i2s1_pins[] = { 33, 34, 35, 36, 37, }; 773static int mt7623_i2s1_funcs[] = { 1, 1, 1, 1, 1, }; 774static int mt7623_i2s2_bclk_lrclk_mclk_pins[] = { 50, 52, 188, }; 775static int mt7623_i2s2_bclk_lrclk_mclk_funcs[] = { 1, 1, 1, }; 776static int mt7623_i2s2_data_in_pins[] = { 51, }; 777static int mt7623_i2s2_data_in_funcs[] = { 1, }; 778static int mt7623_i2s2_data_0_pins[] = { 203, }; 779static int mt7623_i2s2_data_0_funcs[] = { 9, }; 780static int mt7623_i2s2_data_1_pins[] = { 38, }; 781static int mt7623_i2s2_data_1_funcs[] = { 4, }; 782static int mt7623_i2s3_bclk_lrclk_mclk_pins[] = { 191, 192, 193, }; 783static int mt7623_i2s3_bclk_lrclk_mclk_funcs[] = { 1, 1, 1, }; 784static int mt7623_i2s3_data_in_pins[] = { 190, }; 785static int mt7623_i2s3_data_in_funcs[] = { 1, }; 786static int mt7623_i2s3_data_0_pins[] = { 204, }; 787static int mt7623_i2s3_data_0_funcs[] = { 9, }; 788static int mt7623_i2s3_data_1_pins[] = { 2, }; 789static int mt7623_i2s3_data_1_funcs[] = { 0, }; 790static int mt7623_i2s4_pins[] = { 194, 195, 196, 197, 198, }; 791static int mt7623_i2s4_funcs[] = { 1, 1, 1, 1, 1, }; 792static int mt7623_i2s5_pins[] = { 16, 17, 30, 31, 32, }; 793static int mt7623_i2s5_funcs[] = { 1, 1, 1, 1, 1, }; 794 795/* IR */ 796static int mt7623_ir_pins[] = { 46, }; 797static int mt7623_ir_funcs[] = { 1, }; 798 799/* LCD */ 800static int mt7623_mipi_tx_pins[] = { 91, 92, 93, 94, 95, 96, 97, 98, 801 99, 100, }; 802static int mt7623_mipi_tx_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, }; 803static int mt7623_dsi_te_pins[] = { 84, }; 804static int mt7623_dsi_te_funcs[] = { 1, }; 805static int mt7623_lcm_rst_pins[] = { 83, }; 806static int mt7623_lcm_rst_funcs[] = { 1, }; 807 808/* MDC/MDIO */ 809static int mt7623_mdc_mdio_pins[] = { 275, 276, }; 810static int mt7623_mdc_mdio_funcs[] = { 1, 1, }; 811 812/* MSDC */ 813static int mt7623_msdc0_pins[] = { 111, 112, 113, 114, 115, 116, 117, 118, 814 119, 120, 121, }; 815static int mt7623_msdc0_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, }; 816static int mt7623_msdc1_pins[] = { 105, 106, 107, 108, 109, 110, }; 817static int mt7623_msdc1_funcs[] = { 1, 1, 1, 1, 1, 1, }; 818static int mt7623_msdc1_ins_pins[] = { 261, }; 819static int mt7623_msdc1_ins_funcs[] = { 1, }; 820static int mt7623_msdc1_wp_0_pins[] = { 29, }; 821static int mt7623_msdc1_wp_0_funcs[] = { 1, }; 822static int mt7623_msdc1_wp_1_pins[] = { 55, }; 823static int mt7623_msdc1_wp_1_funcs[] = { 3, }; 824static int mt7623_msdc1_wp_2_pins[] = { 209, }; 825static int mt7623_msdc1_wp_2_funcs[] = { 2, }; 826static int mt7623_msdc2_pins[] = { 85, 86, 87, 88, 89, 90, }; 827static int mt7623_msdc2_funcs[] = { 1, 1, 1, 1, 1, 1, }; 828static int mt7623_msdc3_pins[] = { 249, 250, 251, 252, 253, 254, 255, 256, 829 257, 258, 259, 260, }; 830static int mt7623_msdc3_funcs[] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, }; 831 832/* NAND */ 833static int mt7623_nandc_pins[] = { 43, 47, 48, 111, 112, 113, 114, 115, 834 116, 117, 118, 119, 120, 121, }; 835static int mt7623_nandc_funcs[] = { 1, 1, 1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 836 4, 4, }; 837static int mt7623_nandc_ceb0_pins[] = { 45, }; 838static int mt7623_nandc_ceb0_funcs[] = { 1, }; 839static int mt7623_nandc_ceb1_pins[] = { 44, }; 840static int mt7623_nandc_ceb1_funcs[] = { 1, }; 841 842/* RTC */ 843static int mt7623_rtc_pins[] = { 10, }; 844static int mt7623_rtc_funcs[] = { 1, }; 845 846/* OTG */ 847static int mt7623_otg_iddig0_0_pins[] = { 29, }; 848static int mt7623_otg_iddig0_0_funcs[] = { 1, }; 849static int mt7623_otg_iddig0_1_pins[] = { 44, }; 850static int mt7623_otg_iddig0_1_funcs[] = { 2, }; 851static int mt7623_otg_iddig0_2_pins[] = { 236, }; 852static int mt7623_otg_iddig0_2_funcs[] = { 2, }; 853static int mt7623_otg_iddig1_0_pins[] = { 27, }; 854static int mt7623_otg_iddig1_0_funcs[] = { 2, }; 855static int mt7623_otg_iddig1_1_pins[] = { 47, }; 856static int mt7623_otg_iddig1_1_funcs[] = { 2, }; 857static int mt7623_otg_iddig1_2_pins[] = { 238, }; 858static int mt7623_otg_iddig1_2_funcs[] = { 2, }; 859static int mt7623_otg_drv_vbus0_0_pins[] = { 28, }; 860static int mt7623_otg_drv_vbus0_0_funcs[] = { 1, }; 861static int mt7623_otg_drv_vbus0_1_pins[] = { 45, }; 862static int mt7623_otg_drv_vbus0_1_funcs[] = { 2, }; 863static int mt7623_otg_drv_vbus0_2_pins[] = { 237, }; 864static int mt7623_otg_drv_vbus0_2_funcs[] = { 2, }; 865static int mt7623_otg_drv_vbus1_0_pins[] = { 26, }; 866static int mt7623_otg_drv_vbus1_0_funcs[] = { 2, }; 867static int mt7623_otg_drv_vbus1_1_pins[] = { 48, }; 868static int mt7623_otg_drv_vbus1_1_funcs[] = { 2, }; 869static int mt7623_otg_drv_vbus1_2_pins[] = { 239, }; 870static int mt7623_otg_drv_vbus1_2_funcs[] = { 2, }; 871 872/* PCIE */ 873static int mt7623_pcie0_0_perst_pins[] = { 208, }; 874static int mt7623_pcie0_0_perst_funcs[] = { 3, }; 875static int mt7623_pcie0_1_perst_pins[] = { 22, }; 876static int mt7623_pcie0_1_perst_funcs[] = { 2, }; 877static int mt7623_pcie1_0_perst_pins[] = { 209, }; 878static int mt7623_pcie1_0_perst_funcs[] = { 3, }; 879static int mt7623_pcie1_1_perst_pins[] = { 23, }; 880static int mt7623_pcie1_1_perst_funcs[] = { 2, }; 881static int mt7623_pcie2_0_perst_pins[] = { 24, }; 882static int mt7623_pcie2_0_perst_funcs[] = { 2, }; 883static int mt7623_pcie2_1_perst_pins[] = { 29, }; 884static int mt7623_pcie2_1_perst_funcs[] = { 6, }; 885static int mt7623_pcie0_0_wake_pins[] = { 28, }; 886static int mt7623_pcie0_0_wake_funcs[] = { 6, }; 887static int mt7623_pcie0_1_wake_pins[] = { 251, }; 888static int mt7623_pcie0_1_wake_funcs[] = { 6, }; 889static int mt7623_pcie1_0_wake_pins[] = { 27, }; 890static int mt7623_pcie1_0_wake_funcs[] = { 6, }; 891static int mt7623_pcie1_1_wake_pins[] = { 253, }; 892static int mt7623_pcie1_1_wake_funcs[] = { 6, }; 893static int mt7623_pcie2_0_wake_pins[] = { 26, }; 894static int mt7623_pcie2_0_wake_funcs[] = { 6, }; 895static int mt7623_pcie2_1_wake_pins[] = { 255, }; 896static int mt7623_pcie2_1_wake_funcs[] = { 6, }; 897static int mt7623_pcie0_clkreq_pins[] = { 250, }; 898static int mt7623_pcie0_clkreq_funcs[] = { 6, }; 899static int mt7623_pcie1_clkreq_pins[] = { 252, }; 900static int mt7623_pcie1_clkreq_funcs[] = { 6, }; 901static int mt7623_pcie2_clkreq_pins[] = { 254, }; 902static int mt7623_pcie2_clkreq_funcs[] = { 6, }; 903 904/* the pcie_*_rev are only used for MT7623 */ 905static int mt7623_pcie0_0_rev_perst_pins[] = { 208, }; 906static int mt7623_pcie0_0_rev_perst_funcs[] = { 11, }; 907static int mt7623_pcie0_1_rev_perst_pins[] = { 22, }; 908static int mt7623_pcie0_1_rev_perst_funcs[] = { 10, }; 909static int mt7623_pcie1_0_rev_perst_pins[] = { 209, }; 910static int mt7623_pcie1_0_rev_perst_funcs[] = { 11, }; 911static int mt7623_pcie1_1_rev_perst_pins[] = { 23, }; 912static int mt7623_pcie1_1_rev_perst_funcs[] = { 10, }; 913static int mt7623_pcie2_0_rev_perst_pins[] = { 24, }; 914static int mt7623_pcie2_0_rev_perst_funcs[] = { 11, }; 915static int mt7623_pcie2_1_rev_perst_pins[] = { 29, }; 916static int mt7623_pcie2_1_rev_perst_funcs[] = { 14, }; 917 918/* PCM */ 919static int mt7623_pcm_clk_0_pins[] = { 18, }; 920static int mt7623_pcm_clk_0_funcs[] = { 1, }; 921static int mt7623_pcm_clk_1_pins[] = { 17, }; 922static int mt7623_pcm_clk_1_funcs[] = { 3, }; 923static int mt7623_pcm_clk_2_pins[] = { 35, }; 924static int mt7623_pcm_clk_2_funcs[] = { 3, }; 925static int mt7623_pcm_clk_3_pins[] = { 50, }; 926static int mt7623_pcm_clk_3_funcs[] = { 3, }; 927static int mt7623_pcm_clk_4_pins[] = { 74, }; 928static int mt7623_pcm_clk_4_funcs[] = { 3, }; 929static int mt7623_pcm_clk_5_pins[] = { 191, }; 930static int mt7623_pcm_clk_5_funcs[] = { 3, }; 931static int mt7623_pcm_clk_6_pins[] = { 196, }; 932static int mt7623_pcm_clk_6_funcs[] = { 3, }; 933static int mt7623_pcm_sync_0_pins[] = { 19, }; 934static int mt7623_pcm_sync_0_funcs[] = { 1, }; 935static int mt7623_pcm_sync_1_pins[] = { 30, }; 936static int mt7623_pcm_sync_1_funcs[] = { 3, }; 937static int mt7623_pcm_sync_2_pins[] = { 36, }; 938static int mt7623_pcm_sync_2_funcs[] = { 3, }; 939static int mt7623_pcm_sync_3_pins[] = { 52, }; 940static int mt7623_pcm_sync_3_funcs[] = { 31, }; 941static int mt7623_pcm_sync_4_pins[] = { 73, }; 942static int mt7623_pcm_sync_4_funcs[] = { 3, }; 943static int mt7623_pcm_sync_5_pins[] = { 192, }; 944static int mt7623_pcm_sync_5_funcs[] = { 3, }; 945static int mt7623_pcm_sync_6_pins[] = { 197, }; 946static int mt7623_pcm_sync_6_funcs[] = { 3, }; 947static int mt7623_pcm_rx_0_pins[] = { 20, }; 948static int mt7623_pcm_rx_0_funcs[] = { 1, }; 949static int mt7623_pcm_rx_1_pins[] = { 16, }; 950static int mt7623_pcm_rx_1_funcs[] = { 3, }; 951static int mt7623_pcm_rx_2_pins[] = { 34, }; 952static int mt7623_pcm_rx_2_funcs[] = { 3, }; 953static int mt7623_pcm_rx_3_pins[] = { 51, }; 954static int mt7623_pcm_rx_3_funcs[] = { 3, }; 955static int mt7623_pcm_rx_4_pins[] = { 72, }; 956static int mt7623_pcm_rx_4_funcs[] = { 3, }; 957static int mt7623_pcm_rx_5_pins[] = { 190, }; 958static int mt7623_pcm_rx_5_funcs[] = { 3, }; 959static int mt7623_pcm_rx_6_pins[] = { 195, }; 960static int mt7623_pcm_rx_6_funcs[] = { 3, }; 961static int mt7623_pcm_tx_0_pins[] = { 21, }; 962static int mt7623_pcm_tx_0_funcs[] = { 1, }; 963static int mt7623_pcm_tx_1_pins[] = { 32, }; 964static int mt7623_pcm_tx_1_funcs[] = { 3, }; 965static int mt7623_pcm_tx_2_pins[] = { 33, }; 966static int mt7623_pcm_tx_2_funcs[] = { 3, }; 967static int mt7623_pcm_tx_3_pins[] = { 38, }; 968static int mt7623_pcm_tx_3_funcs[] = { 3, }; 969static int mt7623_pcm_tx_4_pins[] = { 49, }; 970static int mt7623_pcm_tx_4_funcs[] = { 3, }; 971static int mt7623_pcm_tx_5_pins[] = { 189, }; 972static int mt7623_pcm_tx_5_funcs[] = { 3, }; 973static int mt7623_pcm_tx_6_pins[] = { 194, }; 974static int mt7623_pcm_tx_6_funcs[] = { 3, }; 975 976/* PWM */ 977static int mt7623_pwm_ch1_0_pins[] = { 203, }; 978static int mt7623_pwm_ch1_0_funcs[] = { 1, }; 979static int mt7623_pwm_ch1_1_pins[] = { 208, }; 980static int mt7623_pwm_ch1_1_funcs[] = { 2, }; 981static int mt7623_pwm_ch1_2_pins[] = { 72, }; 982static int mt7623_pwm_ch1_2_funcs[] = { 4, }; 983static int mt7623_pwm_ch1_3_pins[] = { 88, }; 984static int mt7623_pwm_ch1_3_funcs[] = { 3, }; 985static int mt7623_pwm_ch1_4_pins[] = { 108, }; 986static int mt7623_pwm_ch1_4_funcs[] = { 3, }; 987static int mt7623_pwm_ch2_0_pins[] = { 204, }; 988static int mt7623_pwm_ch2_0_funcs[] = { 1, }; 989static int mt7623_pwm_ch2_1_pins[] = { 53, }; 990static int mt7623_pwm_ch2_1_funcs[] = { 5, }; 991static int mt7623_pwm_ch2_2_pins[] = { 88, }; 992static int mt7623_pwm_ch2_2_funcs[] = { 6, }; 993static int mt7623_pwm_ch2_3_pins[] = { 108, }; 994static int mt7623_pwm_ch2_3_funcs[] = { 6, }; 995static int mt7623_pwm_ch2_4_pins[] = { 209, }; 996static int mt7623_pwm_ch2_4_funcs[] = { 5, }; 997static int mt7623_pwm_ch3_0_pins[] = { 205, }; 998static int mt7623_pwm_ch3_0_funcs[] = { 1, }; 999static int mt7623_pwm_ch3_1_pins[] = { 55, }; 1000static int mt7623_pwm_ch3_1_funcs[] = { 5, }; 1001static int mt7623_pwm_ch3_2_pins[] = { 89, }; 1002static int mt7623_pwm_ch3_2_funcs[] = { 6, }; 1003static int mt7623_pwm_ch3_3_pins[] = { 109, }; 1004static int mt7623_pwm_ch3_3_funcs[] = { 6, }; 1005static int mt7623_pwm_ch4_0_pins[] = { 206, }; 1006static int mt7623_pwm_ch4_0_funcs[] = { 1, }; 1007static int mt7623_pwm_ch4_1_pins[] = { 90, }; 1008static int mt7623_pwm_ch4_1_funcs[] = { 6, }; 1009static int mt7623_pwm_ch4_2_pins[] = { 110, }; 1010static int mt7623_pwm_ch4_2_funcs[] = { 6, }; 1011static int mt7623_pwm_ch4_3_pins[] = { 124, }; 1012static int mt7623_pwm_ch4_3_funcs[] = { 5, }; 1013static int mt7623_pwm_ch5_0_pins[] = { 207, }; 1014static int mt7623_pwm_ch5_0_funcs[] = { 1, }; 1015static int mt7623_pwm_ch5_1_pins[] = { 125, }; 1016static int mt7623_pwm_ch5_1_funcs[] = { 5, }; 1017 1018/* PWRAP */ 1019static int mt7623_pwrap_pins[] = { 0, 1, 2, 3, 4, 5, 6, }; 1020static int mt7623_pwrap_funcs[] = { 1, 1, 1, 1, 1, 1, 1, }; 1021 1022/* SPDIF */ 1023static int mt7623_spdif_in0_0_pins[] = { 56, }; 1024static int mt7623_spdif_in0_0_funcs[] = { 3, }; 1025static int mt7623_spdif_in0_1_pins[] = { 201, }; 1026static int mt7623_spdif_in0_1_funcs[] = { 1, }; 1027static int mt7623_spdif_in1_0_pins[] = { 54, }; 1028static int mt7623_spdif_in1_0_funcs[] = { 3, }; 1029static int mt7623_spdif_in1_1_pins[] = { 202, }; 1030static int mt7623_spdif_in1_1_funcs[] = { 1, }; 1031static int mt7623_spdif_out_pins[] = { 202, }; 1032static int mt7623_spdif_out_funcs[] = { 1, }; 1033 1034/* SPI */ 1035static int mt7623_spi0_pins[] = { 53, 54, 55, 56, }; 1036static int mt7623_spi0_funcs[] = { 1, 1, 1, 1, }; 1037static int mt7623_spi1_pins[] = { 7, 199, 8, 9, }; 1038static int mt7623_spi1_funcs[] = { 1, 1, 1, 1, }; 1039static int mt7623_spi2_pins[] = { 101, 104, 102, 103, }; 1040static int mt7623_spi2_funcs[] = { 1, 1, 1, 1, }; 1041 1042/* UART */ 1043static int mt7623_uart0_0_txd_rxd_pins[] = { 79, 80, }; 1044static int mt7623_uart0_0_txd_rxd_funcs[] = { 1, 1, }; 1045static int mt7623_uart0_1_txd_rxd_pins[] = { 87, 88, }; 1046static int mt7623_uart0_1_txd_rxd_funcs[] = { 5, 5, }; 1047static int mt7623_uart0_2_txd_rxd_pins[] = { 107, 108, }; 1048static int mt7623_uart0_2_txd_rxd_funcs[] = { 5, 5, }; 1049static int mt7623_uart0_3_txd_rxd_pins[] = { 123, 122, }; 1050static int mt7623_uart0_3_txd_rxd_funcs[] = { 5, 5, }; 1051static int mt7623_uart0_rts_cts_pins[] = { 22, 23, }; 1052static int mt7623_uart0_rts_cts_funcs[] = { 1, 1, }; 1053static int mt7623_uart1_0_txd_rxd_pins[] = { 81, 82, }; 1054static int mt7623_uart1_0_txd_rxd_funcs[] = { 1, 1, }; 1055static int mt7623_uart1_1_txd_rxd_pins[] = { 89, 90, }; 1056static int mt7623_uart1_1_txd_rxd_funcs[] = { 5, 5, }; 1057static int mt7623_uart1_2_txd_rxd_pins[] = { 109, 110, }; 1058static int mt7623_uart1_2_txd_rxd_funcs[] = { 5, 5, }; 1059static int mt7623_uart1_rts_cts_pins[] = { 24, 25, }; 1060static int mt7623_uart1_rts_cts_funcs[] = { 1, 1, }; 1061static int mt7623_uart2_0_txd_rxd_pins[] = { 14, 15, }; 1062static int mt7623_uart2_0_txd_rxd_funcs[] = { 1, 1, }; 1063static int mt7623_uart2_1_txd_rxd_pins[] = { 200, 201, }; 1064static int mt7623_uart2_1_txd_rxd_funcs[] = { 6, 6, }; 1065static int mt7623_uart2_rts_cts_pins[] = { 242, 243, }; 1066static int mt7623_uart2_rts_cts_funcs[] = { 1, 1, }; 1067static int mt7623_uart3_txd_rxd_pins[] = { 242, 243, }; 1068static int mt7623_uart3_txd_rxd_funcs[] = { 2, 2, }; 1069static int mt7623_uart3_rts_cts_pins[] = { 26, 27, }; 1070static int mt7623_uart3_rts_cts_funcs[] = { 1, 1, }; 1071 1072/* Watchdog */ 1073static int mt7623_watchdog_0_pins[] = { 11, }; 1074static int mt7623_watchdog_0_funcs[] = { 1, }; 1075static int mt7623_watchdog_1_pins[] = { 121, }; 1076static int mt7623_watchdog_1_funcs[] = { 5, }; 1077 1078static const struct group_desc mt7623_groups[] = { 1079 PINCTRL_PIN_GROUP("aud_ext_clk0", mt7623_aud_ext_clk0), 1080 PINCTRL_PIN_GROUP("aud_ext_clk1", mt7623_aud_ext_clk1), 1081 PINCTRL_PIN_GROUP("dsi_te", mt7623_dsi_te), 1082 PINCTRL_PIN_GROUP("disp_pwm_0", mt7623_disp_pwm_0), 1083 PINCTRL_PIN_GROUP("disp_pwm_1", mt7623_disp_pwm_1), 1084 PINCTRL_PIN_GROUP("disp_pwm_2", mt7623_disp_pwm_2), 1085 PINCTRL_PIN_GROUP("ephy", mt7623_ephy), 1086 PINCTRL_PIN_GROUP("esw_int", mt7623_esw_int), 1087 PINCTRL_PIN_GROUP("esw_rst", mt7623_esw_rst), 1088 PINCTRL_PIN_GROUP("ext_sdio", mt7623_ext_sdio), 1089 PINCTRL_PIN_GROUP("hdmi_cec", mt7623_hdmi_cec), 1090 PINCTRL_PIN_GROUP("hdmi_htplg", mt7623_hdmi_htplg), 1091 PINCTRL_PIN_GROUP("hdmi_i2c", mt7623_hdmi_i2c), 1092 PINCTRL_PIN_GROUP("hdmi_rx", mt7623_hdmi_rx), 1093 PINCTRL_PIN_GROUP("hdmi_rx_i2c", mt7623_hdmi_rx_i2c), 1094 PINCTRL_PIN_GROUP("i2c0", mt7623_i2c0), 1095 PINCTRL_PIN_GROUP("i2c1_0", mt7623_i2c1_0), 1096 PINCTRL_PIN_GROUP("i2c1_1", mt7623_i2c1_1), 1097 PINCTRL_PIN_GROUP("i2c1_2", mt7623_i2c1_2), 1098 PINCTRL_PIN_GROUP("i2c1_3", mt7623_i2c1_3), 1099 PINCTRL_PIN_GROUP("i2c1_4", mt7623_i2c1_4), 1100 PINCTRL_PIN_GROUP("i2c2_0", mt7623_i2c2_0), 1101 PINCTRL_PIN_GROUP("i2c2_1", mt7623_i2c2_1), 1102 PINCTRL_PIN_GROUP("i2c2_2", mt7623_i2c2_2), 1103 PINCTRL_PIN_GROUP("i2c2_3", mt7623_i2c2_3), 1104 PINCTRL_PIN_GROUP("i2s0", mt7623_i2s0), 1105 PINCTRL_PIN_GROUP("i2s1", mt7623_i2s1), 1106 PINCTRL_PIN_GROUP("i2s4", mt7623_i2s4), 1107 PINCTRL_PIN_GROUP("i2s5", mt7623_i2s5), 1108 PINCTRL_PIN_GROUP("i2s2_bclk_lrclk_mclk", mt7623_i2s2_bclk_lrclk_mclk), 1109 PINCTRL_PIN_GROUP("i2s3_bclk_lrclk_mclk", mt7623_i2s3_bclk_lrclk_mclk), 1110 PINCTRL_PIN_GROUP("i2s2_data_in", mt7623_i2s2_data_in), 1111 PINCTRL_PIN_GROUP("i2s3_data_in", mt7623_i2s3_data_in), 1112 PINCTRL_PIN_GROUP("i2s2_data_0", mt7623_i2s2_data_0), 1113 PINCTRL_PIN_GROUP("i2s2_data_1", mt7623_i2s2_data_1), 1114 PINCTRL_PIN_GROUP("i2s3_data_0", mt7623_i2s3_data_0), 1115 PINCTRL_PIN_GROUP("i2s3_data_1", mt7623_i2s3_data_1), 1116 PINCTRL_PIN_GROUP("ir", mt7623_ir), 1117 PINCTRL_PIN_GROUP("lcm_rst", mt7623_lcm_rst), 1118 PINCTRL_PIN_GROUP("mdc_mdio", mt7623_mdc_mdio), 1119 PINCTRL_PIN_GROUP("mipi_tx", mt7623_mipi_tx), 1120 PINCTRL_PIN_GROUP("msdc0", mt7623_msdc0), 1121 PINCTRL_PIN_GROUP("msdc1", mt7623_msdc1), 1122 PINCTRL_PIN_GROUP("msdc1_ins", mt7623_msdc1_ins), 1123 PINCTRL_PIN_GROUP("msdc1_wp_0", mt7623_msdc1_wp_0), 1124 PINCTRL_PIN_GROUP("msdc1_wp_1", mt7623_msdc1_wp_1), 1125 PINCTRL_PIN_GROUP("msdc1_wp_2", mt7623_msdc1_wp_2), 1126 PINCTRL_PIN_GROUP("msdc2", mt7623_msdc2), 1127 PINCTRL_PIN_GROUP("msdc3", mt7623_msdc3), 1128 PINCTRL_PIN_GROUP("nandc", mt7623_nandc), 1129 PINCTRL_PIN_GROUP("nandc_ceb0", mt7623_nandc_ceb0), 1130 PINCTRL_PIN_GROUP("nandc_ceb1", mt7623_nandc_ceb1), 1131 PINCTRL_PIN_GROUP("otg_iddig0_0", mt7623_otg_iddig0_0), 1132 PINCTRL_PIN_GROUP("otg_iddig0_1", mt7623_otg_iddig0_1), 1133 PINCTRL_PIN_GROUP("otg_iddig0_2", mt7623_otg_iddig0_2), 1134 PINCTRL_PIN_GROUP("otg_iddig1_0", mt7623_otg_iddig1_0), 1135 PINCTRL_PIN_GROUP("otg_iddig1_1", mt7623_otg_iddig1_1), 1136 PINCTRL_PIN_GROUP("otg_iddig1_2", mt7623_otg_iddig1_2), 1137 PINCTRL_PIN_GROUP("otg_drv_vbus0_0", mt7623_otg_drv_vbus0_0), 1138 PINCTRL_PIN_GROUP("otg_drv_vbus0_1", mt7623_otg_drv_vbus0_1), 1139 PINCTRL_PIN_GROUP("otg_drv_vbus0_2", mt7623_otg_drv_vbus0_2), 1140 PINCTRL_PIN_GROUP("otg_drv_vbus1_0", mt7623_otg_drv_vbus1_0), 1141 PINCTRL_PIN_GROUP("otg_drv_vbus1_1", mt7623_otg_drv_vbus1_1), 1142 PINCTRL_PIN_GROUP("otg_drv_vbus1_2", mt7623_otg_drv_vbus1_2), 1143 PINCTRL_PIN_GROUP("pcie0_0_perst", mt7623_pcie0_0_perst), 1144 PINCTRL_PIN_GROUP("pcie0_1_perst", mt7623_pcie0_1_perst), 1145 PINCTRL_PIN_GROUP("pcie1_0_perst", mt7623_pcie1_0_perst), 1146 PINCTRL_PIN_GROUP("pcie1_1_perst", mt7623_pcie1_1_perst), 1147 PINCTRL_PIN_GROUP("pcie1_1_perst", mt7623_pcie1_1_perst), 1148 PINCTRL_PIN_GROUP("pcie0_0_rev_perst", mt7623_pcie0_0_rev_perst), 1149 PINCTRL_PIN_GROUP("pcie0_1_rev_perst", mt7623_pcie0_1_rev_perst), 1150 PINCTRL_PIN_GROUP("pcie1_0_rev_perst", mt7623_pcie1_0_rev_perst), 1151 PINCTRL_PIN_GROUP("pcie1_1_rev_perst", mt7623_pcie1_1_rev_perst), 1152 PINCTRL_PIN_GROUP("pcie2_0_rev_perst", mt7623_pcie2_0_rev_perst), 1153 PINCTRL_PIN_GROUP("pcie2_1_rev_perst", mt7623_pcie2_1_rev_perst), 1154 PINCTRL_PIN_GROUP("pcie2_0_perst", mt7623_pcie2_0_perst), 1155 PINCTRL_PIN_GROUP("pcie2_1_perst", mt7623_pcie2_1_perst), 1156 PINCTRL_PIN_GROUP("pcie0_0_wake", mt7623_pcie0_0_wake), 1157 PINCTRL_PIN_GROUP("pcie0_1_wake", mt7623_pcie0_1_wake), 1158 PINCTRL_PIN_GROUP("pcie1_0_wake", mt7623_pcie1_0_wake), 1159 PINCTRL_PIN_GROUP("pcie1_1_wake", mt7623_pcie1_1_wake), 1160 PINCTRL_PIN_GROUP("pcie2_0_wake", mt7623_pcie2_0_wake), 1161 PINCTRL_PIN_GROUP("pcie2_1_wake", mt7623_pcie2_1_wake), 1162 PINCTRL_PIN_GROUP("pcie0_clkreq", mt7623_pcie0_clkreq), 1163 PINCTRL_PIN_GROUP("pcie1_clkreq", mt7623_pcie1_clkreq), 1164 PINCTRL_PIN_GROUP("pcie2_clkreq", mt7623_pcie2_clkreq), 1165 PINCTRL_PIN_GROUP("pcm_clk_0", mt7623_pcm_clk_0), 1166 PINCTRL_PIN_GROUP("pcm_clk_1", mt7623_pcm_clk_1), 1167 PINCTRL_PIN_GROUP("pcm_clk_2", mt7623_pcm_clk_2), 1168 PINCTRL_PIN_GROUP("pcm_clk_3", mt7623_pcm_clk_3), 1169 PINCTRL_PIN_GROUP("pcm_clk_4", mt7623_pcm_clk_4), 1170 PINCTRL_PIN_GROUP("pcm_clk_5", mt7623_pcm_clk_5), 1171 PINCTRL_PIN_GROUP("pcm_clk_6", mt7623_pcm_clk_6), 1172 PINCTRL_PIN_GROUP("pcm_sync_0", mt7623_pcm_sync_0), 1173 PINCTRL_PIN_GROUP("pcm_sync_1", mt7623_pcm_sync_1), 1174 PINCTRL_PIN_GROUP("pcm_sync_2", mt7623_pcm_sync_2), 1175 PINCTRL_PIN_GROUP("pcm_sync_3", mt7623_pcm_sync_3), 1176 PINCTRL_PIN_GROUP("pcm_sync_4", mt7623_pcm_sync_4), 1177 PINCTRL_PIN_GROUP("pcm_sync_5", mt7623_pcm_sync_5), 1178 PINCTRL_PIN_GROUP("pcm_sync_6", mt7623_pcm_sync_6), 1179 PINCTRL_PIN_GROUP("pcm_rx_0", mt7623_pcm_rx_0), 1180 PINCTRL_PIN_GROUP("pcm_rx_1", mt7623_pcm_rx_1), 1181 PINCTRL_PIN_GROUP("pcm_rx_2", mt7623_pcm_rx_2), 1182 PINCTRL_PIN_GROUP("pcm_rx_3", mt7623_pcm_rx_3), 1183 PINCTRL_PIN_GROUP("pcm_rx_4", mt7623_pcm_rx_4), 1184 PINCTRL_PIN_GROUP("pcm_rx_5", mt7623_pcm_rx_5), 1185 PINCTRL_PIN_GROUP("pcm_rx_6", mt7623_pcm_rx_6), 1186 PINCTRL_PIN_GROUP("pcm_tx_0", mt7623_pcm_tx_0), 1187 PINCTRL_PIN_GROUP("pcm_tx_1", mt7623_pcm_tx_1), 1188 PINCTRL_PIN_GROUP("pcm_tx_2", mt7623_pcm_tx_2), 1189 PINCTRL_PIN_GROUP("pcm_tx_3", mt7623_pcm_tx_3), 1190 PINCTRL_PIN_GROUP("pcm_tx_4", mt7623_pcm_tx_4), 1191 PINCTRL_PIN_GROUP("pcm_tx_5", mt7623_pcm_tx_5), 1192 PINCTRL_PIN_GROUP("pcm_tx_6", mt7623_pcm_tx_6), 1193 PINCTRL_PIN_GROUP("pwm_ch1_0", mt7623_pwm_ch1_0), 1194 PINCTRL_PIN_GROUP("pwm_ch1_1", mt7623_pwm_ch1_1), 1195 PINCTRL_PIN_GROUP("pwm_ch1_2", mt7623_pwm_ch1_2), 1196 PINCTRL_PIN_GROUP("pwm_ch1_3", mt7623_pwm_ch1_3), 1197 PINCTRL_PIN_GROUP("pwm_ch1_4", mt7623_pwm_ch1_4), 1198 PINCTRL_PIN_GROUP("pwm_ch2_0", mt7623_pwm_ch2_0), 1199 PINCTRL_PIN_GROUP("pwm_ch2_1", mt7623_pwm_ch2_1), 1200 PINCTRL_PIN_GROUP("pwm_ch2_2", mt7623_pwm_ch2_2), 1201 PINCTRL_PIN_GROUP("pwm_ch2_3", mt7623_pwm_ch2_3), 1202 PINCTRL_PIN_GROUP("pwm_ch2_4", mt7623_pwm_ch2_4), 1203 PINCTRL_PIN_GROUP("pwm_ch3_0", mt7623_pwm_ch3_0), 1204 PINCTRL_PIN_GROUP("pwm_ch3_1", mt7623_pwm_ch3_1), 1205 PINCTRL_PIN_GROUP("pwm_ch3_2", mt7623_pwm_ch3_2), 1206 PINCTRL_PIN_GROUP("pwm_ch3_3", mt7623_pwm_ch3_3), 1207 PINCTRL_PIN_GROUP("pwm_ch4_0", mt7623_pwm_ch4_0), 1208 PINCTRL_PIN_GROUP("pwm_ch4_1", mt7623_pwm_ch4_1), 1209 PINCTRL_PIN_GROUP("pwm_ch4_2", mt7623_pwm_ch4_2), 1210 PINCTRL_PIN_GROUP("pwm_ch4_3", mt7623_pwm_ch4_3), 1211 PINCTRL_PIN_GROUP("pwm_ch5_0", mt7623_pwm_ch5_0), 1212 PINCTRL_PIN_GROUP("pwm_ch5_1", mt7623_pwm_ch5_1), 1213 PINCTRL_PIN_GROUP("pwrap", mt7623_pwrap), 1214 PINCTRL_PIN_GROUP("rtc", mt7623_rtc), 1215 PINCTRL_PIN_GROUP("spdif_in0_0", mt7623_spdif_in0_0), 1216 PINCTRL_PIN_GROUP("spdif_in0_1", mt7623_spdif_in0_1), 1217 PINCTRL_PIN_GROUP("spdif_in1_0", mt7623_spdif_in1_0), 1218 PINCTRL_PIN_GROUP("spdif_in1_1", mt7623_spdif_in1_1), 1219 PINCTRL_PIN_GROUP("spdif_out", mt7623_spdif_out), 1220 PINCTRL_PIN_GROUP("spi0", mt7623_spi0), 1221 PINCTRL_PIN_GROUP("spi1", mt7623_spi1), 1222 PINCTRL_PIN_GROUP("spi2", mt7623_spi2), 1223 PINCTRL_PIN_GROUP("uart0_0_txd_rxd", mt7623_uart0_0_txd_rxd), 1224 PINCTRL_PIN_GROUP("uart0_1_txd_rxd", mt7623_uart0_1_txd_rxd), 1225 PINCTRL_PIN_GROUP("uart0_2_txd_rxd", mt7623_uart0_2_txd_rxd), 1226 PINCTRL_PIN_GROUP("uart0_3_txd_rxd", mt7623_uart0_3_txd_rxd), 1227 PINCTRL_PIN_GROUP("uart1_0_txd_rxd", mt7623_uart1_0_txd_rxd), 1228 PINCTRL_PIN_GROUP("uart1_1_txd_rxd", mt7623_uart1_1_txd_rxd), 1229 PINCTRL_PIN_GROUP("uart1_2_txd_rxd", mt7623_uart1_2_txd_rxd), 1230 PINCTRL_PIN_GROUP("uart2_0_txd_rxd", mt7623_uart2_0_txd_rxd), 1231 PINCTRL_PIN_GROUP("uart2_1_txd_rxd", mt7623_uart2_1_txd_rxd), 1232 PINCTRL_PIN_GROUP("uart3_txd_rxd", mt7623_uart3_txd_rxd), 1233 PINCTRL_PIN_GROUP("uart0_rts_cts", mt7623_uart0_rts_cts), 1234 PINCTRL_PIN_GROUP("uart1_rts_cts", mt7623_uart1_rts_cts), 1235 PINCTRL_PIN_GROUP("uart2_rts_cts", mt7623_uart2_rts_cts), 1236 PINCTRL_PIN_GROUP("uart3_rts_cts", mt7623_uart3_rts_cts), 1237 PINCTRL_PIN_GROUP("watchdog_0", mt7623_watchdog_0), 1238 PINCTRL_PIN_GROUP("watchdog_1", mt7623_watchdog_1), 1239}; 1240 1241/* Joint those groups owning the same capability in user point of view which 1242 * allows that people tend to use through the device tree. 1243 */ 1244static const char *mt7623_aud_clk_groups[] = { "aud_ext_clk0", 1245 "aud_ext_clk1", }; 1246static const char *mt7623_disp_pwm_groups[] = { "disp_pwm_0", "disp_pwm_1", 1247 "disp_pwm_2", }; 1248static const char *mt7623_ethernet_groups[] = { "esw_int", "esw_rst", 1249 "ephy", "mdc_mdio", }; 1250static const char *mt7623_ext_sdio_groups[] = { "ext_sdio", }; 1251static const char *mt7623_hdmi_groups[] = { "hdmi_cec", "hdmi_htplg", 1252 "hdmi_i2c", "hdmi_rx", 1253 "hdmi_rx_i2c", }; 1254static const char *mt7623_i2c_groups[] = { "i2c0", "i2c1_0", "i2c1_1", 1255 "i2c1_2", "i2c1_3", "i2c1_4", 1256 "i2c2_0", "i2c2_1", "i2c2_2", 1257 "i2c2_3", }; 1258static const char *mt7623_i2s_groups[] = { "i2s0", "i2s1", 1259 "i2s2_bclk_lrclk_mclk", 1260 "i2s3_bclk_lrclk_mclk", 1261 "i2s4", "i2s5", 1262 "i2s2_data_in", "i2s3_data_in", 1263 "i2s2_data_0", "i2s2_data_1", 1264 "i2s3_data_0", "i2s3_data_1", }; 1265static const char *mt7623_ir_groups[] = { "ir", }; 1266static const char *mt7623_lcd_groups[] = { "dsi_te", "lcm_rst", "mipi_tx", }; 1267static const char *mt7623_msdc_groups[] = { "msdc0", "msdc1", "msdc1_ins", 1268 "msdc1_wp_0", "msdc1_wp_1", 1269 "msdc1_wp_2", "msdc2", 1270 "msdc3", }; 1271static const char *mt7623_nandc_groups[] = { "nandc", "nandc_ceb0", 1272 "nandc_ceb1", }; 1273static const char *mt7623_otg_groups[] = { "otg_iddig0_0", "otg_iddig0_1", 1274 "otg_iddig0_2", "otg_iddig1_0", 1275 "otg_iddig1_1", "otg_iddig1_2", 1276 "otg_drv_vbus0_0", 1277 "otg_drv_vbus0_1", 1278 "otg_drv_vbus0_2", 1279 "otg_drv_vbus1_0", 1280 "otg_drv_vbus1_1", 1281 "otg_drv_vbus1_2", }; 1282static const char *mt7623_pcie_groups[] = { "pcie0_0_perst", "pcie0_1_perst", 1283 "pcie1_0_perst", "pcie1_1_perst", 1284 "pcie2_0_perst", "pcie2_1_perst", 1285 "pcie0_0_rev_perst", 1286 "pcie0_1_rev_perst", 1287 "pcie1_0_rev_perst", 1288 "pcie1_1_rev_perst", 1289 "pcie2_0_rev_perst", 1290 "pcie2_1_rev_perst", 1291 "pcie0_0_wake", "pcie0_1_wake", 1292 "pcie2_0_wake", "pcie2_1_wake", 1293 "pcie0_clkreq", "pcie1_clkreq", 1294 "pcie2_clkreq", }; 1295static const char *mt7623_pcm_groups[] = { "pcm_clk_0", "pcm_clk_1", 1296 "pcm_clk_2", "pcm_clk_3", 1297 "pcm_clk_4", "pcm_clk_5", 1298 "pcm_clk_6", "pcm_sync_0", 1299 "pcm_sync_1", "pcm_sync_2", 1300 "pcm_sync_3", "pcm_sync_4", 1301 "pcm_sync_5", "pcm_sync_6", 1302 "pcm_rx_0", "pcm_rx_1", 1303 "pcm_rx_2", "pcm_rx_3", 1304 "pcm_rx_4", "pcm_rx_5", 1305 "pcm_rx_6", "pcm_tx_0", 1306 "pcm_tx_1", "pcm_tx_2", 1307 "pcm_tx_3", "pcm_tx_4", 1308 "pcm_tx_5", "pcm_tx_6", }; 1309static const char *mt7623_pwm_groups[] = { "pwm_ch1_0", "pwm_ch1_1", 1310 "pwm_ch1_2", "pwm_ch2_0", 1311 "pwm_ch2_1", "pwm_ch2_2", 1312 "pwm_ch3_0", "pwm_ch3_1", 1313 "pwm_ch3_2", "pwm_ch4_0", 1314 "pwm_ch4_1", "pwm_ch4_2", 1315 "pwm_ch4_3", "pwm_ch5_0", 1316 "pwm_ch5_1", "pwm_ch5_2", 1317 "pwm_ch6_0", "pwm_ch6_1", 1318 "pwm_ch6_2", "pwm_ch6_3", 1319 "pwm_ch7_0", "pwm_ch7_1", 1320 "pwm_ch7_2", }; 1321static const char *mt7623_pwrap_groups[] = { "pwrap", }; 1322static const char *mt7623_rtc_groups[] = { "rtc", }; 1323static const char *mt7623_spi_groups[] = { "spi0", "spi2", "spi2", }; 1324static const char *mt7623_spdif_groups[] = { "spdif_in0_0", "spdif_in0_1", 1325 "spdif_in1_0", "spdif_in1_1", 1326 "spdif_out", }; 1327static const char *mt7623_uart_groups[] = { "uart0_0_txd_rxd", 1328 "uart0_1_txd_rxd", 1329 "uart0_2_txd_rxd", 1330 "uart0_3_txd_rxd", 1331 "uart1_0_txd_rxd", 1332 "uart1_1_txd_rxd", 1333 "uart1_2_txd_rxd", 1334 "uart2_0_txd_rxd", 1335 "uart2_1_txd_rxd", 1336 "uart3_txd_rxd", 1337 "uart0_rts_cts", 1338 "uart1_rts_cts", 1339 "uart2_rts_cts", 1340 "uart3_rts_cts", }; 1341static const char *mt7623_wdt_groups[] = { "watchdog_0", "watchdog_1", }; 1342 1343static const struct function_desc mt7623_functions[] = { 1344 {"audck", mt7623_aud_clk_groups, ARRAY_SIZE(mt7623_aud_clk_groups)}, 1345 {"disp", mt7623_disp_pwm_groups, ARRAY_SIZE(mt7623_disp_pwm_groups)}, 1346 {"eth", mt7623_ethernet_groups, ARRAY_SIZE(mt7623_ethernet_groups)}, 1347 {"sdio", mt7623_ext_sdio_groups, ARRAY_SIZE(mt7623_ext_sdio_groups)}, 1348 {"hdmi", mt7623_hdmi_groups, ARRAY_SIZE(mt7623_hdmi_groups)}, 1349 {"i2c", mt7623_i2c_groups, ARRAY_SIZE(mt7623_i2c_groups)}, 1350 {"i2s", mt7623_i2s_groups, ARRAY_SIZE(mt7623_i2s_groups)}, 1351 {"ir", mt7623_ir_groups, ARRAY_SIZE(mt7623_ir_groups)}, 1352 {"lcd", mt7623_lcd_groups, ARRAY_SIZE(mt7623_lcd_groups)}, 1353 {"msdc", mt7623_msdc_groups, ARRAY_SIZE(mt7623_msdc_groups)}, 1354 {"nand", mt7623_nandc_groups, ARRAY_SIZE(mt7623_nandc_groups)}, 1355 {"otg", mt7623_otg_groups, ARRAY_SIZE(mt7623_otg_groups)}, 1356 {"pcie", mt7623_pcie_groups, ARRAY_SIZE(mt7623_pcie_groups)}, 1357 {"pcm", mt7623_pcm_groups, ARRAY_SIZE(mt7623_pcm_groups)}, 1358 {"pwm", mt7623_pwm_groups, ARRAY_SIZE(mt7623_pwm_groups)}, 1359 {"pwrap", mt7623_pwrap_groups, ARRAY_SIZE(mt7623_pwrap_groups)}, 1360 {"rtc", mt7623_rtc_groups, ARRAY_SIZE(mt7623_rtc_groups)}, 1361 {"spi", mt7623_spi_groups, ARRAY_SIZE(mt7623_spi_groups)}, 1362 {"spdif", mt7623_spdif_groups, ARRAY_SIZE(mt7623_spdif_groups)}, 1363 {"uart", mt7623_uart_groups, ARRAY_SIZE(mt7623_uart_groups)}, 1364 {"watchdog", mt7623_wdt_groups, ARRAY_SIZE(mt7623_wdt_groups)}, 1365}; 1366 1367static const struct mtk_eint_hw mt7623_eint_hw = { 1368 .port_mask = 6, 1369 .ports = 6, 1370 .ap_num = 169, 1371 .db_cnt = 20, 1372}; 1373 1374static struct mtk_pin_soc mt7623_data = { 1375 .reg_cal = mt7623_reg_cals, 1376 .pins = (const struct pinctrl_pin_desc *)mt7623_pins, 1377 .npins = ARRAY_SIZE(mt7623_pins), 1378 .grps = mt7623_groups, 1379 .ngrps = ARRAY_SIZE(mt7623_groups), 1380 .funcs = mt7623_functions, 1381 .nfuncs = ARRAY_SIZE(mt7623_functions), 1382 .eint_hw = &mt7623_eint_hw, 1383 .gpio_m = 0, 1384 .eint_m = 0, 1385 .ies_present = true, 1386 .bias_disable_set = mtk_pinconf_bias_disable_set_rev1, 1387 .bias_disable_get = mtk_pinconf_bias_disable_get_rev1, 1388 .bias_set = mtk_pinconf_bias_set_rev1, 1389 .bias_get = mtk_pinconf_bias_get_rev1, 1390 .drive_set = mtk_pinconf_drive_set_rev1, 1391 .drive_get = mtk_pinconf_drive_get_rev1, 1392 .adv_pull_get = mtk_pinconf_adv_pull_get, 1393 .adv_pull_set = mtk_pinconf_adv_pull_set, 1394}; 1395 1396/* 1397 * There are some specific pins have mux functions greater than 8, 1398 * and if we want to switch thees high modes we need to disable 1399 * bonding constraints firstly. 1400 */ 1401static void mt7623_bonding_disable(struct platform_device *pdev) |
356{ | 1402{ |
357 return mtk_pctrl_init(pdev, &mt7623_pinctrl_data, NULL); | 1403 struct mtk_pinctrl *hw = platform_get_drvdata(pdev); 1404 1405 mtk_rmw(hw, PIN_BOND_REG0, BOND_PCIE_CLR, BOND_PCIE_CLR); 1406 mtk_rmw(hw, PIN_BOND_REG1, BOND_I2S_CLR, BOND_I2S_CLR); 1407 mtk_rmw(hw, PIN_BOND_REG2, BOND_MSDC0E_CLR, BOND_MSDC0E_CLR); |
358} 359 360static const struct of_device_id mt7623_pctrl_match[] = { | 1408} 1409 1410static const struct of_device_id mt7623_pctrl_match[] = { |
361 { .compatible = "mediatek,mt7623-pinctrl", }, | 1411 { .compatible = "mediatek,mt7623-moore-pinctrl", }, |
362 {} 363}; | 1412 {} 1413}; |
364MODULE_DEVICE_TABLE(of, mt7623_pctrl_match); | |
365 | 1414 |
1415static int mt7623_pinctrl_probe(struct platform_device *pdev) 1416{ 1417 int err; 1418 1419 err = mtk_moore_pinctrl_probe(pdev, &mt7623_data); 1420 if (err) 1421 return err; 1422 1423 mt7623_bonding_disable(pdev); 1424 1425 return 0; 1426} 1427 |
|
366static struct platform_driver mtk_pinctrl_driver = { 367 .probe = mt7623_pinctrl_probe, 368 .driver = { | 1428static struct platform_driver mtk_pinctrl_driver = { 1429 .probe = mt7623_pinctrl_probe, 1430 .driver = { |
369 .name = "mediatek-mt7623-pinctrl", | 1431 .name = "mt7623-moore-pinctrl", |
370 .of_match_table = mt7623_pctrl_match, 371 }, 372}; 373 374static int __init mtk_pinctrl_init(void) 375{ 376 return platform_driver_register(&mtk_pinctrl_driver); 377} | 1432 .of_match_table = mt7623_pctrl_match, 1433 }, 1434}; 1435 1436static int __init mtk_pinctrl_init(void) 1437{ 1438 return platform_driver_register(&mtk_pinctrl_driver); 1439} |
378 | |
379arch_initcall(mtk_pinctrl_init); | 1440arch_initcall(mtk_pinctrl_init); |