Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/drivers/pinctrl/mediatek/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 41 kB image not shown  

Quelle  pinctrl-mt6893.c

  Sprache: C
 

// SPDX-License-Identifier: GPL-2.0
/*
 * Copyright (C) 2019 MediaTek Inc.
 * Copyright (C) 2024 Collabora Ltd.
 *                    AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
 */


#include <linux/module.h>
#include "pinctrl-mtk-mt6893.h"
#include "pinctrl-paris.h"

#define PIN_FIELD_BASE(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits)  \
 PIN_FIELD_CALC(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits, \
  320)

#define PINS_FIELD_BASE(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits) \
 PIN_FIELD_CALC(s_pin, e_pin, i_base, s_addr, x_addrs, s_bit, x_bits, \
  321)

static const struct mtk_pin_field_calc mt6893_pin_mode_range[] = {
 PIN_FIELD(02190x0300, 0x10, 04),
};

static const struct mtk_pin_field_calc mt6893_pin_dir_range[] = {
 PIN_FIELD(02190x0000, 0x10, 01),
};

static const struct mtk_pin_field_calc mt6893_pin_di_range[] = {
 PIN_FIELD(02190x0200, 0x10, 01),
};

static const struct mtk_pin_field_calc mt6893_pin_do_range[] = {
 PIN_FIELD(02190x0100, 0x10, 01),
};

static const struct mtk_pin_field_calc mt6893_pin_smt_range[] = {
 PINS_FIELD_BASE(0920x00f0, 0x10, 71),
 PINS_FIELD_BASE(101510x0090, 0x10, 41),
 PIN_FIELD_BASE(161750x00c0, 0x10, 81),
 PINS_FIELD_BASE(182570x00f0, 0x10, 11),
 PINS_FIELD_BASE(263060x00e0, 0x10, 61),
 PINS_FIELD_BASE(313560x00e0, 0x10, 21),
 PIN_FIELD_BASE(363660x00e0, 0x10, 161),
 PINS_FIELD_BASE(373960x00e0, 0x10, 151),
 PIN_FIELD_BASE(404160x00e0, 0x10, 01),
 PIN_FIELD_BASE(424260x00e0, 0x10, 51),
 PIN_FIELD_BASE(434460x00e0, 0x10, 31),
 PIN_FIELD_BASE(454560x00e0, 0x10, 121),
 PIN_FIELD_BASE(464660x00e0, 0x10, 141),
 PIN_FIELD_BASE(474760x00e0, 0x10, 131),
 PIN_FIELD_BASE(484960x00e0, 0x10, 101),
 PIN_FIELD_BASE(505060x00e0, 0x10, 91),
 PIN_FIELD_BASE(515230x0090, 0x10, 61),
 PINS_FIELD_BASE(535630x0090, 0x10, 81),
 PIN_FIELD_BASE(576030x0090, 0x10, 21),
 PIN_FIELD_BASE(616130x0090, 0x10, 11),
 PIN_FIELD_BASE(626240x0050, 0x10, 11),
 PINS_FIELD_BASE(637330x0090, 0x10, 01),
 PINS_FIELD_BASE(748440x0050, 0x10, 01),
 PIN_FIELD_BASE(858640x0050, 0x10, 41),
 PIN_FIELD_BASE(878840x0050, 0x10, 21),
 PIN_FIELD_BASE(899020x00f0, 0x10, 261),
 PIN_FIELD_BASE(919120x00f0, 0x10, 01),
 PINS_FIELD_BASE(929520x0100, 0x10, 01),
 PIN_FIELD_BASE(969620x00f0, 0x10, 301),
 PIN_FIELD_BASE(979720x00f0, 0x10, 281),
 PIN_FIELD_BASE(989820x00f0, 0x10, 311),
 PINS_FIELD_BASE(9910220x00f0, 0x10, 291),
 PINS_FIELD_BASE(10310520x00f0, 0x10, 241),
 PIN_FIELD_BASE(10610620x00f0, 0x10, 251),
 PIN_FIELD_BASE(10710820x00f0, 0x10, 51),
 PINS_FIELD_BASE(10911320x00f0, 0x10, 81),
 PINS_FIELD_BASE(11411620x00f0, 0x10, 161),
 PIN_FIELD_BASE(11711720x00f0, 0x10, 171),
 PIN_FIELD_BASE(11811820x00f0, 0x10, 101),
 PIN_FIELD_BASE(11911920x00f0, 0x10, 181),
 PIN_FIELD_BASE(12012020x00f0, 0x10, 151),
 PIN_FIELD_BASE(12112120x00f0, 0x10, 231),
 PIN_FIELD_BASE(12212220x00f0, 0x10, 141),
 PIN_FIELD_BASE(12312320x00f0, 0x10, 221),
 PIN_FIELD_BASE(12412420x00f0, 0x10, 131),
 PIN_FIELD_BASE(12512520x00f0, 0x10, 211),
 PINS_FIELD_BASE(12612920x00f0, 0x10, 91),
 PINS_FIELD_BASE(13013520x00f0, 0x10, 41),
 PIN_FIELD_BASE(13613820x00f0, 0x10, 11),
 PIN_FIELD_BASE(13913920x00f0, 0x10, 121),
 PIN_FIELD_BASE(14014020x00f0, 0x10, 201),
 PIN_FIELD_BASE(14114120x00f0, 0x10, 111),
 PIN_FIELD_BASE(14214220x00f0, 0x10, 191),
 PINS_FIELD_BASE(14314810x0090, 0x10, 31),
 PIN_FIELD_BASE(14915110x0090, 0x10, 01),
 PINS_FIELD_BASE(15215550x00c0, 0x10, 101),
 PIN_FIELD_BASE(15615650x00c0, 0x10, 141),
 PINS_FIELD_BASE(15715950x00c0, 0x10, 131),
 PIN_FIELD_BASE(16016150x00c0, 0x10, 111),
 PINS_FIELD_BASE(16217150x00c0, 0x10, 01),
 PIN_FIELD_BASE(17217350x00c0, 0x10, 41),
 PIN_FIELD_BASE(17417450x00c0, 0x10, 31),
 PIN_FIELD_BASE(17517550x00c0, 0x10, 61),
 PIN_FIELD_BASE(17617750x00c0, 0x10, 11),
 PINS_FIELD_BASE(17818250x00c0, 0x10, 71),
 PIN_FIELD_BASE(18318370x00f0, 0x10, 31),
 PINS_FIELD_BASE(18419070x00f0, 0x10, 41),
 PIN_FIELD_BASE(19119170x00f0, 0x10, 51),
 PIN_FIELD_BASE(19219270x00f0, 0x10, 21),
 PIN_FIELD_BASE(19319370x00f0, 0x10, 41),
 PIN_FIELD_BASE(19419470x00f0, 0x10, 61),
 PIN_FIELD_BASE(19519570x00f0, 0x10, 121),
 PINS_FIELD_BASE(19619970x00f0, 0x10, 01),
 PIN_FIELD_BASE(20020070x00f0, 0x10, 111),
 PIN_FIELD_BASE(20120170x00f0, 0x10, 141),
 PIN_FIELD_BASE(20220270x00f0, 0x10, 101),
 PIN_FIELD_BASE(20320370x00f0, 0x10, 131),
 PIN_FIELD_BASE(20420560x00e0, 0x10, 71),
 PIN_FIELD_BASE(20620870x00f0, 0x10, 151),
 PINS_FIELD_BASE(20921170x00f0, 0x10, 71),
 PIN_FIELD_BASE(21221370x00f0, 0x10, 81),
 PINS_FIELD_BASE(21421970x00f0, 0x10, 01),
};

