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