xref: /freebsd/sys/contrib/device-tree/include/dt-bindings/pinctrl/am43xx.h (revision c66ec88fed842fbaad62c30d510644ceb7bd2d71)
1*c66ec88fSEmmanuel Vadot /* SPDX-License-Identifier: GPL-2.0 */
2*c66ec88fSEmmanuel Vadot /*
3*c66ec88fSEmmanuel Vadot  * This header provides constants specific to AM43XX pinctrl bindings.
4*c66ec88fSEmmanuel Vadot  */
5*c66ec88fSEmmanuel Vadot 
6*c66ec88fSEmmanuel Vadot #ifndef _DT_BINDINGS_PINCTRL_AM43XX_H
7*c66ec88fSEmmanuel Vadot #define _DT_BINDINGS_PINCTRL_AM43XX_H
8*c66ec88fSEmmanuel Vadot 
9*c66ec88fSEmmanuel Vadot #define MUX_MODE0	0
10*c66ec88fSEmmanuel Vadot #define MUX_MODE1	1
11*c66ec88fSEmmanuel Vadot #define MUX_MODE2	2
12*c66ec88fSEmmanuel Vadot #define MUX_MODE3	3
13*c66ec88fSEmmanuel Vadot #define MUX_MODE4	4
14*c66ec88fSEmmanuel Vadot #define MUX_MODE5	5
15*c66ec88fSEmmanuel Vadot #define MUX_MODE6	6
16*c66ec88fSEmmanuel Vadot #define MUX_MODE7	7
17*c66ec88fSEmmanuel Vadot #define MUX_MODE8	8
18*c66ec88fSEmmanuel Vadot #define MUX_MODE9	9
19*c66ec88fSEmmanuel Vadot 
20*c66ec88fSEmmanuel Vadot #define PULL_DISABLE		(1 << 16)
21*c66ec88fSEmmanuel Vadot #define PULL_UP			(1 << 17)
22*c66ec88fSEmmanuel Vadot #define INPUT_EN		(1 << 18)
23*c66ec88fSEmmanuel Vadot #define SLEWCTRL_SLOW		(1 << 19)
24*c66ec88fSEmmanuel Vadot #define SLEWCTRL_FAST		0
25*c66ec88fSEmmanuel Vadot #define DS0_FORCE_OFF_MODE	(1 << 24)
26*c66ec88fSEmmanuel Vadot #define DS0_INPUT		(1 << 25)
27*c66ec88fSEmmanuel Vadot #define DS0_FORCE_OUT_HIGH	(1 << 26)
28*c66ec88fSEmmanuel Vadot #define DS0_PULL_UP_DOWN_EN	(0 << 27)
29*c66ec88fSEmmanuel Vadot #define DS0_PULL_UP_DOWN_DIS	(1 << 27)
30*c66ec88fSEmmanuel Vadot #define DS0_PULL_UP_SEL		(1 << 28)
31*c66ec88fSEmmanuel Vadot #define WAKEUP_ENABLE		(1 << 29)
32*c66ec88fSEmmanuel Vadot 
33*c66ec88fSEmmanuel Vadot #define DS0_PIN_OUTPUT		(DS0_FORCE_OFF_MODE)
34*c66ec88fSEmmanuel Vadot #define DS0_PIN_OUTPUT_HIGH	(DS0_FORCE_OFF_MODE | DS0_FORCE_OUT_HIGH)
35*c66ec88fSEmmanuel Vadot #define DS0_PIN_OUTPUT_PULLUP	(DS0_FORCE_OFF_MODE | DS0_PULL_UP_DOWN_EN | DS0_PULL_UP_SEL)
36*c66ec88fSEmmanuel Vadot #define DS0_PIN_OUTPUT_PULLDOWN	(DS0_FORCE_OFF_MODE | DS0_PULL_UP_DOWN_EN)
37*c66ec88fSEmmanuel Vadot #define DS0_PIN_INPUT		(DS0_FORCE_OFF_MODE | DS0_INPUT)
38*c66ec88fSEmmanuel Vadot #define DS0_PIN_INPUT_PULLUP	(DS0_FORCE_OFF_MODE | DS0_INPUT | DS0_PULL_UP_DOWN_EN | DS0_PULL_UP_SEL)
39*c66ec88fSEmmanuel Vadot #define DS0_PIN_INPUT_PULLDOWN	(DS0_FORCE_OFF_MODE | DS0_INPUT | DS0_PULL_UP_DOWN_EN)
40*c66ec88fSEmmanuel Vadot 
41*c66ec88fSEmmanuel Vadot #define PIN_OUTPUT		(PULL_DISABLE)
42*c66ec88fSEmmanuel Vadot #define PIN_OUTPUT_PULLUP	(PULL_UP)
43*c66ec88fSEmmanuel Vadot #define PIN_OUTPUT_PULLDOWN	0
44*c66ec88fSEmmanuel Vadot #define PIN_INPUT		(INPUT_EN | PULL_DISABLE)
45*c66ec88fSEmmanuel Vadot #define PIN_INPUT_PULLUP	(INPUT_EN | PULL_UP)
46*c66ec88fSEmmanuel Vadot #define PIN_INPUT_PULLDOWN	(INPUT_EN)
47*c66ec88fSEmmanuel Vadot 
48*c66ec88fSEmmanuel Vadot /*
49*c66ec88fSEmmanuel Vadot  * Macro to allow using the absolute physical address instead of the
50*c66ec88fSEmmanuel Vadot  * padconf registers instead of the offset from padconf base.
51*c66ec88fSEmmanuel Vadot  */
52*c66ec88fSEmmanuel Vadot #define AM4372_IOPAD(pa, val)	(((pa) & 0xffff) - 0x0800) (val)
53*c66ec88fSEmmanuel Vadot 
54*c66ec88fSEmmanuel Vadot #endif
55*c66ec88fSEmmanuel Vadot 
56