static const struct mtk_pin_field_calc mt6893_pin_ies_range[] = {
 PIN_FIELD_BASE(0920x0060, 0x10, 121),
 PIN_FIELD_BASE(101510x0020, 0x10, 91),
 PIN_FIELD_BASE(161750x0030, 0x10, 211),
 PIN_FIELD_BASE(182570x0050, 0x10, 101),
 PIN_FIELD_BASE(263060x0040, 0x10, 101),
 PIN_FIELD_BASE(313160x0040, 0x10, 61),
 PIN_FIELD_BASE(323260x0040, 0x10, 31),
 PIN_FIELD_BASE(333360x0040, 0x10, 51),
 PIN_FIELD_BASE(343460x0040, 0x10, 21),
 PIN_FIELD_BASE(353560x0040, 0x10, 41),
 PIN_FIELD_BASE(363960x0040, 0x10, 231),
 PIN_FIELD_BASE(404160x0040, 0x10, 01),
 PIN_FIELD_BASE(424260x0040, 0x10, 91),
 PIN_FIELD_BASE(434460x0040, 0x10, 71),
 PIN_FIELD_BASE(454560x0040, 0x10, 201),
 PIN_FIELD_BASE(464660x0040, 0x10, 221),
 PIN_FIELD_BASE(474760x0040, 0x10, 211),
 PIN_FIELD_BASE(484960x0040, 0x10, 181),
 PIN_FIELD_BASE(505060x0040, 0x10, 171),
 PIN_FIELD_BASE(515230x0020, 0x10, 161),
 PIN_FIELD_BASE(535330x0020, 0x10, 211),
 PIN_FIELD_BASE(545430x0020, 0x10, 181),
 PIN_FIELD_BASE(555530x0020, 0x10, 201),
 PIN_FIELD_BASE(565630x0020, 0x10, 191),
 PIN_FIELD_BASE(576030x0020, 0x10, 121),
 PIN_FIELD_BASE(616130x0020, 0x10, 111),
 PIN_FIELD_BASE(626240x0010, 0x10, 111),
 PIN_FIELD_BASE(636430x0020, 0x10, 01),
 PIN_FIELD_BASE(657230x0020, 0x10, 31),
 PIN_FIELD_BASE(737330x0020, 0x10, 21),
 PIN_FIELD_BASE(748440x0010, 0x10, 01),
 PIN_FIELD_BASE(858640x0010, 0x10, 141),
 PIN_FIELD_BASE(878840x0010, 0x10, 121),
 PIN_FIELD_BASE(899020x0070, 0x10, 191),
 PIN_FIELD_BASE(919120x0060, 0x10, 01),
 PIN_FIELD_BASE(929220x0070, 0x10, 281),
 PIN_FIELD_BASE(939320x0070, 0x10, 301),
 PIN_FIELD_BASE(949420x0070, 0x10, 291),
 PIN_FIELD_BASE(959520x0070, 0x10, 311),
 PIN_FIELD_BASE(969620x0070, 0x10, 261),
 PIN_FIELD_BASE(979720x0070, 0x10, 211),
 PIN_FIELD_BASE(989820x0070, 0x10, 271),
 PIN_FIELD_BASE(9910220x0070, 0x10, 221),
 PIN_FIELD_BASE(10310320x0070, 0x10, 171),
 PIN_FIELD_BASE(10410420x0070, 0x10, 161),
 PIN_FIELD_BASE(10510520x0070, 0x10, 181),
 PIN_FIELD_BASE(10610620x0070, 0x10, 151),
 PIN_FIELD_BASE(10710820x0060, 0x10, 101),
 PIN_FIELD_BASE(10910920x0060, 0x10, 251),
 PIN_FIELD_BASE(11011020x0060, 0x10, 221),
 PIN_FIELD_BASE(11111120x0060, 0x10, 241),
 PIN_FIELD_BASE(11211220x0060, 0x10, 261),
 PIN_FIELD_BASE(11311320x0060, 0x10, 231),
 PIN_FIELD_BASE(11411420x0070, 0x10, 71),
 PIN_FIELD_BASE(11511520x0070, 0x10, 61),
 PIN_FIELD_BASE(11611620x0070, 0x10, 81),
 PIN_FIELD_BASE(11711720x0070, 0x10, 51),
 PIN_FIELD_BASE(11811820x0060, 0x10, 311),
 PIN_FIELD_BASE(11911920x0070, 0x10, 91),
 PIN_FIELD_BASE(12012020x0070, 0x10, 41),
 PIN_FIELD_BASE(12112120x0070, 0x10, 141),
 PIN_FIELD_BASE(12212220x0070, 0x10, 31),
 PIN_FIELD_BASE(12312320x0070, 0x10, 131),
 PIN_FIELD_BASE(12412420x0070, 0x10, 21),
 PIN_FIELD_BASE(12512520x0070, 0x10, 121),
 PIN_FIELD_BASE(12612920x0060, 0x10, 271),
 PIN_FIELD_BASE(13013220x0060, 0x10, 71),
 PIN_FIELD_BASE(13313520x0060, 0x10, 41),
 PIN_FIELD_BASE(13613820x0060, 0x10, 11),
 PIN_FIELD_BASE(13913920x0070, 0x10, 11),
 PIN_FIELD_BASE(14014020x0070, 0x10, 111),
 PIN_FIELD_BASE(14114120x0070, 0x10, 01),
 PIN_FIELD_BASE(14214220x0070, 0x10, 101),
 PIN_FIELD_BASE(14314510x0020, 0x10, 61),
 PIN_FIELD_BASE(14614810x0020, 0x10, 31),
 PIN_FIELD_BASE(14915110x0020, 0x10, 01),
 PIN_FIELD_BASE(15215250x0030, 0x10, 261),
 PIN_FIELD_BASE(15315350x0030, 0x10, 251),
 PIN_FIELD_BASE(15415550x0030, 0x10, 231),
 PIN_FIELD_BASE(15615850x0030, 0x10, 291),
 PIN_FIELD_BASE(15915950x0040, 0x10, 01),
 PIN_FIELD_BASE(16016150x0030, 0x10, 271),
 PIN_FIELD_BASE(16217150x0030, 0x10, 01),
 PIN_FIELD_BASE(17217350x0030, 0x10, 131),
 PIN_FIELD_BASE(17417450x0030, 0x10, 121),
 PIN_FIELD_BASE(17517550x0030, 0x10, 151),
 PIN_FIELD_BASE(17617750x0030, 0x10, 101),
 PIN_FIELD_BASE(17818250x0030, 0x10, 161),
 PIN_FIELD_BASE(18318470x0050, 0x10, 191),
 PIN_FIELD_BASE(18518570x0050, 0x10, 221),
 PIN_FIELD_BASE(18618670x0050, 0x10, 241),
 PIN_FIELD_BASE(18718770x0050, 0x10, 261),
 PIN_FIELD_BASE(18818870x0050, 0x10, 211),
 PIN_FIELD_BASE(18918970x0050, 0x10, 251),
 PIN_FIELD_BASE(19019170x0050, 0x10, 271),
 PIN_FIELD_BASE(19219270x0050, 0x10, 181),
 PIN_FIELD_BASE(19319370x0050, 0x10, 231),
 PIN_FIELD_BASE(19419470x0050, 0x10, 291),
 PIN_FIELD_BASE(19519570x0060, 0x10, 51),
 PIN_FIELD_BASE(19619670x0050, 0x10, 61),
 PIN_FIELD_BASE(19719770x0050, 0x10, 81),
 PIN_FIELD_BASE(19819870x0050, 0x10, 71),
 PIN_FIELD_BASE(19919970x0050, 0x10, 31),
 PIN_FIELD_BASE(20020070x0060, 0x10, 41),
 PIN_FIELD_BASE(20120170x0060, 0x10, 71),
 PIN_FIELD_BASE(20220270x0060, 0x10, 31),
 PIN_FIELD_BASE(20320370x0060, 0x10, 61),
 PIN_FIELD_BASE(20420560x0040, 0x10, 151),
 PIN_FIELD_BASE(20620870x0060, 0x10, 81),
 PIN_FIELD_BASE(20920970x0060, 0x10, 01),
 PIN_FIELD_BASE(21021070x0050, 0x10, 311),
 PIN_FIELD_BASE(21121170x0060, 0x10, 11),
 PIN_FIELD_BASE(21221270x0050, 0x10, 301),
 PIN_FIELD_BASE(21321370x0060, 0x10, 21),
 PIN_FIELD_BASE(21421470x0050, 0x10, 01),
 PIN_FIELD_BASE(21521570x0050, 0x10, 91),
 PIN_FIELD_BASE(21621770x0050, 0x10, 41),
 PIN_FIELD_BASE(21821970x0050, 0x10, 11),
};

