// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (C) 2021 MediaTek Inc.
*
* Author: Guodong Liu <guodong.liu@mediatek.com>
*
*/
#include "pinctrl-mtk-mt8186.h"
#include "pinctrl-paris.h"
/* MT8186 have multiple bases to program pin configuration listed as the below:
* iocfg[0]:0x10005000, iocfg[1]:0x10002000, iocfg[2]:0x10002200,
* iocfg[3]:0x10002400, iocfg[4]:0x10002600, iocfg[5]:0x10002800,
* iocfg[6]:0x10002C00.
* _i_based could be used to indicate what base the pin should be mapped into.
*/
#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, 32, 0)
#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, 32, 1)
static const struct mtk_pin_field_calc mt8186_pin_mode_range[] = {
PIN_FIELD(0, 184, 0x300, 0x10, 0, 4),
};
static const struct mtk_pin_field_calc mt8186_pin_dir_range[] = {
PIN_FIELD(0, 184, 0x0, 0x10, 0, 1),
};
static const struct mtk_pin_field_calc mt8186_pin_di_range[] = {
PIN_FIELD(0, 184, 0x200, 0x10, 0, 1),
};
static const struct mtk_pin_field_calc mt8186_pin_do_range[] = {
PIN_FIELD(0, 184, 0x100, 0x10, 0, 1),
};
static const struct mtk_pin_field_calc mt8186_pin_ies_range[] = {
PIN_FIELD_BASE(0, 0, 6, 0x0030, 0x10, 13, 1),
PIN_FIELD_BASE(1, 1, 6, 0x0030, 0x10, 14, 1),
PIN_FIELD_BASE(2, 2, 6, 0x0030, 0x10, 17, 1),
PIN_FIELD_BASE(3, 3, 6, 0x0030, 0x10, 18, 1),
PIN_FIELD_BASE(4, 4, 6, 0x0030, 0x10, 19, 1),
PIN_FIELD_BASE(5, 5, 6, 0x0030, 0x10, 20, 1),
PIN_FIELD_BASE(6, 6, 4, 0x0020, 0x10, 19, 1),
PIN_FIELD_BASE(7, 7, 4, 0x0020, 0x10, 20, 1),
PIN_FIELD_BASE(8, 8, 4, 0x0020, 0x10, 21, 1),
PIN_FIELD_BASE(9, 9, 4, 0x0020, 0x10, 22, 1),
PIN_FIELD_BASE(10, 10, 4, 0x0020, 0x10, 16, 1),
PIN_FIELD_BASE(11, 11, 4, 0x0020, 0x10, 17, 1),
PIN_FIELD_BASE(12, 12, 4, 0x0020, 0x10, 18, 1),
PIN_FIELD_BASE(13, 13, 3, 0x0040, 0x10, 0, 1),
PIN_FIELD_BASE(14, 14, 3, 0x0040, 0x10, 1, 1),
PIN_FIELD_BASE(15, 15, 6, 0x0030, 0x10, 15, 1),
PIN_FIELD_BASE(16, 16, 6, 0x0030, 0x10, 16, 1),
PIN_FIELD_BASE(17, 17, 5, 0x0050, 0x10, 9, 1),
PIN_FIELD_BASE(18, 18, 5, 0x0050, 0x10, 10, 1),
PIN_FIELD_BASE(19, 19, 5, 0x0050, 0x10, 3, 1),
PIN_FIELD_BASE(20, 20, 5