mirror of
https://github.com/smaeul/u-boot.git
synced 2025-09-14 22:16:03 +01:00
This patch adds pinctrl and gpio support for MT7987 SoC Signed-off-by: Weijie Gao <weijie.gao@mediatek.com>
737 lines
32 KiB
C
737 lines
32 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Copyright (C) 2024 MediaTek Inc.
|
|
* Author: Tim.Kuo <tim.kuo@mediatek.com>
|
|
*/
|
|
|
|
#include <dm.h>
|
|
#include "pinctrl-mtk-common.h"
|
|
|
|
enum MT7987_PINCTRL_REG_PAGE {
|
|
GPIO_BASE,
|
|
IOCFG_RB_BASE,
|
|
IOCFG_LB_BASE,
|
|
IOCFG_RT1_BASE,
|
|
IOCFG_RT2_BASE,
|
|
IOCFG_TL_BASE,
|
|
};
|
|
|
|
/*
|
|
* IO_TYPE_GRP0 / IO_TYPE_GRP1
|
|
* MT7987 pins can be divided into two groups:
|
|
* - PUPD_R0_R1
|
|
* - PU/PD
|
|
* Here, we divide pins with PU/PD to be IO_TYPE_GRP0 and those with PUPD_R0_R1
|
|
* to be IO_TYPE_GRP1.
|
|
* - PUPD_R0_R1 : IO_TYPE_GRP0
|
|
* - PU/PD : IO_TYPE_GRP1
|
|
* DRV_GRP4
|
|
* For MT7987, thr driving of pins can start from 2mA and increase by 2mA
|
|
* increments up to 16mA.
|
|
*/
|
|
#define MT7987_TYPE0_PIN(_number, _name) \
|
|
MTK_TYPED_PIN(_number, _name, DRV_GRP4, IO_TYPE_GRP0)
|
|
|
|
#define MT7987_TYPE1_PIN(_number, _name) \
|
|
MTK_TYPED_PIN(_number, _name, DRV_GRP4, IO_TYPE_GRP1)
|
|
|
|
#define PIN_FIELD_GPIO(_s_pin, _e_pin, _s_addr, _x_addrs, _s_bit, _x_bits) \
|
|
PIN_FIELD_BASE_CALC(_s_pin, _e_pin, GPIO_BASE, _s_addr, _x_addrs, \
|
|
_s_bit, _x_bits, 32, 0)
|
|
|
|
#define PIN_FIELD_BASE(_s_pin, _e_pin, _i_base, _s_addr, _x_addrs, _s_bit, \
|
|
_x_bits) \
|
|
PIN_FIELD_BASE_CALC(_s_pin, _e_pin, _i_base, _s_addr, _x_addrs, \
|
|
_s_bit, _x_bits, 32, 0)
|
|
|
|
#define PINS_FIELD_BASE(_s_pin, _e_pin, _i_base, _s_addr, _x_addrs, _s_bit, \
|
|
_x_bits) \
|
|
PIN_FIELD_BASE_CALC(_s_pin, _e_pin, _i_base, _s_addr, _x_addrs, \
|
|
_s_bit, _x_bits, 32, 1)
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_mode_range[] = {
|
|
PIN_FIELD_GPIO(0, 49, 0x300, 0x10, 0, 4),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_dir_range[] = {
|
|
PIN_FIELD_GPIO(0, 49, 0x0, 0x10, 0, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_di_range[] = {
|
|
PIN_FIELD_GPIO(0, 49, 0x200, 0x10, 0, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_do_range[] = {
|
|
PIN_FIELD_GPIO(0, 49, 0x100, 0x10, 0, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_ies_range[] = {
|
|
PIN_FIELD_BASE(0, 0, IOCFG_RT2_BASE, 0x20, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(1, 1, IOCFG_RT2_BASE, 0x20, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(2, 2, IOCFG_RT2_BASE, 0x20, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(3, 3, IOCFG_TL_BASE, 0x20, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(4, 4, IOCFG_TL_BASE, 0x20, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(5, 5, IOCFG_TL_BASE, 0x20, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(6, 6, IOCFG_TL_BASE, 0x20, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(7, 7, IOCFG_TL_BASE, 0x20, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(8, 8, IOCFG_RB_BASE, 0x10, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(9, 9, IOCFG_RB_BASE, 0x10, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(10, 10, IOCFG_RB_BASE, 0x10, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(11, 11, IOCFG_RB_BASE, 0x10, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(12, 12, IOCFG_RB_BASE, 0x10, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(13, 13, IOCFG_RT1_BASE, 0x20, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(14, 14, IOCFG_RT1_BASE, 0x20, 0x10, 15, 1),
|
|
PIN_FIELD_BASE(15, 15, IOCFG_RT1_BASE, 0x20, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(16, 16, IOCFG_RT1_BASE, 0x20, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(17, 17, IOCFG_RT1_BASE, 0x20, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(18, 18, IOCFG_RT1_BASE, 0x20, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(19, 19, IOCFG_RT1_BASE, 0x20, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(20, 20, IOCFG_RT1_BASE, 0x20, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(21, 21, IOCFG_RT1_BASE, 0x20, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(22, 22, IOCFG_RT1_BASE, 0x20, 0x10, 12, 1),
|
|
PIN_FIELD_BASE(23, 23, IOCFG_RT1_BASE, 0x20, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(24, 24, IOCFG_RT1_BASE, 0x20, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(25, 25, IOCFG_RT1_BASE, 0x20, 0x10, 13, 1),
|
|
PIN_FIELD_BASE(26, 26, IOCFG_RT1_BASE, 0x20, 0x10, 14, 1),
|
|
PIN_FIELD_BASE(27, 27, IOCFG_RT2_BASE, 0x20, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(28, 28, IOCFG_RT2_BASE, 0x20, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(29, 29, IOCFG_RT2_BASE, 0x20, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(30, 30, IOCFG_RT2_BASE, 0x20, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(31, 31, IOCFG_TL_BASE, 0x20, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(32, 32, IOCFG_TL_BASE, 0x20, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(33, 33, IOCFG_LB_BASE, 0x20, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(34, 34, IOCFG_LB_BASE, 0x20, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(35, 35, IOCFG_LB_BASE, 0x20, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(36, 36, IOCFG_LB_BASE, 0x20, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(37, 37, IOCFG_LB_BASE, 0x20, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(38, 38, IOCFG_LB_BASE, 0x20, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(39, 39, IOCFG_RT1_BASE, 0x20, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(40, 40, IOCFG_RT1_BASE, 0x20, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(41, 41, IOCFG_RT2_BASE, 0x20, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(42, 42, IOCFG_RT2_BASE, 0x20, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(43, 43, IOCFG_RT2_BASE, 0x20, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(44, 44, IOCFG_RT2_BASE, 0x20, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(45, 45, IOCFG_RT2_BASE, 0x20, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(46, 46, IOCFG_TL_BASE, 0x20, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(47, 47, IOCFG_TL_BASE, 0x20, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(48, 48, IOCFG_TL_BASE, 0x20, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(49, 49, IOCFG_TL_BASE, 0x20, 0x10, 8, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_smt_range[] = {
|
|
PIN_FIELD_BASE(0, 0, IOCFG_RT2_BASE, 0x90, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(1, 1, IOCFG_RT2_BASE, 0x90, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(2, 2, IOCFG_RT2_BASE, 0x90, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(3, 3, IOCFG_TL_BASE, 0x90, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(4, 4, IOCFG_TL_BASE, 0x90, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(5, 5, IOCFG_TL_BASE, 0x90, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(6, 6, IOCFG_TL_BASE, 0x90, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(7, 7, IOCFG_TL_BASE, 0x90, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(8, 8, IOCFG_RB_BASE, 0x70, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(9, 9, IOCFG_RB_BASE, 0x70, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(10, 10, IOCFG_RB_BASE, 0x70, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(11, 11, IOCFG_RB_BASE, 0x70, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(12, 12, IOCFG_RB_BASE, 0x70, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(13, 13, IOCFG_RT1_BASE, 0xA0, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(14, 14, IOCFG_RT1_BASE, 0xA0, 0x10, 15, 1),
|
|
PIN_FIELD_BASE(15, 15, IOCFG_RT1_BASE, 0xA0, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(16, 16, IOCFG_RT1_BASE, 0xA0, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(17, 17, IOCFG_RT1_BASE, 0xA0, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(18, 18, IOCFG_RT1_BASE, 0xA0, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(19, 19, IOCFG_RT1_BASE, 0xA0, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(20, 20, IOCFG_RT1_BASE, 0xA0, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(21, 21, IOCFG_RT1_BASE, 0xA0, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(22, 22, IOCFG_RT1_BASE, 0xA0, 0x10, 12, 1),
|
|
PIN_FIELD_BASE(23, 23, IOCFG_RT1_BASE, 0xA0, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(24, 24, IOCFG_RT1_BASE, 0xA0, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(25, 25, IOCFG_RT1_BASE, 0xA0, 0x10, 13, 1),
|
|
PIN_FIELD_BASE(26, 26, IOCFG_RT1_BASE, 0xA0, 0x10, 14, 1),
|
|
PIN_FIELD_BASE(27, 27, IOCFG_RT2_BASE, 0x90, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(28, 28, IOCFG_RT2_BASE, 0x90, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(29, 29, IOCFG_RT2_BASE, 0x90, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(30, 30, IOCFG_RT2_BASE, 0x90, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(31, 31, IOCFG_TL_BASE, 0x90, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(32, 32, IOCFG_TL_BASE, 0x90, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(33, 33, IOCFG_LB_BASE, 0x60, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(34, 34, IOCFG_LB_BASE, 0x60, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(35, 35, IOCFG_LB_BASE, 0x60, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(36, 36, IOCFG_LB_BASE, 0x60, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(37, 37, IOCFG_LB_BASE, 0x60, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(38, 38, IOCFG_LB_BASE, 0x60, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(39, 39, IOCFG_RT1_BASE, 0xA0, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(40, 40, IOCFG_RT1_BASE, 0xA0, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(41, 41, IOCFG_RT2_BASE, 0x90, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(42, 42, IOCFG_RT2_BASE, 0x90, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(43, 43, IOCFG_RT2_BASE, 0x90, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(44, 44, IOCFG_RT2_BASE, 0x90, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(45, 45, IOCFG_RT2_BASE, 0x90, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(46, 46, IOCFG_TL_BASE, 0x90, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(47, 47, IOCFG_TL_BASE, 0x90, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(48, 48, IOCFG_TL_BASE, 0x90, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(49, 49, IOCFG_TL_BASE, 0x90, 0x10, 8, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_pu_range[] = {
|
|
PIN_FIELD_BASE(33, 33, IOCFG_LB_BASE, 0x40, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(34, 34, IOCFG_LB_BASE, 0x40, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(35, 35, IOCFG_LB_BASE, 0x40, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(36, 36, IOCFG_LB_BASE, 0x40, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(37, 37, IOCFG_LB_BASE, 0x40, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(38, 38, IOCFG_LB_BASE, 0x40, 0x10, 5, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_pd_range[] = {
|
|
PIN_FIELD_BASE(33, 33, IOCFG_LB_BASE, 0x30, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(34, 34, IOCFG_LB_BASE, 0x30, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(35, 35, IOCFG_LB_BASE, 0x30, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(36, 36, IOCFG_LB_BASE, 0x30, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(37, 37, IOCFG_LB_BASE, 0x30, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(38, 38, IOCFG_LB_BASE, 0x30, 0x10, 5, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_drv_range[] = {
|
|
PIN_FIELD_BASE(0, 0, IOCFG_RT2_BASE, 0x0, 0x10, 9, 3),
|
|
PIN_FIELD_BASE(1, 1, IOCFG_RT2_BASE, 0x0, 0x10, 6, 3),
|
|
PIN_FIELD_BASE(2, 2, IOCFG_RT2_BASE, 0x10, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(3, 3, IOCFG_TL_BASE, 0x0, 0x10, 6, 3),
|
|
PIN_FIELD_BASE(4, 4, IOCFG_TL_BASE, 0x0, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(5, 5, IOCFG_TL_BASE, 0x0, 0x10, 9, 3),
|
|
PIN_FIELD_BASE(6, 6, IOCFG_TL_BASE, 0x0, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(7, 7, IOCFG_TL_BASE, 0x0, 0x10, 12, 3),
|
|
PIN_FIELD_BASE(8, 8, IOCFG_RB_BASE, 0x0, 0x10, 6, 3),
|
|
PIN_FIELD_BASE(9, 9, IOCFG_RB_BASE, 0x0, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(10, 10, IOCFG_RB_BASE, 0x0, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(11, 11, IOCFG_RB_BASE, 0x0, 0x10, 9, 3),
|
|
PIN_FIELD_BASE(12, 12, IOCFG_RB_BASE, 0x0, 0x10, 12, 3),
|
|
PIN_FIELD_BASE(13, 13, IOCFG_RT1_BASE, 0x0, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(14, 14, IOCFG_RT1_BASE, 0x10, 0x10, 15, 3),
|
|
PIN_FIELD_BASE(15, 15, IOCFG_RT1_BASE, 0x0, 0x10, 9, 3),
|
|
PIN_FIELD_BASE(16, 16, IOCFG_RT1_BASE, 0x0, 0x10, 21, 3),
|
|
PIN_FIELD_BASE(17, 17, IOCFG_RT1_BASE, 0x0, 0x10, 18, 3),
|
|
PIN_FIELD_BASE(18, 18, IOCFG_RT1_BASE, 0x0, 0x10, 12, 3),
|
|
PIN_FIELD_BASE(19, 19, IOCFG_RT1_BASE, 0x0, 0x10, 15, 3),
|
|
PIN_FIELD_BASE(20, 20, IOCFG_RT1_BASE, 0x0, 0x10, 24, 3),
|
|
PIN_FIELD_BASE(21, 21, IOCFG_RT1_BASE, 0x0, 0x10, 27, 3),
|
|
PIN_FIELD_BASE(22, 22, IOCFG_RT1_BASE, 0x10, 0x10, 6, 3),
|
|
PIN_FIELD_BASE(23, 23, IOCFG_RT1_BASE, 0x10, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(24, 24, IOCFG_RT1_BASE, 0x10, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(25, 25, IOCFG_RT1_BASE, 0x10, 0x10, 9, 3),
|
|
PIN_FIELD_BASE(26, 26, IOCFG_RT1_BASE, 0x10, 0x10, 12, 3),
|
|
PIN_FIELD_BASE(27, 27, IOCFG_RT2_BASE, 0x0, 0x10, 27, 3),
|
|
PIN_FIELD_BASE(28, 28, IOCFG_RT2_BASE, 0x0, 0x10, 21, 3),
|
|
PIN_FIELD_BASE(29, 29, IOCFG_RT2_BASE, 0x0, 0x10, 24, 3),
|
|
PIN_FIELD_BASE(30, 30, IOCFG_RT2_BASE, 0x10, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(31, 31, IOCFG_TL_BASE, 0x0, 0x10, 15, 3),
|
|
PIN_FIELD_BASE(32, 32, IOCFG_TL_BASE, 0x0, 0x10, 18, 3),
|
|
PIN_FIELD_BASE(33, 33, IOCFG_LB_BASE, 0x0, 0x10, 6, 3),
|
|
PIN_FIELD_BASE(34, 34, IOCFG_LB_BASE, 0x0, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(35, 35, IOCFG_LB_BASE, 0x0, 0x10, 12, 3),
|
|
PIN_FIELD_BASE(36, 36, IOCFG_LB_BASE, 0x0, 0x10, 9, 3),
|
|
PIN_FIELD_BASE(37, 37, IOCFG_LB_BASE, 0x0, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(38, 38, IOCFG_LB_BASE, 0x0, 0x10, 15, 3),
|
|
PIN_FIELD_BASE(39, 39, IOCFG_RT1_BASE, 0x0, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(40, 40, IOCFG_RT1_BASE, 0x0, 0x10, 6, 3),
|
|
PIN_FIELD_BASE(41, 41, IOCFG_RT2_BASE, 0x0, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(42, 42, IOCFG_RT2_BASE, 0x0, 0x10, 3, 3),
|
|
PIN_FIELD_BASE(43, 43, IOCFG_RT2_BASE, 0x0, 0x10, 12, 3),
|
|
PIN_FIELD_BASE(44, 44, IOCFG_RT2_BASE, 0x0, 0x10, 15, 3),
|
|
PIN_FIELD_BASE(45, 45, IOCFG_RT2_BASE, 0x0, 0x10, 18, 3),
|
|
PIN_FIELD_BASE(46, 46, IOCFG_TL_BASE, 0x0, 0x10, 27, 3),
|
|
PIN_FIELD_BASE(47, 47, IOCFG_TL_BASE, 0x10, 0x10, 0, 3),
|
|
PIN_FIELD_BASE(48, 48, IOCFG_TL_BASE, 0x0, 0x10, 21, 3),
|
|
PIN_FIELD_BASE(49, 49, IOCFG_TL_BASE, 0x0, 0x10, 24, 3),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_pupd_range[] = {
|
|
PIN_FIELD_BASE(0, 0, IOCFG_RT2_BASE, 0x30, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(1, 1, IOCFG_RT2_BASE, 0x30, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(2, 2, IOCFG_RT2_BASE, 0x30, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(3, 3, IOCFG_TL_BASE, 0x30, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(4, 4, IOCFG_TL_BASE, 0x30, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(5, 5, IOCFG_TL_BASE, 0x30, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(6, 6, IOCFG_TL_BASE, 0x30, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(7, 7, IOCFG_TL_BASE, 0x30, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(8, 8, IOCFG_RB_BASE, 0x20, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(9, 9, IOCFG_RB_BASE, 0x20, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(10, 10, IOCFG_RB_BASE, 0x20, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(11, 11, IOCFG_RB_BASE, 0x20, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(12, 12, IOCFG_RB_BASE, 0x20, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(13, 13, IOCFG_RT1_BASE, 0x30, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(14, 14, IOCFG_RT1_BASE, 0x30, 0x10, 15, 1),
|
|
PIN_FIELD_BASE(15, 15, IOCFG_RT1_BASE, 0x30, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(16, 16, IOCFG_RT1_BASE, 0x30, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(17, 17, IOCFG_RT1_BASE, 0x30, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(18, 18, IOCFG_RT1_BASE, 0x30, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(19, 19, IOCFG_RT1_BASE, 0x30, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(20, 20, IOCFG_RT1_BASE, 0x30, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(21, 21, IOCFG_RT1_BASE, 0x30, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(22, 22, IOCFG_RT1_BASE, 0x30, 0x10, 12, 1),
|
|
PIN_FIELD_BASE(23, 23, IOCFG_RT1_BASE, 0x30, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(24, 24, IOCFG_RT1_BASE, 0x30, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(25, 25, IOCFG_RT1_BASE, 0x30, 0x10, 13, 1),
|
|
PIN_FIELD_BASE(26, 26, IOCFG_RT1_BASE, 0x30, 0x10, 14, 1),
|
|
PIN_FIELD_BASE(27, 27, IOCFG_RT2_BASE, 0x30, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(28, 28, IOCFG_RT2_BASE, 0x30, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(29, 29, IOCFG_RT2_BASE, 0x30, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(30, 30, IOCFG_RT2_BASE, 0x30, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(31, 31, IOCFG_TL_BASE, 0x30, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(32, 32, IOCFG_TL_BASE, 0x30, 0x10, 6, 1),
|
|
|
|
PIN_FIELD_BASE(39, 39, IOCFG_RT1_BASE, 0x30, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(40, 40, IOCFG_RT1_BASE, 0x30, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(41, 41, IOCFG_RT2_BASE, 0x30, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(42, 42, IOCFG_RT2_BASE, 0x30, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(43, 43, IOCFG_RT2_BASE, 0x30, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(44, 44, IOCFG_RT2_BASE, 0x30, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(45, 45, IOCFG_RT2_BASE, 0x30, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(46, 46, IOCFG_TL_BASE, 0x30, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(47, 47, IOCFG_TL_BASE, 0x30, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(48, 48, IOCFG_TL_BASE, 0x30, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(49, 49, IOCFG_TL_BASE, 0x30, 0x10, 8, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_r0_range[] = {
|
|
PIN_FIELD_BASE(0, 0, IOCFG_RT2_BASE, 0x40, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(1, 1, IOCFG_RT2_BASE, 0x40, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(2, 2, IOCFG_RT2_BASE, 0x40, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(3, 3, IOCFG_TL_BASE, 0x40, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(4, 4, IOCFG_TL_BASE, 0x40, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(5, 5, IOCFG_TL_BASE, 0x40, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(6, 6, IOCFG_TL_BASE, 0x40, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(7, 7, IOCFG_TL_BASE, 0x40, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(8, 8, IOCFG_RB_BASE, 0x30, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(9, 9, IOCFG_RB_BASE, 0x30, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(10, 10, IOCFG_RB_BASE, 0x30, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(11, 11, IOCFG_RB_BASE, 0x30, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(12, 12, IOCFG_RB_BASE, 0x30, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(13, 13, IOCFG_RT1_BASE, 0x40, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(14, 14, IOCFG_RT1_BASE, 0x40, 0x10, 15, 1),
|
|
PIN_FIELD_BASE(15, 15, IOCFG_RT1_BASE, 0x40, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(16, 16, IOCFG_RT1_BASE, 0x40, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(17, 17, IOCFG_RT1_BASE, 0x40, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(18, 18, IOCFG_RT1_BASE, 0x40, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(19, 19, IOCFG_RT1_BASE, 0x40, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(20, 20, IOCFG_RT1_BASE, 0x40, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(21, 21, IOCFG_RT1_BASE, 0x40, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(22, 22, IOCFG_RT1_BASE, 0x40, 0x10, 12, 1),
|
|
PIN_FIELD_BASE(23, 23, IOCFG_RT1_BASE, 0x40, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(24, 24, IOCFG_RT1_BASE, 0x40, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(25, 25, IOCFG_RT1_BASE, 0x40, 0x10, 13, 1),
|
|
PIN_FIELD_BASE(26, 26, IOCFG_RT1_BASE, 0x40, 0x10, 14, 1),
|
|
PIN_FIELD_BASE(27, 27, IOCFG_RT2_BASE, 0x40, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(28, 28, IOCFG_RT2_BASE, 0x40, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(29, 29, IOCFG_RT2_BASE, 0x40, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(30, 30, IOCFG_RT2_BASE, 0x40, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(31, 31, IOCFG_TL_BASE, 0x40, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(32, 32, IOCFG_TL_BASE, 0x40, 0x10, 6, 1),
|
|
|
|
PIN_FIELD_BASE(39, 39, IOCFG_RT1_BASE, 0x40, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(40, 40, IOCFG_RT1_BASE, 0x40, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(41, 41, IOCFG_RT2_BASE, 0x40, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(42, 42, IOCFG_RT2_BASE, 0x40, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(43, 43, IOCFG_RT2_BASE, 0x40, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(44, 44, IOCFG_RT2_BASE, 0x40, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(45, 45, IOCFG_RT2_BASE, 0x40, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(46, 46, IOCFG_TL_BASE, 0x40, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(47, 47, IOCFG_TL_BASE, 0x40, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(48, 48, IOCFG_TL_BASE, 0x40, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(49, 49, IOCFG_TL_BASE, 0x40, 0x10, 8, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_field_calc mt7987_pin_r1_range[] = {
|
|
PIN_FIELD_BASE(0, 0, IOCFG_RT2_BASE, 0x50, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(1, 1, IOCFG_RT2_BASE, 0x50, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(2, 2, IOCFG_RT2_BASE, 0x50, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(3, 3, IOCFG_TL_BASE, 0x50, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(4, 4, IOCFG_TL_BASE, 0x50, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(5, 5, IOCFG_TL_BASE, 0x50, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(6, 6, IOCFG_TL_BASE, 0x50, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(7, 7, IOCFG_TL_BASE, 0x50, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(8, 8, IOCFG_RB_BASE, 0x40, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(9, 9, IOCFG_RB_BASE, 0x40, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(10, 10, IOCFG_RB_BASE, 0x40, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(11, 11, IOCFG_RB_BASE, 0x40, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(12, 12, IOCFG_RB_BASE, 0x40, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(13, 13, IOCFG_RT1_BASE, 0x50, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(14, 14, IOCFG_RT1_BASE, 0x50, 0x10, 15, 1),
|
|
PIN_FIELD_BASE(15, 15, IOCFG_RT1_BASE, 0x50, 0x10, 3, 1),
|
|
PIN_FIELD_BASE(16, 16, IOCFG_RT1_BASE, 0x50, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(17, 17, IOCFG_RT1_BASE, 0x50, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(18, 18, IOCFG_RT1_BASE, 0x50, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(19, 19, IOCFG_RT1_BASE, 0x50, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(20, 20, IOCFG_RT1_BASE, 0x50, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(21, 21, IOCFG_RT1_BASE, 0x50, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(22, 22, IOCFG_RT1_BASE, 0x50, 0x10, 12, 1),
|
|
PIN_FIELD_BASE(23, 23, IOCFG_RT1_BASE, 0x50, 0x10, 11, 1),
|
|
PIN_FIELD_BASE(24, 24, IOCFG_RT1_BASE, 0x50, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(25, 25, IOCFG_RT1_BASE, 0x50, 0x10, 13, 1),
|
|
PIN_FIELD_BASE(26, 26, IOCFG_RT1_BASE, 0x50, 0x10, 14, 1),
|
|
PIN_FIELD_BASE(27, 27, IOCFG_RT2_BASE, 0x50, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(28, 28, IOCFG_RT2_BASE, 0x50, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(29, 29, IOCFG_RT2_BASE, 0x50, 0x10, 8, 1),
|
|
PIN_FIELD_BASE(30, 30, IOCFG_RT2_BASE, 0x50, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(31, 31, IOCFG_TL_BASE, 0x50, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(32, 32, IOCFG_TL_BASE, 0x50, 0x10, 6, 1),
|
|
|
|
PIN_FIELD_BASE(39, 39, IOCFG_RT1_BASE, 0x50, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(40, 40, IOCFG_RT1_BASE, 0x50, 0x10, 2, 1),
|
|
PIN_FIELD_BASE(41, 41, IOCFG_RT2_BASE, 0x50, 0x10, 0, 1),
|
|
PIN_FIELD_BASE(42, 42, IOCFG_RT2_BASE, 0x50, 0x10, 1, 1),
|
|
PIN_FIELD_BASE(43, 43, IOCFG_RT2_BASE, 0x50, 0x10, 4, 1),
|
|
PIN_FIELD_BASE(44, 44, IOCFG_RT2_BASE, 0x50, 0x10, 5, 1),
|
|
PIN_FIELD_BASE(45, 45, IOCFG_RT2_BASE, 0x50, 0x10, 6, 1),
|
|
PIN_FIELD_BASE(46, 46, IOCFG_TL_BASE, 0x50, 0x10, 9, 1),
|
|
PIN_FIELD_BASE(47, 47, IOCFG_TL_BASE, 0x50, 0x10, 10, 1),
|
|
PIN_FIELD_BASE(48, 48, IOCFG_TL_BASE, 0x50, 0x10, 7, 1),
|
|
PIN_FIELD_BASE(49, 49, IOCFG_TL_BASE, 0x50, 0x10, 8, 1),
|
|
};
|
|
|
|
static const struct mtk_pin_reg_calc mt7987_reg_cals[] = {
|
|
[PINCTRL_PIN_REG_MODE] = MTK_RANGE(mt7987_pin_mode_range),
|
|
[PINCTRL_PIN_REG_DIR] = MTK_RANGE(mt7987_pin_dir_range),
|
|
[PINCTRL_PIN_REG_DI] = MTK_RANGE(mt7987_pin_di_range),
|
|
[PINCTRL_PIN_REG_DO] = MTK_RANGE(mt7987_pin_do_range),
|
|
[PINCTRL_PIN_REG_SMT] = MTK_RANGE(mt7987_pin_smt_range),
|
|
[PINCTRL_PIN_REG_IES] = MTK_RANGE(mt7987_pin_ies_range),
|
|
[PINCTRL_PIN_REG_PU] = MTK_RANGE(mt7987_pin_pu_range),
|
|
[PINCTRL_PIN_REG_PD] = MTK_RANGE(mt7987_pin_pd_range),
|
|
[PINCTRL_PIN_REG_DRV] = MTK_RANGE(mt7987_pin_drv_range),
|
|
[PINCTRL_PIN_REG_PUPD] = MTK_RANGE(mt7987_pin_pupd_range),
|
|
[PINCTRL_PIN_REG_R0] = MTK_RANGE(mt7987_pin_r0_range),
|
|
[PINCTRL_PIN_REG_R1] = MTK_RANGE(mt7987_pin_r1_range),
|
|
};
|
|
|
|
static const struct mtk_pin_desc mt7987_pins[] = {
|
|
MT7987_TYPE0_PIN(0, "GPIO_WPS"),
|
|
MT7987_TYPE0_PIN(1, "GPIO_RESET"),
|
|
MT7987_TYPE0_PIN(2, "SYS_WATCHDOG"),
|
|
MT7987_TYPE0_PIN(3, "JTAG_JTDO"),
|
|
MT7987_TYPE0_PIN(4, "JTAG_JTDI"),
|
|
MT7987_TYPE0_PIN(5, "JTAG_JTMS"),
|
|
MT7987_TYPE0_PIN(6, "JTAG_JTCLK"),
|
|
MT7987_TYPE0_PIN(7, "JTAG_JTRST_N"),
|
|
MT7987_TYPE0_PIN(8, "PCM_DTX_I2S_DOUT"),
|
|
MT7987_TYPE0_PIN(9, "PCM_DRX_I2S_DIN"),
|
|
MT7987_TYPE0_PIN(10, "PCM_CLK_I2S_BCLK"),
|
|
MT7987_TYPE0_PIN(11, "PCM_FS_I2S_LRCK"),
|
|
MT7987_TYPE0_PIN(12, "PCM_MCK_I2S_MCLK"),
|
|
MT7987_TYPE0_PIN(13, "PWM0"),
|
|
MT7987_TYPE0_PIN(14, "USB_VBUS"),
|
|
MT7987_TYPE0_PIN(15, "SPI0_CLK"),
|
|
MT7987_TYPE0_PIN(16, "SPI0_MOSI"),
|
|
MT7987_TYPE0_PIN(17, "SPI0_MISO"),
|
|
MT7987_TYPE0_PIN(18, "SPI0_CS"),
|
|
MT7987_TYPE0_PIN(19, "SPI0_HOLD"),
|
|
MT7987_TYPE0_PIN(20, "SPI0_WP"),
|
|
MT7987_TYPE0_PIN(21, "SPI1_CLK"),
|
|
MT7987_TYPE0_PIN(22, "SPI1_MOSI"),
|
|
MT7987_TYPE0_PIN(23, "SPI1_MISO"),
|
|
MT7987_TYPE0_PIN(24, "SPI1_CS"),
|
|
MT7987_TYPE0_PIN(25, "SPI2_CLK"),
|
|
MT7987_TYPE0_PIN(26, "SPI2_MOSI"),
|
|
MT7987_TYPE0_PIN(27, "SPI2_MISO"),
|
|
MT7987_TYPE0_PIN(28, "SPI2_CS"),
|
|
MT7987_TYPE0_PIN(29, "SPI2_HOLD"),
|
|
MT7987_TYPE0_PIN(30, "SPI2_WP"),
|
|
MT7987_TYPE0_PIN(31, "UART0_RXD"),
|
|
MT7987_TYPE0_PIN(32, "UART0_TXD"),
|
|
MT7987_TYPE1_PIN(33, "PCIE_PERESET_N_0"),
|
|
MT7987_TYPE1_PIN(34, "PCIE_CLK_REQ_0"),
|
|
MT7987_TYPE1_PIN(35, "PCIE_WAKE_N_0"),
|
|
MT7987_TYPE1_PIN(36, "PCIE_PERESET_N_1"),
|
|
MT7987_TYPE1_PIN(37, "PCIE_CLK_REQ_1"),
|
|
MT7987_TYPE1_PIN(38, "PCIE_WAKE_N_1"),
|
|
MT7987_TYPE0_PIN(39, "SMI_MDC"),
|
|
MT7987_TYPE0_PIN(40, "SMI_MDIO"),
|
|
MT7987_TYPE0_PIN(41, "GBE_INT"),
|
|
MT7987_TYPE0_PIN(42, "GBE_RESET"),
|
|
MT7987_TYPE0_PIN(43, "I2C_SCLK"),
|
|
MT7987_TYPE0_PIN(44, "I2C_SDATA"),
|
|
MT7987_TYPE0_PIN(45, "2P5G_LED0"),
|
|
MT7987_TYPE0_PIN(46, "UART1_RXD"),
|
|
MT7987_TYPE0_PIN(47, "UART1_TXD"),
|
|
MT7987_TYPE0_PIN(48, "UART1_CTS"),
|
|
MT7987_TYPE0_PIN(49, "UART1_RTS"),
|
|
};
|
|
|
|
/* watchdog */
|
|
static const int mt7987_watchdog_pins[] = {2};
|
|
static const int mt7987_watchdog_funcs[] = {1};
|
|
|
|
/* jtag */
|
|
static const int mt7987_jtag_pins[] = {3, 4, 5, 6, 7};
|
|
static const int mt7987_jtag_funcs[] = {1, 1, 1, 1, 1};
|
|
|
|
/* pcm */
|
|
static const int mt7987_pcm0_0_pins[] = {3, 4, 5, 6, 7};
|
|
static const int mt7987_pcm0_0_funcs[] = {2, 2, 2, 2, 2};
|
|
|
|
static const int mt7987_pcm0_1_pins[] = {8, 9, 10, 11, 12};
|
|
static const int mt7987_pcm0_1_funcs[] = {1, 1, 1, 1, 1};
|
|
|
|
/* uart */
|
|
static const int mt7987_uart0_pins[] = {31, 32};
|
|
static const int mt7987_uart0_funcs[] = {1, 1};
|
|
|
|
static const int mt7987_uart1_0_pins[] = {3, 4, 5, 6};
|
|
static const int mt7987_uart1_0_funcs[] = {3, 3, 3, 3};
|
|
|
|
static const int mt7987_uart1_1_pins[] = {21, 22, 23, 24};
|
|
static const int mt7987_uart1_1_funcs[] = {3, 3, 3, 3};
|
|
|
|
static const int mt7987_uart1_2_pins[] = {46, 47, 48, 49};
|
|
static const int mt7987_uart1_2_funcs[] = {1, 1, 1, 1};
|
|
|
|
static const int mt7987_uart2_0_pins[] = {8, 9, 10, 11};
|
|
static const int mt7987_uart2_0_funcs[] = {2, 2, 2, 2};
|
|
|
|
static const int mt7987_uart2_1_pins[] = {25, 26, 27, 28};
|
|
static const int mt7987_uart2_1_funcs[] = {2, 2, 2, 2};
|
|
|
|
/* pwm */
|
|
static const int mt7987_pwm0_pins[] = {13};
|
|
static const int mt7987_pwm0_funcs[] = {1};
|
|
|
|
static const int mt7987_pwm1_0_pins[] = {7};
|
|
static const int mt7987_pwm1_0_funcs[] = {3};
|
|
|
|
static const int mt7987_pwm1_1_pins[] = {43};
|
|
static const int mt7987_pwm1_1_funcs[] = {2};
|
|
|
|
static const int mt7987_pwm2_0_pins[] = {12};
|
|
static const int mt7987_pwm2_0_funcs[] = {2};
|
|
|
|
static const int mt7987_pwm2_1_pins[] = {44};
|
|
static const int mt7987_pwm2_1_funcs[] = {2};
|
|
|
|
/* vbus */
|
|
static const int mt7987_drv_vbus_p1_pins[] = {14};
|
|
static const int mt7987_drv_vbus_p1_funcs[] = {1};
|
|
|
|
static const int mt7987_drv_vbus_pins[] = {48};
|
|
static const int mt7987_drv_vbus_funcs[] = {3};
|
|
|
|
/* 2p5gbe_led */
|
|
static const int mt7987_2p5gbe_led0_pins[] = {45};
|
|
static const int mt7987_2p5gbe_led0_funcs[] = {1};
|
|
|
|
static const int mt7987_2p5gbe_led1_0_pins[] = {13};
|
|
static const int mt7987_2p5gbe_led1_0_funcs[] = {2};
|
|
|
|
static const int mt7987_2p5gbe_led1_1_pins[] = {49};
|
|
static const int mt7987_2p5gbe_led1_1_funcs[] = {3};
|
|
|
|
/* mdc, mdio */
|
|
static const int mt7987_2p5g_ext_mdc_mdio_pins[] = {23, 24};
|
|
static const int mt7987_2p5g_ext_mdc_mdio_funcs[] = {4, 4};
|
|
|
|
static const int mt7987_mdc_mdio_pins[] = {39, 40};
|
|
static const int mt7987_mdc_mdio_funcs[] = {1, 1};
|
|
|
|
/* spi */
|
|
static const int mt7987_spi0_pins[] = {15, 16, 17, 18};
|
|
static const int mt7987_spi0_funcs[] = {1, 1, 1, 1};
|
|
|
|
static const int mt7987_spi0_wp_hold_pins[] = {19, 20};
|
|
static const int mt7987_spi0_wp_hold_funcs[] = {1, 1};
|
|
|
|
static const int mt7987_spi1_pins[] = {21, 22, 23, 24};
|
|
static const int mt7987_spi1_funcs[] = {1, 1, 1, 1};
|
|
|
|
static const int mt7987_spi1_1_pins[] = {46, 47, 48, 49};
|
|
static const int mt7987_spi1_1_funcs[] = {2, 2, 2, 2};
|
|
|
|
static const int mt7987_spi2_pins[] = {25, 26, 27, 28};
|
|
static const int mt7987_spi2_funcs[] = {1, 1, 1, 1};
|
|
|
|
static const int mt7987_spi2_wp_hold_pins[] = {29, 30};
|
|
static const int mt7987_spi2_wp_hold_funcs[] = {1, 1};
|
|
|
|
/* emmc */
|
|
static const int mt7987_emmc_45_pins[] = {14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24};
|
|
static const int mt7987_emmc_45_funcs[] = {2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2};
|
|
|
|
/* sd */
|
|
static const int mt7987_sd_pins[] = {15, 16, 17, 18, 23, 24};
|
|
static const int mt7987_sd_funcs[] = {2, 2, 2, 2, 2, 2};
|
|
|
|
/* i2c */
|
|
static const int mt7987_i2c0_0_pins[] = {29, 30};
|
|
static const int mt7987_i2c0_0_funcs[] = {2, 2};
|
|
|
|
static const int mt7987_i2c0_1_pins[] = {39, 40};
|
|
static const int mt7987_i2c0_1_funcs[] = {2, 2};
|
|
|
|
static const int mt7987_i2c0_2_pins[] = {43, 44};
|
|
static const int mt7987_i2c0_2_funcs[] = {1, 1};
|
|
|
|
/* pcie */
|
|
static const int mt7987_pcie0_pereset_pins[] = {33};
|
|
static const int mt7987_pcie0_pereset_funcs[] = {1};
|
|
|
|
static const int mt7987_pcie0_clkreq_pins[] = {34};
|
|
static const int mt7987_pcie0_clkreq_funcs[] = {1};
|
|
|
|
static const int mt7987_pcie0_wake_pins[] = {35};
|
|
static const int mt7987_pcie0_wake_funcs[] = {1};
|
|
|
|
static const int mt7987_pcie1_pereset_pins[] = {36};
|
|
static const int mt7987_pcie1_pereset_funcs[] = {1};
|
|
|
|
static const int mt7987_pcie1_clkreq_pins[] = {37};
|
|
static const int mt7987_pcie1_clkreq_funcs[] = {1};
|
|
|
|
static const int mt7987_pcie1_wake_pins[] = {38};
|
|
static const int mt7987_pcie1_wake_funcs[] = {1};
|
|
|
|
static const int mt7987_pcie_phy_i2c_pins[] = {43, 44};
|
|
static const int mt7987_pcie_phy_i2c_funcs[] = {3, 3};
|
|
|
|
/* snfi */
|
|
static const int mt7987_snfi_pins[] = {25, 26, 27, 28, 29, 30};
|
|
static const int mt7987_snfi_funcs[] = {3, 3, 3, 3, 3, 3};
|
|
|
|
/*
|
|
* - int hsgmii :
|
|
* For pin41 and pin46, they now can only be used as gpio mode for polling
|
|
* event. Hence, there's no need to open their pinctrl setting.
|
|
* - dfd, udi :
|
|
* Due to dfd & udi functions are only used as detection pins for cpu during
|
|
* dvt testing stage, we also remove their pinctrl setting.
|
|
*/
|
|
|
|
static const struct mtk_group_desc mt7987_groups[] = {
|
|
PINCTRL_PIN_GROUP("watchdog", mt7987_watchdog),
|
|
PINCTRL_PIN_GROUP("jtag", mt7987_jtag),
|
|
PINCTRL_PIN_GROUP("pcm0_0", mt7987_pcm0_0),
|
|
PINCTRL_PIN_GROUP("pcm0_1", mt7987_pcm0_1),
|
|
PINCTRL_PIN_GROUP("uart0", mt7987_uart0),
|
|
PINCTRL_PIN_GROUP("uart1_0", mt7987_uart1_0),
|
|
PINCTRL_PIN_GROUP("uart1_1", mt7987_uart1_1),
|
|
PINCTRL_PIN_GROUP("uart1_2", mt7987_uart1_2),
|
|
PINCTRL_PIN_GROUP("uart2_0", mt7987_uart2_0),
|
|
PINCTRL_PIN_GROUP("uart2_1", mt7987_uart2_1),
|
|
PINCTRL_PIN_GROUP("pwm0", mt7987_pwm0),
|
|
PINCTRL_PIN_GROUP("pwm1_0", mt7987_pwm1_0),
|
|
PINCTRL_PIN_GROUP("pwm1_1", mt7987_pwm1_1),
|
|
PINCTRL_PIN_GROUP("pwm2_0", mt7987_pwm2_0),
|
|
PINCTRL_PIN_GROUP("pwm2_1", mt7987_pwm2_1),
|
|
PINCTRL_PIN_GROUP("drv_vbus_p1", mt7987_drv_vbus_p1),
|
|
PINCTRL_PIN_GROUP("drv_vbus", mt7987_drv_vbus),
|
|
PINCTRL_PIN_GROUP("2p5gbe_led0", mt7987_2p5gbe_led0),
|
|
PINCTRL_PIN_GROUP("2p5gbe_led1_0", mt7987_2p5gbe_led1_0),
|
|
PINCTRL_PIN_GROUP("2p5gbe_led1_1", mt7987_2p5gbe_led1_1),
|
|
PINCTRL_PIN_GROUP("2p5g_ext_mdc_mdio", mt7987_2p5g_ext_mdc_mdio),
|
|
PINCTRL_PIN_GROUP("mdc_mdio", mt7987_mdc_mdio),
|
|
PINCTRL_PIN_GROUP("spi0", mt7987_spi0),
|
|
PINCTRL_PIN_GROUP("spi0_wp_hold", mt7987_spi0_wp_hold),
|
|
PINCTRL_PIN_GROUP("spi1", mt7987_spi1),
|
|
PINCTRL_PIN_GROUP("spi1_1", mt7987_spi1_1),
|
|
PINCTRL_PIN_GROUP("spi2", mt7987_spi2),
|
|
PINCTRL_PIN_GROUP("spi2_wp_hold", mt7987_spi2_wp_hold),
|
|
PINCTRL_PIN_GROUP("emmc_45", mt7987_emmc_45),
|
|
PINCTRL_PIN_GROUP("sd", mt7987_sd),
|
|
PINCTRL_PIN_GROUP("i2c0_0", mt7987_i2c0_0),
|
|
PINCTRL_PIN_GROUP("i2c0_1", mt7987_i2c0_1),
|
|
PINCTRL_PIN_GROUP("i2c0_2", mt7987_i2c0_2),
|
|
PINCTRL_PIN_GROUP("pcie_phy_i2c", mt7987_pcie_phy_i2c),
|
|
PINCTRL_PIN_GROUP("pcie0_pereset", mt7987_pcie0_pereset),
|
|
PINCTRL_PIN_GROUP("pcie0_clkreq", mt7987_pcie0_clkreq),
|
|
PINCTRL_PIN_GROUP("pcie0_wake", mt7987_pcie0_wake),
|
|
PINCTRL_PIN_GROUP("pcie1_pereset", mt7987_pcie1_pereset),
|
|
PINCTRL_PIN_GROUP("pcie1_clkreq", mt7987_pcie1_clkreq),
|
|
PINCTRL_PIN_GROUP("pcie1_wake", mt7987_pcie1_wake),
|
|
PINCTRL_PIN_GROUP("snfi", mt7987_snfi),
|
|
};
|
|
|
|
static const struct mtk_io_type_desc mt7987_io_type_desc[] = {
|
|
[IO_TYPE_GRP0] = {
|
|
.name = "18OD33",
|
|
.bias_set = mtk_pinconf_bias_set_pupd_r1_r0,
|
|
.drive_set = mtk_pinconf_drive_set_v1,
|
|
.input_enable = mtk_pinconf_input_enable_v1,
|
|
},
|
|
[IO_TYPE_GRP1] = {
|
|
.name = "18A01",
|
|
.bias_set = mtk_pinconf_bias_set_pu_pd,
|
|
.drive_set = mtk_pinconf_drive_set_v1,
|
|
.input_enable = mtk_pinconf_input_enable_v1,
|
|
},
|
|
};
|
|
|
|
static const char *const mt7987_wdt_groups[] = {"watchdog",};
|
|
static const char *const mt7987_jtag_groups[] = {"jtag",};
|
|
static const char *const mt7987_pcm_groups[] = {"pcm0_0", "pcm0_1"};
|
|
static const char *const mt7987_uart_groups[] = {"uart0", "uart1_0", "uart1_1",
|
|
"uart1_2", "uart2_0", "uart2_1",};
|
|
static const char *const mt7987_pwm_groups[] = {"pwm0", "pwm1_0", "pwm1_1", "pwm2_0",
|
|
"pwm2_1",};
|
|
static const char *const mt7987_usb_groups[] = {"drv_vbus_p1", "drv_vbus",};
|
|
static const char *const mt7987_led_groups[] = {"2p5gbe_led0", "2p5gbe_led1_0",
|
|
"2p5gbe_led1_1",};
|
|
static const char *const mt7987_ethernet_groups[] = {"2p5g_ext_mdc_mdio", "mdc_mdio",};
|
|
static const char *const mt7987_spi_groups[] = {"spi0", "spi0_wp_hold", "spi1",
|
|
"spi1_1", "spi2", "spi2_wp_hold",};
|
|
static const char *const mt7987_flash_groups[] = {"emmc_45", "snfi", "sd",};
|
|
static const char *const mt7987_i2c_groups[] = {"i2c0_0", "i2c0_1", "i2c0_2",};
|
|
static const char *const mt7987_pcie_groups[] = {"pcie_phy_i2c", "pcie0_pereset",
|
|
"pcie0_clkreq", "pcie0_wake",
|
|
"pcie1_pereset", "pcie1_clkreq",
|
|
"pcie1_wake",};
|
|
|
|
static const struct mtk_function_desc mt7987_functions[] = {
|
|
{"wdt", mt7987_wdt_groups, ARRAY_SIZE(mt7987_wdt_groups)},
|
|
{"jtag", mt7987_jtag_groups, ARRAY_SIZE(mt7987_jtag_groups)},
|
|
{"pcm", mt7987_pcm_groups, ARRAY_SIZE(mt7987_pcm_groups)},
|
|
{"uart", mt7987_uart_groups, ARRAY_SIZE(mt7987_uart_groups)},
|
|
{"pwm", mt7987_pwm_groups, ARRAY_SIZE(mt7987_pwm_groups)},
|
|
{"usb", mt7987_usb_groups, ARRAY_SIZE(mt7987_usb_groups)},
|
|
{"led", mt7987_led_groups, ARRAY_SIZE(mt7987_led_groups)},
|
|
{"eth", mt7987_ethernet_groups, ARRAY_SIZE(mt7987_ethernet_groups)},
|
|
{"spi", mt7987_spi_groups, ARRAY_SIZE(mt7987_spi_groups)},
|
|
{"flash", mt7987_flash_groups, ARRAY_SIZE(mt7987_flash_groups)},
|
|
{"i2c", mt7987_i2c_groups, ARRAY_SIZE(mt7987_i2c_groups)},
|
|
{"pcie", mt7987_pcie_groups, ARRAY_SIZE(mt7987_pcie_groups)},
|
|
};
|
|
|
|
static const char *const mt7987_pinctrl_register_base_names[] = {
|
|
"gpio", "iocfg_rb", "iocfg_lb", "iocfg_rt1", "iocfg_rt2", "iocfg_tl",
|
|
};
|
|
|
|
static const struct mtk_pinctrl_soc mt7987_data = {
|
|
.name = "mt7987_pinctrl",
|
|
.reg_cal = mt7987_reg_cals,
|
|
.pins = mt7987_pins,
|
|
.npins = ARRAY_SIZE(mt7987_pins),
|
|
.grps = mt7987_groups,
|
|
.ngrps = ARRAY_SIZE(mt7987_groups),
|
|
.funcs = mt7987_functions,
|
|
.nfuncs = ARRAY_SIZE(mt7987_functions),
|
|
.io_type = mt7987_io_type_desc,
|
|
.ntype = ARRAY_SIZE(mt7987_io_type_desc),
|
|
.gpio_mode = 0,
|
|
.base_names = mt7987_pinctrl_register_base_names,
|
|
.nbase_names = ARRAY_SIZE(mt7987_pinctrl_register_base_names),
|
|
.base_calc = 1,
|
|
};
|
|
|
|
static int mtk_pinctrl_mt7987_probe(struct udevice *dev)
|
|
{
|
|
return mtk_pinctrl_common_probe(dev, &mt7987_data);
|
|
}
|
|
|
|
static const struct udevice_id mt7987_pctrl_match[] = {
|
|
{.compatible = "mediatek,mt7987-pinctrl"},
|
|
{ /* sentinel */ }
|
|
};
|
|
|
|
U_BOOT_DRIVER(mt7987_pinctrl) = {
|
|
.name = "mt7987_pinctrl",
|
|
.id = UCLASS_PINCTRL,
|
|
.of_match = mt7987_pctrl_match,
|
|
.ops = &mtk_pinctrl_ops,
|
|
.bind = mtk_pinctrl_common_bind,
|
|
.probe = mtk_pinctrl_mt7987_probe,
|
|
.priv_auto = sizeof(struct mtk_pinctrl_priv),
|
|
};
|