static const struct mtk_pin_field_calc mt6893_pin_pu_range[] = {
 PIN_FIELD_BASE(0920x00a0, 0x10, 121),
 PIN_FIELD_BASE(161750x0070, 0x10, 211),
 PIN_FIELD_BASE(182570x0090, 0x10, 101),
 PIN_FIELD_BASE(263060x0080, 0x10, 101),
 PIN_FIELD_BASE(313160x0080, 0x10, 61),
 PIN_FIELD_BASE(323260x0080, 0x10, 31),
 PIN_FIELD_BASE(333360x0080, 0x10, 51),
 PIN_FIELD_BASE(343460x0080, 0x10, 21),
 PIN_FIELD_BASE(353560x0080, 0x10, 41),
 PIN_FIELD_BASE(363960x0080, 0x10, 171),
 PIN_FIELD_BASE(404160x0080, 0x10, 01),
 PIN_FIELD_BASE(424260x0080, 0x10, 91),
 PIN_FIELD_BASE(434460x0080, 0x10, 71),
 PIN_FIELD_BASE(576030x0050, 0x10, 121),
 PIN_FIELD_BASE(616130x0050, 0x10, 111),
 PIN_FIELD_BASE(626240x0030, 0x10, 111),
 PIN_FIELD_BASE(636430x0050, 0x10, 01),
 PIN_FIELD_BASE(657230x0050, 0x10, 31),
 PIN_FIELD_BASE(737330x0050, 0x10, 21),
 PIN_FIELD_BASE(748440x0030, 0x10, 01),
 PIN_FIELD_BASE(858640x0030, 0x10, 141),
 PIN_FIELD_BASE(878840x0030, 0x10, 121),
 PIN_FIELD_BASE(899020x00b0, 0x10, 191),
 PIN_FIELD_BASE(919120x00a0, 0x10, 01),
 PIN_FIELD_BASE(929220x00b0, 0x10, 281),
 PIN_FIELD_BASE(939320x00b0, 0x10, 301),
 PIN_FIELD_BASE(949420x00b0, 0x10, 291),
 PIN_FIELD_BASE(959520x00b0, 0x10, 311),
 PIN_FIELD_BASE(969620x00b0, 0x10, 261),
 PIN_FIELD_BASE(979720x00b0, 0x10, 211),
 PIN_FIELD_BASE(989820x00b0, 0x10, 271),
 PIN_FIELD_BASE(9910220x00b0, 0x10, 221),
 PIN_FIELD_BASE(10310320x00b0, 0x10, 171),
 PIN_FIELD_BASE(10410420x00b0, 0x10, 161),
 PIN_FIELD_BASE(10510520x00b0, 0x10, 181),
 PIN_FIELD_BASE(10610620x00b0, 0x10, 151),
 PIN_FIELD_BASE(10710820x00a0, 0x10, 101),
 PIN_FIELD_BASE(10910920x00a0, 0x10, 251),
 PIN_FIELD_BASE(11011020x00a0, 0x10, 221),
 PIN_FIELD_BASE(11111120x00a0, 0x10, 241),
 PIN_FIELD_BASE(11211220x00a0, 0x10, 261),
 PIN_FIELD_BASE(11311320x00a0, 0x10, 231),
 PIN_FIELD_BASE(11411420x00b0, 0x10, 71),
 PIN_FIELD_BASE(11511520x00b0, 0x10, 61),
 PIN_FIELD_BASE(11611620x00b0, 0x10, 81),
 PIN_FIELD_BASE(11711720x00b0, 0x10, 51),
 PIN_FIELD_BASE(11811820x00a0, 0x10, 311),
 PIN_FIELD_BASE(11911920x00b0, 0x10, 91),
 PIN_FIELD_BASE(12012020x00b0, 0x10, 41),
 PIN_FIELD_BASE(12112120x00b0, 0x10, 141),
 PIN_FIELD_BASE(12212220x00b0, 0x10, 31),
 PIN_FIELD_BASE(12312320x00b0, 0x10, 131),
 PIN_FIELD_BASE(12412420x00b0, 0x10, 21),
 PIN_FIELD_BASE(12512520x00b0, 0x10, 121),
 PIN_FIELD_BASE(12612920x00a0, 0x10, 271),
 PIN_FIELD_BASE(13013220x00a0, 0x10, 71),
 PIN_FIELD_BASE(13313520x00a0, 0x10, 41),
 PIN_FIELD_BASE(13613820x00a0, 0x10, 11),
 PIN_FIELD_BASE(13913920x00b0, 0x10, 11),
 PIN_FIELD_BASE(14014020x00b0, 0x10, 111),
 PIN_FIELD_BASE(14114120x00b0, 0x10, 01),
 PIN_FIELD_BASE(14214220x00b0, 0x10, 101),
 PIN_FIELD_BASE(14314510x0050, 0x10, 61),
 PIN_FIELD_BASE(14614810x0050, 0x10, 31),
 PIN_FIELD_BASE(14915110x0050, 0x10, 01),
 PIN_FIELD_BASE(15615950x0070, 0x10, 251),
 PIN_FIELD_BASE(16016150x0070, 0x10, 231),
 PIN_FIELD_BASE(16217150x0070, 0x10, 01),
 PIN_FIELD_BASE(17217350x0070, 0x10, 131),
 PIN_FIELD_BASE(17417450x0070, 0x10, 121),
 PIN_FIELD_BASE(17517550x0070, 0x10, 151),
 PIN_FIELD_BASE(17617750x0070, 0x10, 101),
 PIN_FIELD_BASE(17818250x0070, 0x10, 161),
 PIN_FIELD_BASE(19519570x0090, 0x10, 251),
 PIN_FIELD_BASE(19619670x0090, 0x10, 61),
 PIN_FIELD_BASE(19719770x0090, 0x10, 81),
 PIN_FIELD_BASE(19819870x0090, 0x10, 71),
 PIN_FIELD_BASE(19919970x0090, 0x10, 31),
 PIN_FIELD_BASE(20020070x0090, 0x10, 241),
 PIN_FIELD_BASE(20120170x0090, 0x10, 271),
 PIN_FIELD_BASE(20220270x0090, 0x10, 231),
 PIN_FIELD_BASE(20320370x0090, 0x10, 261),
 PIN_FIELD_BASE(20420560x0080, 0x10, 151),
 PIN_FIELD_BASE(20620870x0090, 0x10, 281),
 PIN_FIELD_BASE(20920970x0090, 0x10, 201),
 PIN_FIELD_BASE(21021070x0090, 0x10, 191),
 PIN_FIELD_BASE(21121170x0090, 0x10, 211),
 PIN_FIELD_BASE(21221270x0090, 0x10, 181),
 PIN_FIELD_BASE(21321370x0090, 0x10, 221),
 PIN_FIELD_BASE(21421470x0090, 0x10, 01),
 PIN_FIELD_BASE(21521570x0090, 0x10, 91),
 PIN_FIELD_BASE(21621770x0090, 0x10, 41),
 PIN_FIELD_BASE(21821970x0090, 0x10, 11),
};

