blob: 09eb80f2574a5314f5843478d090271cd45a20da [file] [log] [blame]
Linus Walleijae6b4d82011-10-19 18:14:33 +02001/*
2 * Interface the pinconfig portions of the pinctrl subsystem
3 *
4 * Copyright (C) 2011 ST-Ericsson SA
5 * Written on behalf of Linaro for ST-Ericsson
6 * This interface is used in the core to keep track of pins.
7 *
8 * Author: Linus Walleij <linus.walleij@linaro.org>
9 *
10 * License terms: GNU General Public License (GPL) version 2
11 */
12#ifndef __LINUX_PINCTRL_PINCONF_H
13#define __LINUX_PINCTRL_PINCONF_H
14
15#ifdef CONFIG_PINCONF
16
Laurent Meunierf07512e2013-04-18 10:48:07 +020017#include <linux/pinctrl/machine.h>
18
Linus Walleijae6b4d82011-10-19 18:14:33 +020019struct pinctrl_dev;
Stephen Warren63fd5982011-12-15 16:57:16 -070020struct seq_file;
Linus Walleijae6b4d82011-10-19 18:14:33 +020021
22/**
23 * struct pinconf_ops - pin config operations, to be implemented by
24 * pin configuration capable drivers.
Linus Walleij394349f2011-11-24 18:27:15 +010025 * @is_generic: for pin controllers that want to use the generic interface,
26 * this flag tells the framework that it's generic.
Linus Walleijae6b4d82011-10-19 18:14:33 +020027 * @pin_config_get: get the config of a certain pin, if the requested config
28 * is not available on this controller this should return -ENOTSUPP
29 * and if it is available but disabled it should return -EINVAL
Linus Walleijae6b4d82011-10-19 18:14:33 +020030 * @pin_config_set: configure an individual pin
31 * @pin_config_group_get: get configurations for an entire pin group
32 * @pin_config_group_set: configure all pins in a group
James Hogan1c851fb2013-06-18 10:49:33 +010033 * @pin_config_dbg_parse_modify: optional debugfs to modify a pin configuration
Linus Walleijae6b4d82011-10-19 18:14:33 +020034 * @pin_config_dbg_show: optional debugfs display hook that will provide
35 * per-device info for a certain pin in debugfs
36 * @pin_config_group_dbg_show: optional debugfs display hook that will provide
37 * per-device info for a certain group in debugfs
Stephen Warren6cb41582012-04-13 10:49:06 -060038 * @pin_config_config_dbg_show: optional debugfs display hook that will decode
39 * and display a driver's pin configuration parameter
Linus Walleijae6b4d82011-10-19 18:14:33 +020040 */
41struct pinconf_ops {
Linus Walleij394349f2011-11-24 18:27:15 +010042#ifdef CONFIG_GENERIC_PINCONF
43 bool is_generic;
44#endif
Linus Walleijae6b4d82011-10-19 18:14:33 +020045 int (*pin_config_get) (struct pinctrl_dev *pctldev,
46 unsigned pin,
47 unsigned long *config);
48 int (*pin_config_set) (struct pinctrl_dev *pctldev,
49 unsigned pin,
Sherman Yin03b054e2013-08-27 11:32:12 -070050 unsigned long *configs,
51 unsigned num_configs);
Linus Walleijae6b4d82011-10-19 18:14:33 +020052 int (*pin_config_group_get) (struct pinctrl_dev *pctldev,
53 unsigned selector,
54 unsigned long *config);
55 int (*pin_config_group_set) (struct pinctrl_dev *pctldev,
56 unsigned selector,
Sherman Yin03b054e2013-08-27 11:32:12 -070057 unsigned long *configs,
58 unsigned num_configs);
Laurent Meunierf07512e2013-04-18 10:48:07 +020059 int (*pin_config_dbg_parse_modify) (struct pinctrl_dev *pctldev,
60 const char *arg,
61 unsigned long *config);
Linus Walleijae6b4d82011-10-19 18:14:33 +020062 void (*pin_config_dbg_show) (struct pinctrl_dev *pctldev,
63 struct seq_file *s,
64 unsigned offset);
65 void (*pin_config_group_dbg_show) (struct pinctrl_dev *pctldev,
66 struct seq_file *s,
67 unsigned selector);
Stephen Warren6cb41582012-04-13 10:49:06 -060068 void (*pin_config_config_dbg_show) (struct pinctrl_dev *pctldev,
69 struct seq_file *s,
70 unsigned long config);
Linus Walleijae6b4d82011-10-19 18:14:33 +020071};
72
Linus Walleijae6b4d82011-10-19 18:14:33 +020073#endif
74
75#endif /* __LINUX_PINCTRL_PINCONF_H */