1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0+
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun * Pinctrl data for the NVIDIA Tegra194 pinmux
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * Copyright (c) 2019, NVIDIA CORPORATION. All rights reserved.
6*4882a593Smuzhiyun *
7*4882a593Smuzhiyun * This program is free software; you can redistribute it and/or modify it
8*4882a593Smuzhiyun * under the terms and conditions of the GNU General Public License,
9*4882a593Smuzhiyun * version 2, as published by the Free Software Foundation.
10*4882a593Smuzhiyun *
11*4882a593Smuzhiyun * This program is distributed in the hope it will be useful, but WITHOUT
12*4882a593Smuzhiyun * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14*4882a593Smuzhiyun * more details.
15*4882a593Smuzhiyun */
16*4882a593Smuzhiyun
17*4882a593Smuzhiyun #include <linux/init.h>
18*4882a593Smuzhiyun #include <linux/of.h>
19*4882a593Smuzhiyun #include <linux/platform_device.h>
20*4882a593Smuzhiyun #include <linux/pinctrl/pinctrl.h>
21*4882a593Smuzhiyun #include <linux/pinctrl/pinmux.h>
22*4882a593Smuzhiyun
23*4882a593Smuzhiyun #include "pinctrl-tegra.h"
24*4882a593Smuzhiyun
25*4882a593Smuzhiyun /* Define unique ID for each pins */
26*4882a593Smuzhiyun enum pin_id {
27*4882a593Smuzhiyun TEGRA_PIN_PEX_L5_CLKREQ_N_PGG0,
28*4882a593Smuzhiyun TEGRA_PIN_PEX_L5_RST_N_PGG1,
29*4882a593Smuzhiyun };
30*4882a593Smuzhiyun
31*4882a593Smuzhiyun /* Table for pin descriptor */
32*4882a593Smuzhiyun static const struct pinctrl_pin_desc tegra194_pins[] = {
33*4882a593Smuzhiyun PINCTRL_PIN(TEGRA_PIN_PEX_L5_CLKREQ_N_PGG0, "PEX_L5_CLKREQ_N_PGG0"),
34*4882a593Smuzhiyun PINCTRL_PIN(TEGRA_PIN_PEX_L5_RST_N_PGG1, "PEX_L5_RST_N_PGG1"),
35*4882a593Smuzhiyun };
36*4882a593Smuzhiyun
37*4882a593Smuzhiyun static const unsigned int pex_l5_clkreq_n_pgg0_pins[] = {
38*4882a593Smuzhiyun TEGRA_PIN_PEX_L5_CLKREQ_N_PGG0,
39*4882a593Smuzhiyun };
40*4882a593Smuzhiyun
41*4882a593Smuzhiyun static const unsigned int pex_l5_rst_n_pgg1_pins[] = {
42*4882a593Smuzhiyun TEGRA_PIN_PEX_L5_RST_N_PGG1,
43*4882a593Smuzhiyun };
44*4882a593Smuzhiyun
45*4882a593Smuzhiyun /* Define unique ID for each function */
46*4882a593Smuzhiyun enum tegra_mux_dt {
47*4882a593Smuzhiyun TEGRA_MUX_RSVD0,
48*4882a593Smuzhiyun TEGRA_MUX_RSVD1,
49*4882a593Smuzhiyun TEGRA_MUX_RSVD2,
50*4882a593Smuzhiyun TEGRA_MUX_RSVD3,
51*4882a593Smuzhiyun TEGRA_MUX_PE5,
52*4882a593Smuzhiyun };
53*4882a593Smuzhiyun
54*4882a593Smuzhiyun /* Make list of each function name */
55*4882a593Smuzhiyun #define TEGRA_PIN_FUNCTION(lid) \
56*4882a593Smuzhiyun { \
57*4882a593Smuzhiyun .name = #lid, \
58*4882a593Smuzhiyun }
59*4882a593Smuzhiyun
60*4882a593Smuzhiyun static struct tegra_function tegra194_functions[] = {
61*4882a593Smuzhiyun TEGRA_PIN_FUNCTION(rsvd0),
62*4882a593Smuzhiyun TEGRA_PIN_FUNCTION(rsvd1),
63*4882a593Smuzhiyun TEGRA_PIN_FUNCTION(rsvd2),
64*4882a593Smuzhiyun TEGRA_PIN_FUNCTION(rsvd3),
65*4882a593Smuzhiyun TEGRA_PIN_FUNCTION(pe5),
66*4882a593Smuzhiyun };
67*4882a593Smuzhiyun
68*4882a593Smuzhiyun #define DRV_PINGROUP_ENTRY_Y(r, drvdn_b, drvdn_w, drvup_b, \
69*4882a593Smuzhiyun drvup_w, slwr_b, slwr_w, slwf_b, \
70*4882a593Smuzhiyun slwf_w, bank) \
71*4882a593Smuzhiyun .drv_reg = ((r)), \
72*4882a593Smuzhiyun .drv_bank = bank, \
73*4882a593Smuzhiyun .drvdn_bit = drvdn_b, \
74*4882a593Smuzhiyun .drvdn_width = drvdn_w, \
75*4882a593Smuzhiyun .drvup_bit = drvup_b, \
76*4882a593Smuzhiyun .drvup_width = drvup_w, \
77*4882a593Smuzhiyun .slwr_bit = slwr_b, \
78*4882a593Smuzhiyun .slwr_width = slwr_w, \
79*4882a593Smuzhiyun .slwf_bit = slwf_b, \
80*4882a593Smuzhiyun .slwf_width = slwf_w
81*4882a593Smuzhiyun
82*4882a593Smuzhiyun #define PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_lpbk, e_input, \
83*4882a593Smuzhiyun e_od, schmitt_b, drvtype) \
84*4882a593Smuzhiyun .mux_reg = ((r)), \
85*4882a593Smuzhiyun .lpmd_bit = -1, \
86*4882a593Smuzhiyun .lock_bit = -1, \
87*4882a593Smuzhiyun .hsm_bit = -1, \
88*4882a593Smuzhiyun .mux_bank = bank, \
89*4882a593Smuzhiyun .mux_bit = 0, \
90*4882a593Smuzhiyun .pupd_reg = ((r)), \
91*4882a593Smuzhiyun .pupd_bank = bank, \
92*4882a593Smuzhiyun .pupd_bit = 2, \
93*4882a593Smuzhiyun .tri_reg = ((r)), \
94*4882a593Smuzhiyun .tri_bank = bank, \
95*4882a593Smuzhiyun .tri_bit = 4, \
96*4882a593Smuzhiyun .einput_bit = e_input, \
97*4882a593Smuzhiyun .odrain_bit = e_od, \
98*4882a593Smuzhiyun .sfsel_bit = 10, \
99*4882a593Smuzhiyun .schmitt_bit = schmitt_b, \
100*4882a593Smuzhiyun .drvtype_bit = 13, \
101*4882a593Smuzhiyun .parked_bitmask = 0
102*4882a593Smuzhiyun
103*4882a593Smuzhiyun #define drive_pex_l5_clkreq_n_pgg0 \
104*4882a593Smuzhiyun DRV_PINGROUP_ENTRY_Y(0x14004, 12, 5, 20, 5, -1, -1, -1, -1, 0)
105*4882a593Smuzhiyun #define drive_pex_l5_rst_n_pgg1 \
106*4882a593Smuzhiyun DRV_PINGROUP_ENTRY_Y(0x1400c, 12, 5, 20, 5, -1, -1, -1, -1, 0)
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun #define PINGROUP(pg_name, f0, f1, f2, f3, r, bank, pupd, e_lpbk, \
109*4882a593Smuzhiyun e_input, e_lpdr, e_od, schmitt_b, drvtype, io_rail) \
110*4882a593Smuzhiyun { \
111*4882a593Smuzhiyun .name = #pg_name, \
112*4882a593Smuzhiyun .pins = pg_name##_pins, \
113*4882a593Smuzhiyun .npins = ARRAY_SIZE(pg_name##_pins), \
114*4882a593Smuzhiyun .funcs = { \
115*4882a593Smuzhiyun TEGRA_MUX_##f0, \
116*4882a593Smuzhiyun TEGRA_MUX_##f1, \
117*4882a593Smuzhiyun TEGRA_MUX_##f2, \
118*4882a593Smuzhiyun TEGRA_MUX_##f3, \
119*4882a593Smuzhiyun }, \
120*4882a593Smuzhiyun PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_lpbk, \
121*4882a593Smuzhiyun e_input, e_od, \
122*4882a593Smuzhiyun schmitt_b, drvtype), \
123*4882a593Smuzhiyun drive_##pg_name, \
124*4882a593Smuzhiyun }
125*4882a593Smuzhiyun
126*4882a593Smuzhiyun static const struct tegra_pingroup tegra194_groups[] = {
127*4882a593Smuzhiyun PINGROUP(pex_l5_clkreq_n_pgg0, PE5, RSVD1, RSVD2, RSVD3, 0x14000, 0,
128*4882a593Smuzhiyun Y, -1, 6, 8, 11, 12, N, "vddio_pex_ctl_2"),
129*4882a593Smuzhiyun PINGROUP(pex_l5_rst_n_pgg1, PE5, RSVD1, RSVD2, RSVD3, 0x14008, 0,
130*4882a593Smuzhiyun Y, -1, 6, 8, 11, 12, N, "vddio_pex_ctl_2"),
131*4882a593Smuzhiyun };
132*4882a593Smuzhiyun
133*4882a593Smuzhiyun static const struct tegra_pinctrl_soc_data tegra194_pinctrl = {
134*4882a593Smuzhiyun .pins = tegra194_pins,
135*4882a593Smuzhiyun .npins = ARRAY_SIZE(tegra194_pins),
136*4882a593Smuzhiyun .functions = tegra194_functions,
137*4882a593Smuzhiyun .nfunctions = ARRAY_SIZE(tegra194_functions),
138*4882a593Smuzhiyun .groups = tegra194_groups,
139*4882a593Smuzhiyun .ngroups = ARRAY_SIZE(tegra194_groups),
140*4882a593Smuzhiyun .hsm_in_mux = true,
141*4882a593Smuzhiyun .schmitt_in_mux = true,
142*4882a593Smuzhiyun .drvtype_in_mux = true,
143*4882a593Smuzhiyun .sfsel_in_mux = true,
144*4882a593Smuzhiyun };
145*4882a593Smuzhiyun
tegra194_pinctrl_probe(struct platform_device * pdev)146*4882a593Smuzhiyun static int tegra194_pinctrl_probe(struct platform_device *pdev)
147*4882a593Smuzhiyun {
148*4882a593Smuzhiyun return tegra_pinctrl_probe(pdev, &tegra194_pinctrl);
149*4882a593Smuzhiyun }
150*4882a593Smuzhiyun
151*4882a593Smuzhiyun static const struct of_device_id tegra194_pinctrl_of_match[] = {
152*4882a593Smuzhiyun { .compatible = "nvidia,tegra194-pinmux", },
153*4882a593Smuzhiyun { },
154*4882a593Smuzhiyun };
155*4882a593Smuzhiyun
156*4882a593Smuzhiyun static struct platform_driver tegra194_pinctrl_driver = {
157*4882a593Smuzhiyun .driver = {
158*4882a593Smuzhiyun .name = "tegra194-pinctrl",
159*4882a593Smuzhiyun .of_match_table = tegra194_pinctrl_of_match,
160*4882a593Smuzhiyun },
161*4882a593Smuzhiyun .probe = tegra194_pinctrl_probe,
162*4882a593Smuzhiyun };
163*4882a593Smuzhiyun
tegra194_pinctrl_init(void)164*4882a593Smuzhiyun static int __init tegra194_pinctrl_init(void)
165*4882a593Smuzhiyun {
166*4882a593Smuzhiyun return platform_driver_register(&tegra194_pinctrl_driver);
167*4882a593Smuzhiyun }
168*4882a593Smuzhiyun arch_initcall(tegra194_pinctrl_init);
169