static const struct mtk_pin_field_calc mt6893_pin_pd_range[] = {
 PIN_FIELD_BASE(0920x0080, 0x10, 121),
 PIN_FIELD_BASE(161750x0050, 0x10, 211),
 PIN_FIELD_BASE(182570x0070, 0x10, 101),
 PIN_FIELD_BASE(263060x0060, 0x10, 101),
 PIN_FIELD_BASE(313160x0060, 0x10, 61),
 PIN_FIELD_BASE(323260x0060, 0x10, 31),
 PIN_FIELD_BASE(333360x0060, 0x10, 51),
 PIN_FIELD_BASE(343460x0060, 0x10, 21),
 PIN_FIELD_BASE(353560x0060, 0x10, 41),
 PIN_FIELD_BASE(363960x0060, 0x10, 171),
 PIN_FIELD_BASE(404160x0060, 0x10, 01),
 PIN_FIELD_BASE(424260x0060, 0x10, 91),
 PIN_FIELD_BASE(434460x0060, 0x10, 71),
 PIN_FIELD_BASE(576030x0030, 0x10, 121),
 PIN_FIELD_BASE(616130x0030, 0x10, 111),
 PIN_FIELD_BASE(626240x0020, 0x10, 111),
 PIN_FIELD_BASE(636430x0030, 0x10, 01),
 PIN_FIELD_BASE(657230x0030, 0x10, 31),
 PIN_FIELD_BASE(737330x0030, 0x10, 21),
 PIN_FIELD_BASE(748440x0020, 0x10, 01),
 PIN_FIELD_BASE(858640x0020, 0x10, 141),
 PIN_FIELD_BASE(878840x0020, 0x10, 121),
 PIN_FIELD_BASE(899020x0090, 0x10, 191),
 PIN_FIELD_BASE(919120x0080, 0x10, 01),
 PIN_FIELD_BASE(929220x0090, 0x10, 281),
 PIN_FIELD_BASE(939320x0090, 0x10, 301),
 PIN_FIELD_BASE(949420x0090, 0x10, 291),
 PIN_FIELD_BASE(959520x0090, 0x10, 311),
 PIN_FIELD_BASE(969620x0090, 0x10, 261),
 PIN_FIELD_BASE(979720x0090, 0x10, 211),
 PIN_FIELD_BASE(989820x0090, 0x10, 271),
 PIN_FIELD_BASE(9910220x0090, 0x10, 221),
 PIN_FIELD_BASE(10310320x0090, 0x10, 171),
 PIN_FIELD_BASE(10410420x0090, 0x10, 161),
 PIN_FIELD_BASE(10510520x0090, 0x10, 181),
 PIN_FIELD_BASE(10610620x0090, 0x10, 151),
 PIN_FIELD_BASE(10710820x0080, 0x10, 101),
 PIN_FIELD_BASE(10910920x0080, 0x10, 251),
 PIN_FIELD_BASE(11011020x0080, 0x10, 221),
 PIN_FIELD_BASE(11111120x0080, 0x10, 241),
 PIN_FIELD_BASE(11211220x0080, 0x10, 261),
 PIN_FIELD_BASE(11311320x0080, 0x10, 231),
 PIN_FIELD_BASE(11411420x0090, 0x10, 71),
 PIN_FIELD_BASE(11511520x0090, 0x10, 61),
 PIN_FIELD_BASE(11611620x0090, 0x10, 81),
 PIN_FIELD_BASE(11711720x0090, 0x10, 51),
 PIN_FIELD_BASE(11811820x0080, 0x10, 311),
 PIN_FIELD_BASE(11911920x0090, 0x10, 91),
 PIN_FIELD_BASE(12012020x0090, 0x10, 41),
 PIN_FIELD_BASE(12112120x0090, 0x10, 141),
 PIN_FIELD_BASE(12212220x0090, 0x10, 31),
 PIN_FIELD_BASE(12312320x0090, 0x10, 131),
 PIN_FIELD_BASE(12412420x0090, 0x10, 21),
 PIN_FIELD_BASE(12512520x0090, 0x10, 121),
 PIN_FIELD_BASE(12612920x0080, 0x10, 271),
 PIN_FIELD_BASE(13013220x0080, 0x10, 71),
 PIN_FIELD_BASE(13313520x0080, 0x10, 41),
 PIN_FIELD_BASE(13613820x0080, 0x10, 11),
 PIN_FIELD_BASE(13913920x0090, 0x10, 11),
 PIN_FIELD_BASE(14014020x0090, 0x10, 111),
 PIN_FIELD_BASE(14114120x0090, 0x10, 01),
 PIN_FIELD_BASE(14214220x0090, 0x10, 101),
 PIN_FIELD_BASE(14314510x0030, 0x10, 61),
 PIN_FIELD_BASE(14614810x0030, 0x10, 31),
 PIN_FIELD_BASE(14915110x0030, 0x10, 01),
 PIN_FIELD_BASE(15615950x0050, 0x10, 251),
 PIN_FIELD_BASE(16016150x0050, 0x10, 231),
 PIN_FIELD_BASE(16217150x0050, 0x10, 01),
 PIN_FIELD_BASE(17217350x0050, 0x10, 131),
 PIN_FIELD_BASE(17417450x0050, 0x10, 121),
 PIN_FIELD_BASE(17517550x0050, 0x10, 151),
 PIN_FIELD_BASE(17617750x0050, 0x10, 101),
 PIN_FIELD_BASE(17818250x0050, 0x10, 161),
 PIN_FIELD_BASE(19519570x0070, 0x10, 251),
 PIN_FIELD_BASE(19619670x0070, 0x10, 61),
 PIN_FIELD_BASE(19719770x0070, 0x10, 81),
 PIN_FIELD_BASE(19819870x0070, 0x10, 71),
 PIN_FIELD_BASE(19919970x0070, 0x10, 31),
 PIN_FIELD_BASE(20020070x0070, 0x10, 241),
 PIN_FIELD_BASE(20120170x0070, 0x10, 271),
 PIN_FIELD_BASE(20220270x0070, 0x10, 231),
 PIN_FIELD_BASE(20320370x0070, 0x10, 261),
 PIN_FIELD_BASE(20420560x0060, 0x10, 151),
 PIN_FIELD_BASE(20620870x0070, 0x10, 281),
 PIN_FIELD_BASE(20920970x0070, 0x10, 201),
 PIN_FIELD_BASE(21021070x0070, 0x10, 191),
 PIN_FIELD_BASE(21121170x0070, 0x10, 211),
 PIN_FIELD_BASE(21221270x0070, 0x10, 181),
 PIN_FIELD_BASE(21321370x0070, 0x10, 221),
 PIN_FIELD_BASE(21421470x0070, 0x10, 01),
 PIN_FIELD_BASE(21521570x0070, 0x10, 91),
 PIN_FIELD_BASE(21621770x0070, 0x10, 41),
 PIN_FIELD_BASE(21821970x0070, 0x10, 11),
};

