18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Copyright (c) 2020 TOSHIBA CORPORATION
48c2ecf20Sopenharmony_ci * Copyright (c) 2020 Toshiba Electronic Devices & Storage Corporation
58c2ecf20Sopenharmony_ci * Copyright (c) 2020 Nobuhiro Iwamatsu <nobuhiro1.iwamatsu@toshiba.co.jp>
68c2ecf20Sopenharmony_ci */
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_ci#ifndef __VISCONTI_PINCTRL_COMMON_H__
98c2ecf20Sopenharmony_ci#define __VISCONTI_PINCTRL_COMMON_H__
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_cistruct pinctrl_pin_desc;
128c2ecf20Sopenharmony_ci
138c2ecf20Sopenharmony_ci/* PIN */
148c2ecf20Sopenharmony_ci#define VISCONTI_PINS(pins_name, ...)  \
158c2ecf20Sopenharmony_ci	static const unsigned int pins_name ## _pins[] = { __VA_ARGS__ }
168c2ecf20Sopenharmony_ci
178c2ecf20Sopenharmony_cistruct visconti_desc_pin {
188c2ecf20Sopenharmony_ci	struct pinctrl_pin_desc pin;
198c2ecf20Sopenharmony_ci	unsigned int dsel_offset;
208c2ecf20Sopenharmony_ci	unsigned int dsel_shift;
218c2ecf20Sopenharmony_ci	unsigned int pude_offset;
228c2ecf20Sopenharmony_ci	unsigned int pudsel_offset;
238c2ecf20Sopenharmony_ci	unsigned int pud_shift;
248c2ecf20Sopenharmony_ci};
258c2ecf20Sopenharmony_ci
268c2ecf20Sopenharmony_ci#define VISCONTI_PIN(_pin, dsel, d_sh, pude, pudsel, p_sh)	\
278c2ecf20Sopenharmony_ci{								\
288c2ecf20Sopenharmony_ci	.pin = _pin,						\
298c2ecf20Sopenharmony_ci	.dsel_offset = dsel,					\
308c2ecf20Sopenharmony_ci	.dsel_shift = d_sh,					\
318c2ecf20Sopenharmony_ci	.pude_offset = pude,					\
328c2ecf20Sopenharmony_ci	.pudsel_offset = pudsel,				\
338c2ecf20Sopenharmony_ci	.pud_shift = p_sh,					\
348c2ecf20Sopenharmony_ci}
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci/* Group */
378c2ecf20Sopenharmony_ci#define VISCONTI_GROUPS(groups_name, ...)	\
388c2ecf20Sopenharmony_ci	static const char * const groups_name ## _grps[] = { __VA_ARGS__ }
398c2ecf20Sopenharmony_ci
408c2ecf20Sopenharmony_cistruct visconti_mux {
418c2ecf20Sopenharmony_ci	unsigned int offset;
428c2ecf20Sopenharmony_ci	unsigned int mask;
438c2ecf20Sopenharmony_ci	unsigned int val;
448c2ecf20Sopenharmony_ci};
458c2ecf20Sopenharmony_ci
468c2ecf20Sopenharmony_cistruct visconti_pin_group {
478c2ecf20Sopenharmony_ci	const char *name;
488c2ecf20Sopenharmony_ci	const unsigned int *pins;
498c2ecf20Sopenharmony_ci	unsigned int nr_pins;
508c2ecf20Sopenharmony_ci	struct visconti_mux mux;
518c2ecf20Sopenharmony_ci};
528c2ecf20Sopenharmony_ci
538c2ecf20Sopenharmony_ci#define VISCONTI_PIN_GROUP(group_name, off, msk, v)	\
548c2ecf20Sopenharmony_ci{							\
558c2ecf20Sopenharmony_ci	.name = __stringify(group_name) "_grp",		\
568c2ecf20Sopenharmony_ci	.pins = group_name ## _pins,			\
578c2ecf20Sopenharmony_ci	.nr_pins = ARRAY_SIZE(group_name ## _pins),	\
588c2ecf20Sopenharmony_ci	.mux = {					\
598c2ecf20Sopenharmony_ci		.offset = off,				\
608c2ecf20Sopenharmony_ci		.mask = msk,				\
618c2ecf20Sopenharmony_ci		.val = v,				\
628c2ecf20Sopenharmony_ci	}						\
638c2ecf20Sopenharmony_ci}
648c2ecf20Sopenharmony_ci
658c2ecf20Sopenharmony_ci/* MUX */
668c2ecf20Sopenharmony_cistruct visconti_pin_function {
678c2ecf20Sopenharmony_ci	const char *name;
688c2ecf20Sopenharmony_ci	const char * const *groups;
698c2ecf20Sopenharmony_ci	unsigned int nr_groups;
708c2ecf20Sopenharmony_ci};
718c2ecf20Sopenharmony_ci
728c2ecf20Sopenharmony_ci#define VISCONTI_PIN_FUNCTION(func)		\
738c2ecf20Sopenharmony_ci{						\
748c2ecf20Sopenharmony_ci	.name = #func,				\
758c2ecf20Sopenharmony_ci	.groups = func ## _grps,		\
768c2ecf20Sopenharmony_ci	.nr_groups = ARRAY_SIZE(func ## _grps),	\
778c2ecf20Sopenharmony_ci}
788c2ecf20Sopenharmony_ci
798c2ecf20Sopenharmony_ci/* chip dependent data */
808c2ecf20Sopenharmony_cistruct visconti_pinctrl_devdata {
818c2ecf20Sopenharmony_ci	const struct visconti_desc_pin *pins;
828c2ecf20Sopenharmony_ci	unsigned int nr_pins;
838c2ecf20Sopenharmony_ci	const struct visconti_pin_group *groups;
848c2ecf20Sopenharmony_ci	unsigned int nr_groups;
858c2ecf20Sopenharmony_ci	const struct visconti_pin_function *functions;
868c2ecf20Sopenharmony_ci	unsigned int nr_functions;
878c2ecf20Sopenharmony_ci
888c2ecf20Sopenharmony_ci	const struct visconti_mux *gpio_mux;
898c2ecf20Sopenharmony_ci
908c2ecf20Sopenharmony_ci	void (*unlock)(void __iomem *base);
918c2ecf20Sopenharmony_ci};
928c2ecf20Sopenharmony_ci
938c2ecf20Sopenharmony_ciint visconti_pinctrl_probe(struct platform_device *pdev,
948c2ecf20Sopenharmony_ci			   const struct visconti_pinctrl_devdata *devdata);
958c2ecf20Sopenharmony_ci
968c2ecf20Sopenharmony_ci#endif /* __VISCONTI_PINCTRL_COMMON_H__ */
97