blob: d6cc1bbdda8526b6de7dc6512a55f1c053cf7b46 [file] [log] [blame]
Neil Armstrong06534722024-04-05 10:15:11 +02001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Qualcomm sm8650 pinctrl
4 *
5 * (C) Copyright 2024 Linaro Ltd.
6 *
7 */
8
Neil Armstrong06534722024-04-05 10:15:11 +02009#include <dm.h>
10
11#include "pinctrl-qcom.h"
12
13#define MAX_PIN_NAME_LEN 32
14static char pin_name[MAX_PIN_NAME_LEN] __section(".data");
15
16static const struct pinctrl_function msm_pinctrl_functions[] = {
17 {"qup2_se7", 1},
18 {"gpio", 0},
19};
20
21static const char *sm8650_get_function_name(struct udevice *dev,
22 unsigned int selector)
23{
24 return msm_pinctrl_functions[selector].name;
25}
26
27static const char *sm8650_get_pin_name(struct udevice *dev,
28 unsigned int selector)
29{
30 static const char *special_pins_names[] = {
31 "ufs_reset",
32 "sdc2_clk",
33 "sdc2_cmd",
34 "sdc2_data",
35 };
36
37 if (selector >= 210 && selector <= 213)
38 snprintf(pin_name, MAX_PIN_NAME_LEN, special_pins_names[selector - 210]);
39 else
40 snprintf(pin_name, MAX_PIN_NAME_LEN, "gpio%u", selector);
41
42 return pin_name;
43}
44
45static unsigned int sm8650_get_function_mux(__maybe_unused unsigned int pin,
46 unsigned int selector)
47{
48 return msm_pinctrl_functions[selector].val;
49}
50
51static struct msm_pinctrl_data sm8650_data = {
52 .pin_data = {
53 .pin_count = 214,
54 .special_pins_start = 210,
55 },
56 .functions_count = ARRAY_SIZE(msm_pinctrl_functions),
57 .get_function_name = sm8650_get_function_name,
58 .get_function_mux = sm8650_get_function_mux,
59 .get_pin_name = sm8650_get_pin_name,
60};
61
62static const struct udevice_id msm_pinctrl_ids[] = {
63 { .compatible = "qcom,sm8650-tlmm", .data = (ulong)&sm8650_data },
64 { /* Sentinel */ }
65};
66
67U_BOOT_DRIVER(pinctrl_sm8650) = {
68 .name = "pinctrl_sm8650",
69 .id = UCLASS_NOP,
70 .of_match = msm_pinctrl_ids,
71 .ops = &msm_pinctrl_ops,
72 .bind = msm_pinctrl_bind,
73};
74