static const struct mtk_pin_field_calc mt6893_pin_drv_range[] = {
 PINS_FIELD_BASE(0920x0000, 0x10, 213),
 PINS_FIELD_BASE(101510x0000, 0x10, 123),
 PIN_FIELD_BASE(161750x0000, 0x10, 183),
 PINS_FIELD_BASE(182570x0000, 0x10, 33),
 PINS_FIELD_BASE(263060x0000, 0x10, 153),
 PINS_FIELD_BASE(313560x0000, 0x10, 63),
 PIN_FIELD_BASE(363660x0010, 0x10, 73),
 PINS_FIELD_BASE(373960x0010, 0x10, 43),
 PIN_FIELD_BASE(404160x0000, 0x10, 03),
 PIN_FIELD_BASE(424260x0000, 0x10, 123),
 PINS_FIELD_BASE(434460x0000, 0x10, 93),
 PIN_FIELD_BASE(454560x0000, 0x10, 302),
 PIN_FIELD_BASE(464660x0010, 0x10, 22),
 PIN_FIELD_BASE(474760x0010, 0x10, 02),
 PIN_FIELD_BASE(484960x0000, 0x10, 262),
 PIN_FIELD_BASE(505060x0000, 0x10, 242),
 PIN_FIELD_BASE(515230x0000, 0x10, 183),
 PINS_FIELD_BASE(535630x0000, 0x10, 243),
 PIN_FIELD_BASE(576030x0000, 0x10, 63),
 PIN_FIELD_BASE(616130x0000, 0x10, 33),
 PIN_FIELD_BASE(626240x0000, 0x10, 33),
 PINS_FIELD_BASE(637330x0000, 0x10, 03),
 PINS_FIELD_BASE(748440x0000, 0x10, 03),
 PIN_FIELD_BASE(858640x0000, 0x10, 123),
 PIN_FIELD_BASE(878840x0000, 0x10, 63),
 PIN_FIELD_BASE(899020x0020, 0x10, 153),
 PIN_FIELD_BASE(919120x0000, 0x10, 03),
 PINS_FIELD_BASE(929520x0030, 0x10, 33),
 PIN_FIELD_BASE(969620x0020, 0x10, 273),
 PIN_FIELD_BASE(979720x0020, 0x10, 213),
 PIN_FIELD_BASE(989820x0030, 0x10, 03),
 PINS_FIELD_BASE(9910220x0020, 0x10, 243),
 PINS_FIELD_BASE(10310520x0020, 0x10, 93),
 PIN_FIELD_BASE(10610620x0020, 0x10, 123),
 PIN_FIELD_BASE(10710820x0000, 0x10, 153),
 PINS_FIELD_BASE(10911320x0000, 0x10, 243),
 PINS_FIELD_BASE(11411720x0010, 0x10, 183),
 PIN_FIELD_BASE(11811820x0010, 0x10, 03),
 PIN_FIELD_BASE(11911920x0010, 0x10, 213),
 PIN_FIELD_BASE(12012020x0010, 0x10, 153),
 PIN_FIELD_BASE(12112120x0020, 0x10, 63),
 PIN_FIELD_BASE(12212220x0010, 0x10, 123),
 PIN_FIELD_BASE(12312320x0020, 0x10, 33),
 PIN_FIELD_BASE(12412420x0010, 0x10, 93),
 PIN_FIELD_BASE(12512520x0020, 0x10, 03),
 PINS_FIELD_BASE(12612920x0000, 0x10, 273),
 PINS_FIELD_BASE(13013520x0000, 0x10, 123),
 PIN_FIELD_BASE(13613820x0000, 0x10, 33),
 PIN_FIELD_BASE(13913920x0010, 0x10, 63),
 PIN_FIELD_BASE(14014020x0010, 0x10, 273),
 PIN_FIELD_BASE(14114120x0010, 0x10, 33),
 PIN_FIELD_BASE(14214220x0010, 0x10, 243),
 PINS_FIELD_BASE(14314810x0000, 0x10, 93),
 PIN_FIELD_BASE(14915110x0000, 0x10, 03),
 PINS_FIELD_BASE(15215550x0000, 0x10, 243),
 PIN_FIELD_BASE(15615650x0010, 0x10, 63),
 PINS_FIELD_BASE(15715950x0010, 0x10, 33),
 PIN_FIELD_BASE(16016050x0000, 0x10, 273),
 PIN_FIELD_BASE(16116150x0010, 0x10, 03),
 PINS_FIELD_BASE(16217150x0000, 0x10, 03),
 PIN_FIELD_BASE(17217250x0000, 0x10, 153),
 PIN_FIELD_BASE(17317350x0000, 0x10, 33),
 PIN_FIELD_BASE(17417450x0000, 0x10, 123),
 PIN_FIELD_BASE(17517750x0000, 0x10, 33),
 PINS_FIELD_BASE(17818250x0000, 0x10, 33),
 PIN_FIELD_BASE(18318370x0000, 0x10, 93),
 PINS_FIELD_BASE(18419070x0000, 0x10, 123),
 PIN_FIELD_BASE(19119170x0000, 0x10, 153),
 PIN_FIELD_BASE(19219270x0000, 0x10, 63),
 PIN_FIELD_BASE(19319370x0000, 0x10, 123),
 PIN_FIELD_BASE(19419470x0000, 0x10, 183),
 PIN_FIELD_BASE(19519570x0010, 0x10, 33),
 PINS_FIELD_BASE(19619970x0000, 0x10, 03),
 PIN_FIELD_BASE(20020070x0010, 0x10, 03),
 PIN_FIELD_BASE(20120170x0010, 0x10, 93),
 PIN_FIELD_BASE(20220270x0000, 0x10, 273),
 PIN_FIELD_BASE(20320370x0010, 0x10, 63),
 PIN_FIELD_BASE(20420560x0000, 0x10, 183),
 PIN_FIELD_BASE(20620870x0010, 0x10, 123),
 PINS_FIELD_BASE(20921270x0000, 0x10, 213),
 PIN_FIELD_BASE(21321370x0000, 0x10, 243),
 PINS_FIELD_BASE(21421970x0000, 0x10, 03),
};

static const struct mtk_pin_field_calc mt6893_pin_pupd_range[] = {
 PIN_FIELD_BASE(101510x0040, 0x10, 01),
 PIN_FIELD_BASE(454560x0070, 0x10, 31),
 PIN_FIELD_BASE(464660x0070, 0x10, 51),
 PIN_FIELD_BASE(474760x0070, 0x10, 41),
 PIN_FIELD_BASE(484960x0070, 0x10, 11),
 PIN_FIELD_BASE(505060x0070, 0x10, 01),
 PIN_FIELD_BASE(515230x0040, 0x10, 01),
 PIN_FIELD_BASE(535330x0040, 0x10, 51),
 PIN_FIELD_BASE(545430x0040, 0x10, 21),
 PIN_FIELD_BASE(555530x0040, 0x10, 41),
 PIN_FIELD_BASE(565630x0040, 0x10, 31),
 PIN_FIELD_BASE(15215250x0060, 0x10, 31),
 PIN_FIELD_BASE(15315350x0060, 0x10, 21),
 PIN_FIELD_BASE(15415550x0060, 0x10, 01),
 PIN_FIELD_BASE(18318470x0080, 0x10, 11),
 PIN_FIELD_BASE(18518570x0080, 0x10, 41),
 PIN_FIELD_BASE(18618670x0080, 0x10, 61),
 PIN_FIELD_BASE(18718770x0080, 0x10, 81),
 PIN_FIELD_BASE(18818870x0080, 0x10, 31),
 PIN_FIELD_BASE(18918970x0080, 0x10, 71),
 PIN_FIELD_BASE(19019170x0080, 0x10, 91),
 PIN_FIELD_BASE(19219270x0080, 0x10, 01),
 PIN_FIELD_BASE(19319370x0080, 0x10, 51),
 PIN_FIELD_BASE(19419470x0080, 0x10, 111),
};

static const struct mtk_pin_field_calc mt6893_pin_r0_range[] = {
 PIN_FIELD_BASE(101510x0060, 0x10, 01),
 PIN_FIELD_BASE(242470x00e0, 0x10, 01),
 PIN_FIELD_BASE(252570x00e0, 0x10, 21),
 PIN_FIELD_BASE(454560x0090, 0x10, 31),
 PIN_FIELD_BASE(464660x0090, 0x10, 51),
 PIN_FIELD_BASE(474760x0090, 0x10, 41),
 PIN_FIELD_BASE(484960x0090, 0x10, 11),
 PIN_FIELD_BASE(505060x0090, 0x10, 01),
 PIN_FIELD_BASE(515230x0060, 0x10, 01),
 PIN_FIELD_BASE(535330x0060, 0x10, 51),
 PIN_FIELD_BASE(545430x0060, 0x10, 21),
 PIN_FIELD_BASE(555530x0060, 0x10, 41),
 PIN_FIELD_BASE(565630x0060, 0x10, 31),
 PIN_FIELD_BASE(11811820x00e0, 0x10, 01),
 PIN_FIELD_BASE(11911920x00e0, 0x10, 121),
 PIN_FIELD_BASE(12012020x00e0, 0x10, 101),
 PIN_FIELD_BASE(12112120x00e0, 0x10, 221),
 PIN_FIELD_BASE(12212220x00e0, 0x10, 81),
 PIN_FIELD_BASE(12312320x00e0, 0x10, 201),
 PIN_FIELD_BASE(12412420x00e0, 0x10, 61),
 PIN_FIELD_BASE(12512520x00e0, 0x10, 181),
 PIN_FIELD_BASE(13913920x00e0, 0x10, 41),
 PIN_FIELD_BASE(14014020x00e0, 0x10, 161),
 PIN_FIELD_BASE(14114120x00e0, 0x10, 21),
 PIN_FIELD_BASE(14214220x00e0, 0x10, 141),
 PIN_FIELD_BASE(15215250x0080, 0x10, 31),
 PIN_FIELD_BASE(15315350x0080, 0x10, 21),
 PIN_FIELD_BASE(15415550x0080, 0x10, 01),
 PIN_FIELD_BASE(16016050x00b0, 0x10, 01),
 PIN_FIELD_BASE(16116150x00b0, 0x10, 21),
 PIN_FIELD_BASE(18318470x00a0, 0x10, 11),
 PIN_FIELD_BASE(18518570x00a0, 0x10, 41),
 PIN_FIELD_BASE(18618670x00a0, 0x10, 61),
 PIN_FIELD_BASE(18718770x00a0, 0x10, 81),
 PIN_FIELD_BASE(18818870x00a0, 0x10, 31),
 PIN_FIELD_BASE(18918970x00a0, 0x10, 71),
 PIN_FIELD_BASE(19019170x00a0, 0x10, 91),
 PIN_FIELD_BASE(19219270x00a0, 0x10, 01),
 PIN_FIELD_BASE(19319370x00a0, 0x10, 51),
 PIN_FIELD_BASE(19419470x00a0, 0x10, 111),
 PIN_FIELD_BASE(20020070x00e0, 0x10, 61),
 PIN_FIELD_BASE(20120170x00e0, 0x10, 101),
 PIN_FIELD_BASE(20220270x00e0, 0x10, 41),
 PIN_FIELD_BASE(20320370x00e0, 0x10, 81),
 PIN_FIELD_BASE(20420460x00d0, 0x10, 01),
 PIN_FIELD_BASE(20520560x00d0, 0x10, 21),
};

