162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (c) 2020 TOSHIBA CORPORATION
462306a36Sopenharmony_ci * Copyright (c) 2020 Toshiba Electronic Devices & Storage Corporation
562306a36Sopenharmony_ci * Copyright (c) 2020 Nobuhiro Iwamatsu <nobuhiro1.iwamatsu@toshiba.co.jp>
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifndef __VISCONTI_PINCTRL_COMMON_H__
962306a36Sopenharmony_ci#define __VISCONTI_PINCTRL_COMMON_H__
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_cistruct pinctrl_pin_desc;
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci/* PIN */
1462306a36Sopenharmony_ci#define VISCONTI_PINS(pins_name, ...)  \
1562306a36Sopenharmony_ci	static const unsigned int pins_name ## _pins[] = { __VA_ARGS__ }
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_cistruct visconti_desc_pin {
1862306a36Sopenharmony_ci	struct pinctrl_pin_desc pin;
1962306a36Sopenharmony_ci	unsigned int dsel_offset;
2062306a36Sopenharmony_ci	unsigned int dsel_shift;
2162306a36Sopenharmony_ci	unsigned int pude_offset;
2262306a36Sopenharmony_ci	unsigned int pudsel_offset;
2362306a36Sopenharmony_ci	unsigned int pud_shift;
2462306a36Sopenharmony_ci};
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci#define VISCONTI_PIN(_pin, dsel, d_sh, pude, pudsel, p_sh)	\
2762306a36Sopenharmony_ci{								\
2862306a36Sopenharmony_ci	.pin = _pin,						\
2962306a36Sopenharmony_ci	.dsel_offset = dsel,					\
3062306a36Sopenharmony_ci	.dsel_shift = d_sh,					\
3162306a36Sopenharmony_ci	.pude_offset = pude,					\
3262306a36Sopenharmony_ci	.pudsel_offset = pudsel,				\
3362306a36Sopenharmony_ci	.pud_shift = p_sh,					\
3462306a36Sopenharmony_ci}
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci/* Group */
3762306a36Sopenharmony_ci#define VISCONTI_GROUPS(groups_name, ...)	\
3862306a36Sopenharmony_ci	static const char * const groups_name ## _grps[] = { __VA_ARGS__ }
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_cistruct visconti_mux {
4162306a36Sopenharmony_ci	unsigned int offset;
4262306a36Sopenharmony_ci	unsigned int mask;
4362306a36Sopenharmony_ci	unsigned int val;
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_cistruct visconti_pin_group {
4762306a36Sopenharmony_ci	const char *name;
4862306a36Sopenharmony_ci	const unsigned int *pins;
4962306a36Sopenharmony_ci	unsigned int nr_pins;
5062306a36Sopenharmony_ci	struct visconti_mux mux;
5162306a36Sopenharmony_ci};
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci#define VISCONTI_PIN_GROUP(group_name, off, msk, v)	\
5462306a36Sopenharmony_ci{							\
5562306a36Sopenharmony_ci	.name = __stringify(group_name) "_grp",		\
5662306a36Sopenharmony_ci	.pins = group_name ## _pins,			\
5762306a36Sopenharmony_ci	.nr_pins = ARRAY_SIZE(group_name ## _pins),	\
5862306a36Sopenharmony_ci	.mux = {					\
5962306a36Sopenharmony_ci		.offset = off,				\
6062306a36Sopenharmony_ci		.mask = msk,				\
6162306a36Sopenharmony_ci		.val = v,				\
6262306a36Sopenharmony_ci	}						\
6362306a36Sopenharmony_ci}
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci/* MUX */
6662306a36Sopenharmony_cistruct visconti_pin_function {
6762306a36Sopenharmony_ci	const char *name;
6862306a36Sopenharmony_ci	const char * const *groups;
6962306a36Sopenharmony_ci	unsigned int nr_groups;
7062306a36Sopenharmony_ci};
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_ci#define VISCONTI_PIN_FUNCTION(func)		\
7362306a36Sopenharmony_ci{						\
7462306a36Sopenharmony_ci	.name = #func,				\
7562306a36Sopenharmony_ci	.groups = func ## _grps,		\
7662306a36Sopenharmony_ci	.nr_groups = ARRAY_SIZE(func ## _grps),	\
7762306a36Sopenharmony_ci}
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci/* chip dependent data */
8062306a36Sopenharmony_cistruct visconti_pinctrl_devdata {
8162306a36Sopenharmony_ci	const struct visconti_desc_pin *pins;
8262306a36Sopenharmony_ci	unsigned int nr_pins;
8362306a36Sopenharmony_ci	const struct visconti_pin_group *groups;
8462306a36Sopenharmony_ci	unsigned int nr_groups;
8562306a36Sopenharmony_ci	const struct visconti_pin_function *functions;
8662306a36Sopenharmony_ci	unsigned int nr_functions;
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci	const struct visconti_mux *gpio_mux;
8962306a36Sopenharmony_ci
9062306a36Sopenharmony_ci	void (*unlock)(void __iomem *base);
9162306a36Sopenharmony_ci};
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ciint visconti_pinctrl_probe(struct platform_device *pdev,
9462306a36Sopenharmony_ci			   const struct visconti_pinctrl_devdata *devdata);
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_ci#endif /* __VISCONTI_PINCTRL_COMMON_H__ */
97