Zephyr API Documentation
4.2.99
A Scalable Open Source RTOS
4.2.99
Toggle main menu visibility
Main Page
Related Pages
Topics
Data Structures
Data Structures
Data Structure Index
Data Fields
All
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Functions
Variables
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Enumerations
Enumerator
Files
File List
Globals
All
$
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Functions
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Variables
$
a
b
c
d
f
g
h
i
k
l
m
n
o
p
r
s
t
u
x
z
Typedefs
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Enumerations
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
w
x
z
Enumerator
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
w
x
z
Macros
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
Zephyr API Documentation
Introduction
Deprecated List
Topics
Data Structures
Files
File List
doc
kernel
lib
modules
subsys
zephyr
acpi
app_memory
arch
audio
bluetooth
canbus
console
crypto
data
debug
devicetree
dfu
display
drivers
dsp
dt-bindings
acpi
adc
battery
clock
comparator
dac
dai
display
dma
espi
ethernet
flash_controller
gnss
gpio
i2c
input
inputmux
interrupt-controller
ipc_service
led
lora
lvgl
memory-attr
memory-controller
mfd
mipi_dbi
mipi_dsi
misc
pcie
pinctrl
renesas
silabs
ambiq-apollo3-pinctrl.h
ambiq-apollo4-pinctrl.h
ambiq-apollo5-pinctrl.h
arm-mps2-pinctrl.h
arm-mps3-pinctrl.h
arm-mps4-pinctrl.h
arm-v2m_beetle-pinctrl.h
b91-pinctrl.h
cc13xx_cc26xx-pinctrl.h
cc23x0-pinctrl.h
ch32v003-pinctrl.h
ch32v00x-pinctrl.h
ch32v20x_30x-pinctrl.h
emsdp-pinctrl.h
ene-kb106x-pinctrl.h
ene-kb1200-pinctrl.h
esp-pinctrl-common.h
esp32-gpio-sigmap.h
esp32-pinctrl.h
esp32c2-gpio-sigmap.h
esp32c2-pinctrl.h
esp32c3-gpio-sigmap.h
esp32c3-pinctrl.h
esp32c6-gpio-sigmap.h
esp32c6-pinctrl.h
esp32s2-gpio-sigmap.h
esp32s2-pinctrl.h
esp32s3-gpio-sigmap.h
esp32s3-pinctrl.h
gecko-pinctrl-s1.h
gecko-pinctrl.h
ifx_cat1-pinctrl.h
imx8qm-pinctrl.h
imx8qxp-pinctrl.h
it8xxx2-pinctrl.h
lpc11u6x-pinctrl.h
max32-pinctrl.h
mchp-xec-pinctrl.h
mspm0-pinctrl.h
npcx-pinctrl.h
nrf-pinctrl.h
numaker-m46x-pinctrl.h
numicro-pinctrl.h
nxp-s32-pinctrl.h
pinctrl-zynq.h
pinctrl-zynqmp.h
quicklogic-eos-s3-pinctrl.h
realtek-rts5912-pinctrl.h
renesas-rzt2m-pinctrl.h
rpi-pico-pinctrl-common.h
rpi-pico-rp2040-pinctrl.h
rpi-pico-rp2350-pinctrl-common.h
rpi-pico-rp2350a-pinctrl.h
rpi-pico-rp2350b-pinctrl.h
rv32m1-pinctrl.h
si32-pinctrl.h
sifive-pinctrl.h
silabs-pinctrl-dbus.h
silabs-pinctrl-siwx91x.h
smartbond-pinctrl.h
stm32-pinctrl-common.h
stm32-pinctrl.h
stm32f1-afio.h
stm32f1-pinctrl.h
sy1xx-pinctrl.h
ti-cc32xx-pinctrl.h
ti-k3-pinctrl.h
xmc4xxx-pinctrl.h
power
pwm
qspi
rdc
regulator
reserved-memory
reset
sensor
sent
spi
timer
usb
usb-c
video
dt-util.h
fs
input
internal
ipc
kernel
linker
llext
logging
lorawan
math
mem_mgmt
mgmt
misc
modbus
modem
multi_heap
net
platform
pm
pmci
portability
posix
psa
random
retention
rtio
sd
sensing
settings
shell
sip_svc
stats
storage
sys
task_wdt
timing
toolchain
tracing
usb
usb_c
xen
zbus
zvfs
bindesc.h
cache.h
device.h
devicetree.h
fatal.h
fatal_types.h
init.h
irq.h
irq_multilevel.h
irq_nextlevel.h
irq_offload.h
kernel.h
kernel_includes.h
kernel_structs.h
kernel_version.h
net_buf.h
shared_irq.h
smf.h
spinlock.h
sw_isr_table.h
sys_clock.h
syscall.h
toolchain.h
types.h
Globals
•
All
Data Structures
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Modules
Pages
Loading...
Searching...
No Matches
ifx_cat1-pinctrl.h
Go to the documentation of this file.
1
/* Copyright 2022 Cypress Semiconductor Corporation (an Infineon company) or
2
* an affiliate of Cypress Semiconductor Corporation
3
*
4
* SPDX-License-Identifier: Apache-2.0
5
*/
6
#ifndef ZEPHYR_INCLUDE_DT_BINDINGS_PINCTRL_IFX_CAT1_PINCTRL_H_
7
#define ZEPHYR_INCLUDE_DT_BINDINGS_PINCTRL_IFX_CAT1_PINCTRL_H_
11
15
#define SOC_PINMUX_PORT_POS (0)
16
#define SOC_PINMUX_PORT_MASK (0xFFul << SOC_PINMUX_PORT_POS)
17
#define SOC_PINMUX_PIN_POS (8)
18
#define SOC_PINMUX_PIN_MASK (0xFFul << SOC_PINMUX_PIN_POS)
19
#define SOC_PINMUX_HSIOM_FUNC_POS (16)
20
#define SOC_PINMUX_HSIOM_MASK (0xFFul << SOC_PINMUX_HSIOM_FUNC_POS)
21
#define SOC_PINMUX_SIGNAL_POS (24)
22
#define SOC_PINMUX_SIGNAL_MASK (0xFFul << SOC_PINMUX_SIGNAL_POS)
23
27
#define HSIOM_SEL_GPIO (0)
28
#define HSIOM_SEL_GPIO_DSI (1)
29
#define HSIOM_SEL_DSI_DSI (2)
30
#define HSIOM_SEL_DSI_GPIO (3)
31
#define HSIOM_SEL_AMUXA (4)
32
#define HSIOM_SEL_AMUXB (5)
33
#define HSIOM_SEL_AMUXA_DSI (6)
34
#define HSIOM_SEL_AMUXB_DSI (7)
35
#define HSIOM_SEL_ACT_0 (8)
36
#define HSIOM_SEL_ACT_1 (9)
37
#define HSIOM_SEL_ACT_2 (10)
38
#define HSIOM_SEL_ACT_3 (11)
39
#define HSIOM_SEL_DS_0 (12)
40
#define HSIOM_SEL_DS_1 (13)
41
#define HSIOM_SEL_DS_2 (14)
42
#define HSIOM_SEL_DS_3 (15)
43
#define HSIOM_SEL_ACT_4 (16)
44
#define HSIOM_SEL_ACT_5 (17)
45
#define HSIOM_SEL_ACT_6 (18)
46
#define HSIOM_SEL_ACT_7 (19)
47
#define HSIOM_SEL_ACT_8 (20)
48
#define HSIOM_SEL_ACT_9 (21)
49
#define HSIOM_SEL_ACT_10 (22)
50
#define HSIOM_SEL_ACT_11 (23)
51
#define HSIOM_SEL_ACT_12 (24)
52
#define HSIOM_SEL_ACT_13 (25)
53
#define HSIOM_SEL_ACT_14 (26)
54
#define HSIOM_SEL_ACT_15 (27)
55
#define HSIOM_SEL_DS_4 (28)
56
#define HSIOM_SEL_DS_5 (29)
57
#define HSIOM_SEL_DS_6 (30)
58
#define HSIOM_SEL_DS_7 (31)
59
63
#define DT_CAT1_DRIVE_MODE_INFO(peripheral_signal) \
64
CAT1_PIN_MAP_DRIVE_MODE_##peripheral_signal
63
#define DT_CAT1_DRIVE_MODE_INFO(peripheral_signal) \
…
65
69
#define DT_CAT1_PINMUX(port, pin, hsiom) \
70
((port << SOC_PINMUX_PORT_POS) | \
71
(pin << SOC_PINMUX_PIN_POS) | \
72
(hsiom << SOC_PINMUX_HSIOM_FUNC_POS))
69
#define DT_CAT1_PINMUX(port, pin, hsiom) \
…
73
74
/* Redefine DT GPIO label (Px) to CYHAL port macros (CYHAL_PORT_x) */
75
#define P0 CYHAL_PORT_0
76
#define P1 CYHAL_PORT_1
77
#define P2 CYHAL_PORT_2
78
#define P3 CYHAL_PORT_3
79
#define P4 CYHAL_PORT_4
80
#define P5 CYHAL_PORT_5
81
#define P6 CYHAL_PORT_6
82
#define P7 CYHAL_PORT_7
83
#define P8 CYHAL_PORT_8
84
#define P9 CYHAL_PORT_9
85
#define P10 CYHAL_PORT_10
86
#define P11 CYHAL_PORT_11
87
#define P12 CYHAL_PORT_12
88
#define P13 CYHAL_PORT_13
89
#define P14 CYHAL_PORT_14
90
#define P15 CYHAL_PORT_15
91
#define P16 CYHAL_PORT_16
92
#define P17 CYHAL_PORT_17
93
#define P18 CYHAL_PORT_18
94
#define P19 CYHAL_PORT_19
95
#define P20 CYHAL_PORT_20
96
97
/* Returns CYHAL GPIO from Board device tree GPIO configuration
98
* CYHAL_GET_GPIO(port_number, pin_number),
99
* port_number = ((REG ADDR of node) - (REG ADDR of gpio_prt0)) / (REG SIZE of gpio_prt0)
100
* pin_number = DT_PHA_BY_IDX(node, gpios_prop, 0, pin)
101
*/
102
#define DT_GET_CYHAL_GPIO_FROM_DT_GPIOS(node, gpios_prop) \
103
CYHAL_GET_GPIO( \
104
(DT_REG_ADDR_BY_IDX(DT_GPIO_CTLR_BY_IDX(node, gpios_prop, 0), 0) - \
105
DT_REG_ADDR_BY_IDX(DT_NODELABEL(gpio_prt0), 0)) / \
106
DT_REG_ADDR_BY_IDX(DT_NODELABEL(gpio_prt0), 1), \
107
DT_PHA_BY_IDX(node, gpios_prop, 0, pin) \
108
)
102
#define DT_GET_CYHAL_GPIO_FROM_DT_GPIOS(node, gpios_prop) \
…
109
110
#endif
/* ZEPHYR_INCLUDE_DT_BINDINGS_PINCTRL_IFX_CAT1_PINCTRL_H_ */
zephyr
dt-bindings
pinctrl
ifx_cat1-pinctrl.h
Generated on
for Zephyr API Documentation by
1.14.0