static const struct mtk_pin_field_calc mt6893_pin_r1_range[] = {
 PIN_FIELD_BASE(101510x0070, 0x10, 01),
 PIN_FIELD_BASE(242470x00e0, 0x10, 11),
 PIN_FIELD_BASE(252570x00e0, 0x10, 31),
 PIN_FIELD_BASE(454560x00a0, 0x10, 31),
 PIN_FIELD_BASE(464660x00a0, 0x10, 51),
 PIN_FIELD_BASE(474760x00a0, 0x10, 41),
 PIN_FIELD_BASE(484960x00a0, 0x10, 11),
 PIN_FIELD_BASE(505060x00a0, 0x10, 01),
 PIN_FIELD_BASE(515230x0070, 0x10, 01),
 PIN_FIELD_BASE(535330x0070, 0x10, 51),
 PIN_FIELD_BASE(545430x0070, 0x10, 21),
 PIN_FIELD_BASE(555530x0070, 0x10, 41),
 PIN_FIELD_BASE(565630x0070, 0x10, 31),
 PIN_FIELD_BASE(11811820x00e0, 0x10, 11),
 PIN_FIELD_BASE(11911920x00e0, 0x10, 131),
 PIN_FIELD_BASE(12012020x00e0, 0x10, 111),
 PIN_FIELD_BASE(12112120x00e0, 0x10, 231),
 PIN_FIELD_BASE(12212220x00e0, 0x10, 91),
 PIN_FIELD_BASE(12312320x00e0, 0x10, 211),
 PIN_FIELD_BASE(12412420x00e0, 0x10, 71),
 PIN_FIELD_BASE(12512520x00e0, 0x10, 191),
 PIN_FIELD_BASE(13913920x00e0, 0x10, 51),
 PIN_FIELD_BASE(14014020x00e0, 0x10, 171),
 PIN_FIELD_BASE(14114120x00e0, 0x10, 31),
 PIN_FIELD_BASE(14214220x00e0, 0x10, 151),
 PIN_FIELD_BASE(15215250x0090, 0x10, 31),
 PIN_FIELD_BASE(15315350x0090, 0x10, 21),
 PIN_FIELD_BASE(15415550x0090, 0x10, 01),
 PIN_FIELD_BASE(16016050x00b0, 0x10, 11),
 PIN_FIELD_BASE(16116150x00b0, 0x10, 31),
 PIN_FIELD_BASE(18318470x00b0, 0x10, 11),
 PIN_FIELD_BASE(18518570x00b0, 0x10, 41),
 PIN_FIELD_BASE(18618670x00b0, 0x10, 61),
 PIN_FIELD_BASE(18718770x00b0, 0x10, 81),
 PIN_FIELD_BASE(18818870x00b0, 0x10, 31),
 PIN_FIELD_BASE(18918970x00b0, 0x10, 71),
 PIN_FIELD_BASE(19019170x00b0, 0x10, 91),
 PIN_FIELD_BASE(19219270x00b0, 0x10, 01),
 PIN_FIELD_BASE(19319370x00b0, 0x10, 51),
 PIN_FIELD_BASE(19419470x00b0, 0x10, 111),
 PIN_FIELD_BASE(20020070x00e0, 0x10, 71),
 PIN_FIELD_BASE(20120170x00e0, 0x10, 111),
 PIN_FIELD_BASE(20220270x00e0, 0x10, 51),
 PIN_FIELD_BASE(20320370x00e0, 0x10, 91),
 PIN_FIELD_BASE(20420460x00d0, 0x10, 11),
 PIN_FIELD_BASE(20520560x00d0, 0x10, 31),
};

static const struct mtk_pin_field_calc mt6893_pin_drv_adv_range[] = {
 PIN_FIELD_BASE(242470x0030, 0x10, 03),
 PIN_FIELD_BASE(252570x0030, 0x10, 33),
 PIN_FIELD_BASE(898920x0050, 0x10, 65),
 PIN_FIELD_BASE(909020x0050, 0x10, 115),
 PIN_FIELD_BASE(11811820x0040, 0x10, 03),
 PIN_FIELD_BASE(11911920x0040, 0x10, 183),
 PIN_FIELD_BASE(12012020x0040, 0x10, 153),
 PIN_FIELD_BASE(12112120x0050, 0x10, 33),
 PIN_FIELD_BASE(12212220x0040, 0x10, 123),
 PIN_FIELD_BASE(12312320x0050, 0x10, 03),
 PIN_FIELD_BASE(12412420x0040, 0x10, 93),
 PIN_FIELD_BASE(12512520x0040, 0x10, 273),
 PIN_FIELD_BASE(13913920x0040, 0x10, 63),
 PIN_FIELD_BASE(14014020x0040, 0x10, 243),
 PIN_FIELD_BASE(14114120x0040, 0x10, 33),
 PIN_FIELD_BASE(14214220x0040, 0x10, 213),
 PIN_FIELD_BASE(16016050x0020, 0x10, 03),
 PIN_FIELD_BASE(16116150x0020, 0x10, 33),
 PIN_FIELD_BASE(20020070x0030, 0x10, 93),
 PIN_FIELD_BASE(20120170x0030, 0x10, 153),
 PIN_FIELD_BASE(20220270x0030, 0x10, 63),
 PIN_FIELD_BASE(20320370x0030, 0x10, 123),
 PIN_FIELD_BASE(20420460x0020, 0x10, 03),
 PIN_FIELD_BASE(20520560x0020, 0x10, 33),
};

static const struct mtk_pin_field_calc mt6893_pin_rsel_range[] = {
 PIN_FIELD_BASE(242470x00e0, 0x10, 02),
 PIN_FIELD_BASE(252570x00e0, 0x10, 22),
 PIN_FIELD_BASE(11811820x00e0, 0x10, 02),
 PIN_FIELD_BASE(11911920x00e0, 0x10, 122),
 PIN_FIELD_BASE(12012020x00e0, 0x10, 102),
 PIN_FIELD_BASE(12112120x00e0, 0x10, 222),
 PIN_FIELD_BASE(12212220x00e0, 0x10, 82),
 PIN_FIELD_BASE(12312320x00e0, 0x10, 202),
 PIN_FIELD_BASE(12412420x00e0, 0x10, 62),
 PIN_FIELD_BASE(12512520x00e0, 0x10, 182),
 PIN_FIELD_BASE(13913920x00e0, 0x10, 42),
 PIN_FIELD_BASE(14014020x00e0, 0x10, 162),
 PIN_FIELD_BASE(14114120x00e0, 0x10, 22),
 PIN_FIELD_BASE(14214220x00e0, 0x10, 142),
 PIN_FIELD_BASE(16016050x00b0, 0x10, 02),
 PIN_FIELD_BASE(16116150x00b0, 0x10, 22),
 PIN_FIELD_BASE(20020070x00e0, 0x10, 62),
 PIN_FIELD_BASE(20120170x00e0, 0x10, 102),
 PIN_FIELD_BASE(20220270x00e0, 0x10, 42),
 PIN_FIELD_BASE(20320370x00e0, 0x10, 82),
 PIN_FIELD_BASE(20420460x00d0, 0x10, 02),
 PIN_FIELD_BASE(20520560x00d0, 0x10, 22),
};

