blob: a7788b76d902a64dd5708e40f6fb62c3b4ef4918 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Thomas Abraham16ca80a2016-04-23 22:18:08 +05302/*
3 * Exynos pinctrl driver header.
4 * Copyright (C) 2016 Samsung Electronics
5 * Thomas Abraham <thomas.ab@samsung.com>
Thomas Abraham16ca80a2016-04-23 22:18:08 +05306 */
7
8#ifndef __PINCTRL_EXYNOS_H_
9#define __PINCTRL_EXYNOS__H_
10
11#define PIN_CON 0x00 /* Offset of pin function register */
12#define PIN_DAT 0x04 /* Offset of pin data register */
13#define PIN_PUD 0x08 /* Offset of pin pull up/down config register */
14#define PIN_DRV 0x0C /* Offset of pin drive strength register */
15
16/**
17 * struct samsung_pin_bank_data: represent a controller pin-bank data.
18 * @offset: starting offset of the pin-bank registers.
19 * @nr_pins: number of pins included in this bank.
20 * @name: name to be prefixed for each pin in this pin bank.
21 */
22struct samsung_pin_bank_data {
23 u32 offset;
24 u8 nr_pins;
25 const char *name;
26};
27
28#define EXYNOS_PIN_BANK(pins, reg, id) \
29 { \
30 .offset = reg, \
31 .nr_pins = pins, \
32 .name = id \
33 }
34
35/**
36 * struct samsung_pin_ctrl: represent a pin controller.
37 * @pin_banks: list of pin banks included in this controller.
38 * @nr_banks: number of pin banks.
39 */
40struct samsung_pin_ctrl {
41 const struct samsung_pin_bank_data *pin_banks;
42 u32 nr_banks;
43};
44
45/**
46 * struct exynos_pinctrl_priv: exynos pin controller driver private data
47 * @pin_ctrl: pin controller bank information.
48 * @base: base address of the pin controller instance.
49 * @num_banks: number of pin banks included in the pin controller.
50 */
51struct exynos_pinctrl_priv {
52 const struct samsung_pin_ctrl *pin_ctrl;
53 unsigned long base;
54 int num_banks;
55};
56
57/**
58 * struct exynos_pinctrl_config_data: configuration for a peripheral.
59 * @offset: offset of the config registers in the controller.
60 * @mask: value of the register to be masked with.
61 * @value: new value to be programmed.
62 */
63struct exynos_pinctrl_config_data {
64 const unsigned int offset;
65 const unsigned int mask;
66 const unsigned int value;
67};
68
69
70void exynos_pinctrl_setup_peri(struct exynos_pinctrl_config_data *conf,
71 unsigned int num_conf, unsigned long base);
72int exynos_pinctrl_set_state(struct udevice *dev,
73 struct udevice *config);
74int exynos_pinctrl_probe(struct udevice *dev);
75
76#endif /* __PINCTRL_EXYNOS_H_ */