static const unsigned int mt6893_pull_type[] = {
 MTK_PULL_PU_PD_TYPE, /* 0 */ MTK_PULL_PU_PD_TYPE, /* 1 */
 MTK_PULL_PU_PD_TYPE, /* 2 */ MTK_PULL_PU_PD_TYPE, /* 3 */
 MTK_PULL_PU_PD_TYPE, /* 4 */ MTK_PULL_PU_PD_TYPE, /* 5 */
 MTK_PULL_PU_PD_TYPE, /* 6 */ MTK_PULL_PU_PD_TYPE, /* 7 */
 MTK_PULL_PU_PD_TYPE, /* 8 */ MTK_PULL_PU_PD_TYPE, /* 9 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 10 */ MTK_PULL_PUPD_R1R0_TYPE, /* 11 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 12 */ MTK_PULL_PUPD_R1R0_TYPE, /* 13 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 14 */ MTK_PULL_PUPD_R1R0_TYPE, /* 15 */
 MTK_PULL_PU_PD_TYPE, /* 16 */ MTK_PULL_PU_PD_TYPE, /* 17 */
 MTK_PULL_PU_PD_TYPE, /* 18 */ MTK_PULL_PU_PD_TYPE, /* 19 */
 MTK_PULL_PU_PD_TYPE, /* 20 */ MTK_PULL_PU_PD_TYPE, /* 21 */
 MTK_PULL_PU_PD_TYPE, /* 22 */ MTK_PULL_PU_PD_TYPE, /* 23 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 24 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 25 */
 MTK_PULL_PU_PD_TYPE, /* 26 */ MTK_PULL_PU_PD_TYPE, /* 27 */
 MTK_PULL_PU_PD_TYPE, /* 28 */ MTK_PULL_PU_PD_TYPE, /* 29 */
 MTK_PULL_PU_PD_TYPE, /* 30 */ MTK_PULL_PU_PD_TYPE, /* 31 */
 MTK_PULL_PU_PD_TYPE, /* 32 */ MTK_PULL_PU_PD_TYPE, /* 33 */
 MTK_PULL_PU_PD_TYPE, /* 34 */ MTK_PULL_PU_PD_TYPE, /* 35 */
 MTK_PULL_PU_PD_TYPE, /* 36 */ MTK_PULL_PU_PD_TYPE, /* 37 */
 MTK_PULL_PU_PD_TYPE, /* 38 */ MTK_PULL_PU_PD_TYPE, /* 39 */
 MTK_PULL_PU_PD_TYPE, /* 40 */ MTK_PULL_PU_PD_TYPE, /* 41 */
 MTK_PULL_PU_PD_TYPE, /* 42 */ MTK_PULL_PU_PD_TYPE, /* 43 */
 MTK_PULL_PU_PD_TYPE, /* 44 */ MTK_PULL_PUPD_R1R0_TYPE, /* 45 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 46 */ MTK_PULL_PUPD_R1R0_TYPE, /* 47 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 48 */ MTK_PULL_PUPD_R1R0_TYPE, /* 49 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 50 */ MTK_PULL_PUPD_R1R0_TYPE, /* 51 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 52 */ MTK_PULL_PUPD_R1R0_TYPE, /* 53 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 54 */ MTK_PULL_PUPD_R1R0_TYPE, /* 55 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 56 */ MTK_PULL_PU_PD_TYPE, /* 57 */
 MTK_PULL_PU_PD_TYPE, /* 58 */ MTK_PULL_PU_PD_TYPE, /* 59 */
 MTK_PULL_PU_PD_TYPE, /* 60 */ MTK_PULL_PU_PD_TYPE, /* 61 */
 MTK_PULL_PU_PD_TYPE, /* 62 */ MTK_PULL_PU_PD_TYPE, /* 63 */
 MTK_PULL_PU_PD_TYPE, /* 64 */ MTK_PULL_PU_PD_TYPE, /* 65 */
 MTK_PULL_PU_PD_TYPE, /* 66 */ MTK_PULL_PU_PD_TYPE, /* 67 */
 MTK_PULL_PU_PD_TYPE, /* 68 */ MTK_PULL_PU_PD_TYPE, /* 69 */
 MTK_PULL_PU_PD_TYPE, /* 70 */ MTK_PULL_PU_PD_TYPE, /* 71 */
 MTK_PULL_PU_PD_TYPE, /* 72 */ MTK_PULL_PU_PD_TYPE, /* 73 */
 MTK_PULL_PU_PD_TYPE, /* 74 */ MTK_PULL_PU_PD_TYPE, /* 75 */
 MTK_PULL_PU_PD_TYPE, /* 76 */ MTK_PULL_PU_PD_TYPE, /* 77 */
 MTK_PULL_PU_PD_TYPE, /* 78 */ MTK_PULL_PU_PD_TYPE, /* 79 */
 MTK_PULL_PU_PD_TYPE, /* 80 */ MTK_PULL_PU_PD_TYPE, /* 81 */
 MTK_PULL_PU_PD_TYPE, /* 82 */ MTK_PULL_PU_PD_TYPE, /* 83 */
 MTK_PULL_PU_PD_TYPE, /* 84 */ MTK_PULL_PU_PD_TYPE, /* 85 */
 MTK_PULL_PU_PD_TYPE, /* 86 */ MTK_PULL_PU_PD_TYPE, /* 87 */
 MTK_PULL_PU_PD_TYPE, /* 88 */ MTK_PULL_PU_PD_TYPE, /* 89 */
 MTK_PULL_PU_PD_TYPE, /* 90 */ MTK_PULL_PU_PD_TYPE, /* 91 */
 MTK_PULL_PU_PD_TYPE, /* 92 */ MTK_PULL_PU_PD_TYPE, /* 93 */
 MTK_PULL_PU_PD_TYPE, /* 94 */ MTK_PULL_PU_PD_TYPE, /* 95 */
 MTK_PULL_PU_PD_TYPE, /* 96 */ MTK_PULL_PU_PD_TYPE, /* 97 */
 MTK_PULL_PU_PD_TYPE, /* 98 */ MTK_PULL_PU_PD_TYPE, /* 99 */
 MTK_PULL_PU_PD_TYPE, /* 100 */ MTK_PULL_PU_PD_TYPE, /* 101 */
 MTK_PULL_PU_PD_TYPE, /* 102 */ MTK_PULL_PU_PD_TYPE, /* 103 */
 MTK_PULL_PU_PD_TYPE, /* 104 */ MTK_PULL_PU_PD_TYPE, /* 105 */
 MTK_PULL_PU_PD_TYPE, /* 106 */ MTK_PULL_PU_PD_TYPE, /* 107 */
 MTK_PULL_PU_PD_TYPE, /* 108 */ MTK_PULL_PU_PD_TYPE, /* 109 */
 MTK_PULL_PU_PD_TYPE, /* 110 */ MTK_PULL_PU_PD_TYPE, /* 111 */
 MTK_PULL_PU_PD_TYPE, /* 112 */ MTK_PULL_PU_PD_TYPE, /* 113 */
 MTK_PULL_PU_PD_TYPE, /* 114 */ MTK_PULL_PU_PD_TYPE, /* 115 */
 MTK_PULL_PU_PD_TYPE, /* 116 */ MTK_PULL_PU_PD_TYPE, /* 117 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 118 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 119 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 120 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 121 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 122 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 123 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 124 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 125 */
 MTK_PULL_PU_PD_TYPE, /* 126 */ MTK_PULL_PU_PD_TYPE, /* 127 */
 MTK_PULL_PU_PD_TYPE, /* 128 */ MTK_PULL_PU_PD_TYPE, /* 129 */
 MTK_PULL_PU_PD_TYPE, /* 130 */ MTK_PULL_PU_PD_TYPE, /* 131 */
 MTK_PULL_PU_PD_TYPE, /* 132 */ MTK_PULL_PU_PD_TYPE, /* 133 */
 MTK_PULL_PU_PD_TYPE, /* 134 */ MTK_PULL_PU_PD_TYPE, /* 135 */
 MTK_PULL_PU_PD_TYPE, /* 136 */ MTK_PULL_PU_PD_TYPE, /* 137 */
 MTK_PULL_PU_PD_TYPE, /* 138 */ MTK_PULL_PU_PD_TYPE, /* 139 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 140 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 141 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 142 */ MTK_PULL_PU_PD_TYPE, /* 143 */
 MTK_PULL_PU_PD_TYPE, /* 144 */ MTK_PULL_PU_PD_TYPE, /* 145 */
 MTK_PULL_PU_PD_TYPE, /* 146 */ MTK_PULL_PU_PD_TYPE, /* 147 */
 MTK_PULL_PU_PD_TYPE, /* 148 */ MTK_PULL_PU_PD_TYPE, /* 149 */
 MTK_PULL_PU_PD_TYPE, /* 150 */ MTK_PULL_PU_PD_TYPE, /* 151 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 152 */ MTK_PULL_PUPD_R1R0_TYPE, /* 153 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 154 */ MTK_PULL_PUPD_R1R0_TYPE, /* 155 */
 MTK_PULL_PU_PD_TYPE, /* 156 */ MTK_PULL_PU_PD_TYPE, /* 157 */
 MTK_PULL_PU_PD_TYPE, /* 158 */ MTK_PULL_PU_PD_TYPE, /* 159 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 160 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 161 */
 MTK_PULL_PU_PD_TYPE, /* 162 */ MTK_PULL_PU_PD_TYPE, /* 163 */
 MTK_PULL_PU_PD_TYPE, /* 164 */ MTK_PULL_PU_PD_TYPE, /* 165 */
 MTK_PULL_PU_PD_TYPE, /* 166 */ MTK_PULL_PU_PD_TYPE, /* 167 */
 MTK_PULL_PU_PD_TYPE, /* 168 */ MTK_PULL_PU_PD_TYPE, /* 169 */
 MTK_PULL_PU_PD_TYPE, /* 170 */ MTK_PULL_PU_PD_TYPE, /* 171 */
 MTK_PULL_PU_PD_TYPE, /* 172 */ MTK_PULL_PU_PD_TYPE, /* 173 */
 MTK_PULL_PU_PD_TYPE, /* 174 */ MTK_PULL_PU_PD_TYPE, /* 175 */
 MTK_PULL_PU_PD_TYPE, /* 176 */ MTK_PULL_PU_PD_TYPE, /* 177 */
 MTK_PULL_PU_PD_TYPE, /* 178 */ MTK_PULL_PU_PD_TYPE, /* 179 */
 MTK_PULL_PU_PD_TYPE, /* 180 */ MTK_PULL_PU_PD_TYPE, /* 181 */
 MTK_PULL_PU_PD_TYPE, /* 182 */ MTK_PULL_PUPD_R1R0_TYPE, /* 183 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 184 */ MTK_PULL_PUPD_R1R0_TYPE, /* 185 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 186 */ MTK_PULL_PUPD_R1R0_TYPE, /* 187 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 188 */ MTK_PULL_PUPD_R1R0_TYPE, /* 189 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 190 */ MTK_PULL_PUPD_R1R0_TYPE, /* 191 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 192 */ MTK_PULL_PUPD_R1R0_TYPE, /* 193 */
 MTK_PULL_PUPD_R1R0_TYPE, /* 194 */ MTK_PULL_PU_PD_TYPE, /* 195 */
 MTK_PULL_PU_PD_TYPE, /* 196 */ MTK_PULL_PU_PD_TYPE, /* 197 */
 MTK_PULL_PU_PD_TYPE, /* 198 */ MTK_PULL_PU_PD_TYPE, /* 199 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 200 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 201 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 202 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 203 */
 MTK_PULL_PU_PD_RSEL_TYPE, /* 204 */ MTK_PULL_PU_PD_RSEL_TYPE, /* 205 */
 MTK_PULL_PU_PD_TYPE, /* 206 */ MTK_PULL_PU_PD_TYPE, /* 207 */
 MTK_PULL_PU_PD_TYPE, /* 208 */ MTK_PULL_PU_PD_TYPE, /* 209 */
 MTK_PULL_PU_PD_TYPE, /* 210 */ MTK_PULL_PU_PD_TYPE, /* 211 */
 MTK_PULL_PU_PD_TYPE, /* 212 */ MTK_PULL_PU_PD_TYPE, /* 213 */
 MTK_PULL_PU_PD_TYPE, /* 214 */ MTK_PULL_PU_PD_TYPE, /* 215 */
 MTK_PULL_PU_PD_TYPE, /* 216 */ MTK_PULL_PU_PD_TYPE, /* 217 */
 MTK_PULL_PU_PD_TYPE, /* 218 */ MTK_PULL_PU_PD_TYPE, /* 219 */
};

static const char * const mt6893_pinctrl_register_base_name[] = {
 "base""rm""bm""bl""br""lm""lb""rt""lt""tl",
};

static const struct mtk_pin_reg_calc mt6893_reg_cals[PINCTRL_PIN_REG_MAX] = {
 [PINCTRL_PIN_REG_MODE] = MTK_RANGE(mt6893_pin_mode_range),
 [PINCTRL_PIN_REG_DIR] = MTK_RANGE(mt6893_pin_dir_range),
 [PINCTRL_PIN_REG_DI] = MTK_RANGE(mt6893_pin_di_range),
 [PINCTRL_PIN_REG_DO] = MTK_RANGE(mt6893_pin_do_range),
 [PINCTRL_PIN_REG_SR] = MTK_RANGE(mt6893_pin_dir_range),
 [PINCTRL_PIN_REG_SMT] = MTK_RANGE(mt6893_pin_smt_range),
 [PINCTRL_PIN_REG_IES] = MTK_RANGE(mt6893_pin_ies_range),
 [PINCTRL_PIN_REG_PU] = MTK_RANGE(mt6893_pin_pu_range),
 [PINCTRL_PIN_REG_PD] = MTK_RANGE(mt6893_pin_pd_range),
 [PINCTRL_PIN_REG_DRV] = MTK_RANGE(mt6893_pin_drv_range),
 [PINCTRL_PIN_REG_PUPD] = MTK_RANGE(mt6893_pin_pupd_range),
 [PINCTRL_PIN_REG_R0] = MTK_RANGE(mt6893_pin_r0_range),
 [PINCTRL_PIN_REG_R1] = MTK_RANGE(mt6893_pin_r1_range),
 [PINCTRL_PIN_REG_DRV_ADV] = MTK_RANGE(mt6893_pin_drv_adv_range),
 [PINCTRL_PIN_REG_RSEL] = MTK_RANGE(mt6893_pin_rsel_range),
};

static const struct mtk_eint_hw mt6893_eint_hw = {
 .port_mask = 7,
 .ports     = 7,
 .ap_num    = 224,
 .db_cnt    = 32,
 .db_time   = debounce_time_mt6765,
};

static const struct mtk_pin_soc mt6893_data = {
 .reg_cal = mt6893_reg_cals,
 .pins = mtk_pins_mt6893,
 .npins = ARRAY_SIZE(mtk_pins_mt6893),
 .ngrps = ARRAY_SIZE(mtk_pins_mt6893),
 .eint_hw = &mt6893_eint_hw,
 .nfuncs = 8,
 .gpio_m = 0,
 .base_names = mt6893_pinctrl_register_base_name,
 .nbase_names = ARRAY_SIZE(mt6893_pinctrl_register_base_name),
 .pull_type = mt6893_pull_type,
 .bias_set_combo = mtk_pinconf_bias_set_combo,
 .bias_get_combo = mtk_pinconf_bias_get_combo,
 .drive_set = mtk_pinconf_drive_set_rev1,
 .drive_get = mtk_pinconf_drive_get_rev1,
 .adv_drive_set = mtk_pinconf_adv_drive_set_raw,
 .adv_drive_get = mtk_pinconf_adv_drive_get_raw,
};

static const struct of_device_id mt6893_pinctrl_of_match[] = {
 { .compatible = "mediatek,mt6893-pinctrl", .data = &mt6893_data },
 { /* sentinel */ }
};

static struct platform_driver mt6893_pinctrl_driver = {
 .driver = {
  .name = "mt6893-pinctrl",
  .of_match_table = mt6893_pinctrl_of_match,
  .pm = pm_sleep_ptr(&mtk_paris_pinctrl_pm_ops)
 },
 .probe = mtk_paris_pinctrl_probe,
};

static int __init mt6893_pinctrl_init(void)
{
 return platform_driver_register(&mt6893_pinctrl_driver);
}

arch_initcall(mt6893_pinctrl_init);

MODULE_DESCRIPTION("MediaTek MT6893 Pinctrl Driver");

Messung V0.5 in Prozent
C=95 H=97 G=95

¤ Dauer der Verarbeitung: 0.19 Sekunden  (vorverarbeitet am  2026-06-08) ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.