Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
gpio.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2019-2020 Nordic Semiconductor ASA
3 * Copyright (c) 2019 Piotr Mienkowski
4 * Copyright (c) 2017 ARM Ltd
5 * Copyright (c) 2015-2016 Intel Corporation.
6 *
7 * SPDX-License-Identifier: Apache-2.0
8 */
9
15
16#ifndef ZEPHYR_INCLUDE_DRIVERS_GPIO_H_
17#define ZEPHYR_INCLUDE_DRIVERS_GPIO_H_
18
19#include <errno.h>
20
21#include <zephyr/sys/__assert.h>
22#include <zephyr/sys/slist.h>
24
25#include <zephyr/types.h>
26#include <stddef.h>
27#include <zephyr/device.h>
29
30#ifdef __cplusplus
31extern "C" {
32#endif
33
48
53
55#define GPIO_INPUT BIT(16)
56
58#define GPIO_OUTPUT BIT(17)
59
61#define GPIO_DISCONNECTED 0
62
64
65/* Initializes output to a low state. */
66#define GPIO_OUTPUT_INIT_LOW BIT(18)
67
68/* Initializes output to a high state. */
69#define GPIO_OUTPUT_INIT_HIGH BIT(19)
70
71/* Initializes output based on logic level */
72#define GPIO_OUTPUT_INIT_LOGICAL BIT(20)
73
75
77#define GPIO_OUTPUT_LOW (GPIO_OUTPUT | GPIO_OUTPUT_INIT_LOW)
79#define GPIO_OUTPUT_HIGH (GPIO_OUTPUT | GPIO_OUTPUT_INIT_HIGH)
81#define GPIO_OUTPUT_INACTIVE (GPIO_OUTPUT | \
82 GPIO_OUTPUT_INIT_LOW | \
83 GPIO_OUTPUT_INIT_LOGICAL)
84
85#define GPIO_OUTPUT_ACTIVE (GPIO_OUTPUT | \
86 GPIO_OUTPUT_INIT_HIGH | \
87 GPIO_OUTPUT_INIT_LOGICAL)
88
90
106
108#define GPIO_INT_DISABLE BIT(21)
109
111
112/* Enables GPIO pin interrupt. */
113#define GPIO_INT_ENABLE BIT(22)
114
115/* GPIO interrupt is sensitive to logical levels.
116 *
117 * This is a component flag that should be combined with other
118 * `GPIO_INT_*` flags to produce a meaningful configuration.
119 */
120#define GPIO_INT_LEVELS_LOGICAL BIT(23)
121
122/* GPIO interrupt is edge sensitive.
123 *
124 * Note: by default interrupts are level sensitive.
125 *
126 * This is a component flag that should be combined with other
127 * `GPIO_INT_*` flags to produce a meaningful configuration.
128 */
129#define GPIO_INT_EDGE BIT(24)
130
131/* Trigger detection when input state is (or transitions to) physical low or
132 * logical 0 level.
133 *
134 * This is a component flag that should be combined with other
135 * `GPIO_INT_*` flags to produce a meaningful configuration.
136 */
137#define GPIO_INT_LOW_0 BIT(25)
138
139/* Trigger detection on input state is (or transitions to) physical high or
140 * logical 1 level.
141 *
142 * This is a component flag that should be combined with other
143 * `GPIO_INT_*` flags to produce a meaningful configuration.
144 */
145#define GPIO_INT_HIGH_1 BIT(26)
146
147#ifdef CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT
148/* Disable/Enable interrupt functionality without changing other interrupt
149 * related register, such as clearing the pending register.
150 *
151 * This is a component flag that should be combined with `GPIO_INT_ENABLE` or
152 * `GPIO_INT_DISABLE` flags to produce a meaningful configuration.
153 */
154#define GPIO_INT_ENABLE_DISABLE_ONLY BIT(27)
155#endif /* CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT */
156
157#define GPIO_INT_MASK (GPIO_INT_DISABLE | \
158 GPIO_INT_ENABLE | \
159 GPIO_INT_LEVELS_LOGICAL | \
160 GPIO_INT_EDGE | \
161 GPIO_INT_LOW_0 | \
162 GPIO_INT_HIGH_1)
163
165
168#define GPIO_INT_EDGE_RISING (GPIO_INT_ENABLE | \
169 GPIO_INT_EDGE | \
170 GPIO_INT_HIGH_1)
171
175#define GPIO_INT_EDGE_FALLING (GPIO_INT_ENABLE | \
176 GPIO_INT_EDGE | \
177 GPIO_INT_LOW_0)
178
182#define GPIO_INT_EDGE_BOTH (GPIO_INT_ENABLE | \
183 GPIO_INT_EDGE | \
184 GPIO_INT_LOW_0 | \
185 GPIO_INT_HIGH_1)
186
190#define GPIO_INT_LEVEL_LOW (GPIO_INT_ENABLE | \
191 GPIO_INT_LOW_0)
192
196#define GPIO_INT_LEVEL_HIGH (GPIO_INT_ENABLE | \
197 GPIO_INT_HIGH_1)
198
202#define GPIO_INT_EDGE_TO_INACTIVE (GPIO_INT_ENABLE | \
203 GPIO_INT_LEVELS_LOGICAL | \
204 GPIO_INT_EDGE | \
205 GPIO_INT_LOW_0)
206
210#define GPIO_INT_EDGE_TO_ACTIVE (GPIO_INT_ENABLE | \
211 GPIO_INT_LEVELS_LOGICAL | \
212 GPIO_INT_EDGE | \
213 GPIO_INT_HIGH_1)
214
218#define GPIO_INT_LEVEL_INACTIVE (GPIO_INT_ENABLE | \
219 GPIO_INT_LEVELS_LOGICAL | \
220 GPIO_INT_LOW_0)
221
225#define GPIO_INT_LEVEL_ACTIVE (GPIO_INT_ENABLE | \
226 GPIO_INT_LEVELS_LOGICAL | \
227 GPIO_INT_HIGH_1)
228
230
232#define GPIO_DIR_MASK (GPIO_INPUT | GPIO_OUTPUT)
234
242
255
263
275
283
304
339#define GPIO_DT_SPEC_GET_BY_IDX(node_id, prop, idx) \
340 { \
341 .port = DEVICE_DT_GET(DT_GPIO_CTLR_BY_IDX(node_id, prop, idx)),\
342 .pin = DT_GPIO_PIN_BY_IDX(node_id, prop, idx), \
343 .dt_flags = DT_GPIO_FLAGS_BY_IDX(node_id, prop, idx), \
344 }
345
363#define GPIO_DT_SPEC_GET_BY_IDX_OR(node_id, prop, idx, default_value) \
364 COND_CODE_1(DT_PROP_HAS_IDX(node_id, prop, idx), \
365 (GPIO_DT_SPEC_GET_BY_IDX(node_id, prop, idx)), \
366 (default_value))
367
376#define GPIO_DT_SPEC_GET(node_id, prop) \
377 GPIO_DT_SPEC_GET_BY_IDX(node_id, prop, 0)
378
389#define GPIO_DT_SPEC_GET_OR(node_id, prop, default_value) \
390 GPIO_DT_SPEC_GET_BY_IDX_OR(node_id, prop, 0, default_value)
391
402#define GPIO_DT_SPEC_INST_GET_BY_IDX(inst, prop, idx) \
403 GPIO_DT_SPEC_GET_BY_IDX(DT_DRV_INST(inst), prop, idx)
404
416#define GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, prop, idx, default_value) \
417 COND_CODE_1(DT_PROP_HAS_IDX(DT_DRV_INST(inst), prop, idx), \
418 (GPIO_DT_SPEC_GET_BY_IDX(DT_DRV_INST(inst), prop, idx)), \
419 (default_value))
420
429#define GPIO_DT_SPEC_INST_GET(inst, prop) \
430 GPIO_DT_SPEC_INST_GET_BY_IDX(inst, prop, 0)
431
442#define GPIO_DT_SPEC_INST_GET_OR(inst, prop, default_value) \
443 GPIO_DT_SPEC_INST_GET_BY_IDX_OR(inst, prop, 0, default_value)
444
445/*
446 * @cond INTERNAL_HIDDEN
447 */
448
459#define Z_GPIO_GEN_BITMASK_COND(node_id, prop, off_idx, sz_idx) \
460 COND_CODE_1(DT_PROP_HAS_IDX(node_id, prop, off_idx), \
461 (COND_CODE_0(DT_PROP_BY_IDX(node_id, prop, sz_idx), \
462 (0), \
463 (GENMASK64(DT_PROP_BY_IDX(node_id, prop, off_idx) + \
464 DT_PROP_BY_IDX(node_id, prop, sz_idx) - 1, \
465 DT_PROP_BY_IDX(node_id, prop, off_idx)))) \
466 ), (0))
467
475#define Z_GPIO_GEN_RESERVED_RANGES_COND(odd_it, node_id) \
476 COND_CODE_1(DT_PROP_HAS_IDX(node_id, gpio_reserved_ranges, odd_it), \
477 (Z_GPIO_GEN_BITMASK_COND(node_id, \
478 gpio_reserved_ranges, \
479 GET_ARG_N(odd_it, Z_SPARSE_LIST_EVEN_NUMBERS), \
480 odd_it)), \
481 (0))
482
486
574#define GPIO_DT_RESERVED_RANGES_NGPIOS(node_id, ngpios) \
575 ((gpio_port_pins_t) \
576 COND_CODE_1(DT_NODE_HAS_PROP(node_id, gpio_reserved_ranges), \
577 (GENMASK64(BITS_PER_LONG_LONG - 1, ngpios) \
578 | FOR_EACH_FIXED_ARG(Z_GPIO_GEN_RESERVED_RANGES_COND, \
579 (|), \
580 node_id, \
581 LIST_DROP_EMPTY(Z_SPARSE_LIST_ODD_NUMBERS))), \
582 (0)))
583
591#define GPIO_DT_RESERVED_RANGES(node_id) \
592 GPIO_DT_RESERVED_RANGES_NGPIOS(node_id, DT_PROP(node_id, ngpios))
593
603#define GPIO_DT_INST_RESERVED_RANGES_NGPIOS(inst, ngpios) \
604 GPIO_DT_RESERVED_RANGES_NGPIOS(DT_DRV_INST(inst), ngpios)
605
614#define GPIO_DT_INST_RESERVED_RANGES(inst) \
615 GPIO_DT_RESERVED_RANGES(DT_DRV_INST(inst))
616
665#define GPIO_DT_PORT_PIN_MASK_NGPIOS_EXC(node_id, ngpios) \
666 ((gpio_port_pins_t) \
667 COND_CODE_0(ngpios, \
668 (0), \
669 (COND_CODE_1(DT_NODE_HAS_PROP(node_id, gpio_reserved_ranges), \
670 ((GENMASK64(ngpios - 1, 0) & \
671 ~GPIO_DT_RESERVED_RANGES_NGPIOS(node_id, ngpios))), \
672 (GENMASK64(ngpios - 1, 0))) \
673 ) \
674 ))
675
685#define GPIO_DT_INST_PORT_PIN_MASK_NGPIOS_EXC(inst, ngpios) \
686 GPIO_DT_PORT_PIN_MASK_NGPIOS_EXC(DT_DRV_INST(inst), ngpios)
687
691#define GPIO_MAX_PINS_PER_PORT (sizeof(gpio_port_pins_t) * __CHAR_BIT__)
692
706
719
720struct gpio_callback;
721
734typedef void (*gpio_callback_handler_t)(const struct device *port,
735 struct gpio_callback *cb,
736 gpio_port_pins_t pins);
737
765
771
772/* Used by driver api function pin_interrupt_configure, these are defined
773 * in terms of the public flags so we can just mask and pass them
774 * through to the driver api
775 */
776enum gpio_int_mode {
777 GPIO_INT_MODE_DISABLED = GPIO_INT_DISABLE,
778 GPIO_INT_MODE_LEVEL = GPIO_INT_ENABLE,
779 GPIO_INT_MODE_EDGE = GPIO_INT_ENABLE | GPIO_INT_EDGE,
780#ifdef CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT
781 GPIO_INT_MODE_DISABLE_ONLY = GPIO_INT_DISABLE | GPIO_INT_ENABLE_DISABLE_ONLY,
782 GPIO_INT_MODE_ENABLE_ONLY = GPIO_INT_ENABLE | GPIO_INT_ENABLE_DISABLE_ONLY,
783#endif /* CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT */
784};
785
786enum gpio_int_trig {
787 /* Trigger detection when input state is (or transitions to)
788 * physical low. (Edge Falling or Active Low)
789 */
790 GPIO_INT_TRIG_LOW = GPIO_INT_LOW_0,
791 /* Trigger detection when input state is (or transitions to)
792 * physical high. (Edge Rising or Active High) */
793 GPIO_INT_TRIG_HIGH = GPIO_INT_HIGH_1,
794 /* Trigger detection on pin rising or falling edge. */
795 GPIO_INT_TRIG_BOTH = GPIO_INT_LOW_0 | GPIO_INT_HIGH_1,
796 /* Trigger a system wakeup. */
797 GPIO_INT_TRIG_WAKE = GPIO_INT_WAKEUP,
798 /* Trigger a system wakeup when input state is (or transitions to)
799 * physical low. (Edge Falling or Active Low)
800 */
801 GPIO_INT_TRIG_WAKE_LOW = GPIO_INT_LOW_0 | GPIO_INT_WAKEUP,
802 /* Trigger a system wakeup when input state is (or transitions to)
803 * physical high. (Edge Rising or Active High)
804 */
805 GPIO_INT_TRIG_WAKE_HIGH = GPIO_INT_HIGH_1 | GPIO_INT_WAKEUP,
806 /* Trigger a system wakeup on pin rising or falling edge. */
807 GPIO_INT_TRIG_WAKE_BOTH = GPIO_INT_LOW_0 | GPIO_INT_HIGH_1 | GPIO_INT_WAKEUP,
808};
809
810__subsystem struct gpio_driver_api {
811 int (*pin_configure)(const struct device *port, gpio_pin_t pin,
813#ifdef CONFIG_GPIO_GET_CONFIG
814 int (*pin_get_config)(const struct device *port, gpio_pin_t pin,
816#endif
817 int (*port_get_raw)(const struct device *port,
818 gpio_port_value_t *value);
819 int (*port_set_masked_raw)(const struct device *port,
820 gpio_port_pins_t mask,
821 gpio_port_value_t value);
822 int (*port_set_bits_raw)(const struct device *port,
823 gpio_port_pins_t pins);
824 int (*port_clear_bits_raw)(const struct device *port,
825 gpio_port_pins_t pins);
826 int (*port_toggle_bits)(const struct device *port,
827 gpio_port_pins_t pins);
828 int (*pin_interrupt_configure)(const struct device *port,
829 gpio_pin_t pin,
830 enum gpio_int_mode mode,
831 enum gpio_int_trig trig);
832 int (*manage_callback)(const struct device *port,
833 struct gpio_callback *cb,
834 bool set);
835 uint32_t (*get_pending_int)(const struct device *dev);
836#ifdef CONFIG_GPIO_GET_DIRECTION
837 int (*port_get_direction)(const struct device *port, gpio_port_pins_t map,
838 gpio_port_pins_t *inputs, gpio_port_pins_t *outputs);
839#endif /* CONFIG_GPIO_GET_DIRECTION */
840};
841
845
854static inline bool gpio_is_ready_dt(const struct gpio_dt_spec *spec)
855{
856 /* Validate port is ready */
857 return device_is_ready(spec->port);
858}
859
883__syscall int gpio_pin_interrupt_configure(const struct device *port,
884 gpio_pin_t pin,
886
887static inline int z_impl_gpio_pin_interrupt_configure(const struct device *port,
888 gpio_pin_t pin,
890{
891 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
892 __unused const struct gpio_driver_config *const cfg =
893 (const struct gpio_driver_config *)port->config;
894 const struct gpio_driver_data *const data =
895 (const struct gpio_driver_data *)port->data;
896 enum gpio_int_trig trig;
897 enum gpio_int_mode mode;
898 int ret;
899
900 SYS_PORT_TRACING_FUNC_ENTER(gpio_pin, interrupt_configure, port, pin, flags);
901
902 if (api->pin_interrupt_configure == NULL) {
903 SYS_PORT_TRACING_FUNC_EXIT(gpio_pin, interrupt_configure, port, pin, -ENOSYS);
904 return -ENOSYS;
905 }
906
907 __ASSERT((flags & (GPIO_INT_DISABLE | GPIO_INT_ENABLE))
908 != (GPIO_INT_DISABLE | GPIO_INT_ENABLE),
909 "Cannot both enable and disable interrupts");
910
911 __ASSERT((flags & (GPIO_INT_DISABLE | GPIO_INT_ENABLE)) != 0U,
912 "Must either enable or disable interrupts");
913
914 __ASSERT(((flags & GPIO_INT_ENABLE) == 0) ||
915 ((flags & GPIO_INT_EDGE) != 0) ||
916 ((flags & (GPIO_INT_LOW_0 | GPIO_INT_HIGH_1)) !=
917 (GPIO_INT_LOW_0 | GPIO_INT_HIGH_1)),
918 "Only one of GPIO_INT_LOW_0, GPIO_INT_HIGH_1 can be "
919 "enabled for a level interrupt.");
920
921#ifdef CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT
922#define GPIO_INT_ENABLE_DISABLE_ONLY_VALUE GPIO_INT_ENABLE_DISABLE_ONLY
923#else
924#define GPIO_INT_ENABLE_DISABLE_ONLY_VALUE 0
925#endif /* CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT */
926
927 __ASSERT(((flags & GPIO_INT_ENABLE) == 0) ||
928 ((flags & (GPIO_INT_LOW_0 | GPIO_INT_HIGH_1)) != 0) ||
930 "At least one of GPIO_INT_LOW_0, GPIO_INT_HIGH_1 has to be enabled.");
931#undef GPIO_INT_ENABLE_DISABLE_ONLY_VALUE
932 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
933 "Unsupported pin");
934
935 if (((flags & GPIO_INT_LEVELS_LOGICAL) != 0) &&
936 ((data->invert & (gpio_port_pins_t)BIT(pin)) != 0)) {
937 /* Invert signal bits */
938 flags ^= (GPIO_INT_LOW_0 | GPIO_INT_HIGH_1);
939 }
940
941 trig = (enum gpio_int_trig)(flags & (GPIO_INT_LOW_0 | GPIO_INT_HIGH_1 | GPIO_INT_WAKEUP));
942#ifdef CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT
943 mode = (enum gpio_int_mode)(flags & (GPIO_INT_EDGE | GPIO_INT_DISABLE | GPIO_INT_ENABLE |
944 GPIO_INT_ENABLE_DISABLE_ONLY));
945#else
946 mode = (enum gpio_int_mode)(flags & (GPIO_INT_EDGE | GPIO_INT_DISABLE | GPIO_INT_ENABLE));
947#endif /* CONFIG_GPIO_ENABLE_DISABLE_INTERRUPT */
948
949 ret = api->pin_interrupt_configure(port, pin, mode, trig);
950 SYS_PORT_TRACING_FUNC_EXIT(gpio_pin, interrupt_configure, port, pin, ret);
951 return ret;
952}
953
971static inline int gpio_pin_interrupt_configure_dt(const struct gpio_dt_spec *spec,
973{
974 return gpio_pin_interrupt_configure(spec->port, spec->pin,
975 flags | (spec->dt_flags & GPIO_INT_WAKEUP));
976}
977
993__syscall int gpio_pin_configure(const struct device *port,
994 gpio_pin_t pin,
996
997static inline int z_impl_gpio_pin_configure(const struct device *port,
998 gpio_pin_t pin,
1000{
1001 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1002 __unused const struct gpio_driver_config *const cfg =
1003 (const struct gpio_driver_config *)port->config;
1004 struct gpio_driver_data *data =
1005 (struct gpio_driver_data *)port->data;
1006 int ret;
1007
1008 SYS_PORT_TRACING_FUNC_ENTER(gpio_pin, configure, port, pin, flags);
1009
1010 __ASSERT((flags & GPIO_INT_MASK) == 0,
1011 "Interrupt flags are not supported");
1012
1013 __ASSERT((flags & (GPIO_PULL_UP | GPIO_PULL_DOWN)) !=
1015 "Pull Up and Pull Down should not be enabled simultaneously");
1016
1017 __ASSERT(!((flags & GPIO_INPUT) && !(flags & GPIO_OUTPUT) && (flags & GPIO_SINGLE_ENDED)),
1018 "Input cannot be enabled for 'Open Drain', 'Open Source' modes without Output");
1019
1020 __ASSERT_NO_MSG((flags & GPIO_SINGLE_ENDED) != 0 ||
1021 (flags & GPIO_LINE_OPEN_DRAIN) == 0);
1022
1023 __ASSERT((flags & (GPIO_OUTPUT_INIT_LOW | GPIO_OUTPUT_INIT_HIGH)) == 0
1024 || (flags & GPIO_OUTPUT) != 0,
1025 "Output needs to be enabled to be initialized low or high");
1026
1027 __ASSERT((flags & (GPIO_OUTPUT_INIT_LOW | GPIO_OUTPUT_INIT_HIGH))
1028 != (GPIO_OUTPUT_INIT_LOW | GPIO_OUTPUT_INIT_HIGH),
1029 "Output cannot be initialized low and high");
1030
1031 if (((flags & GPIO_OUTPUT_INIT_LOGICAL) != 0)
1032 && ((flags & (GPIO_OUTPUT_INIT_LOW | GPIO_OUTPUT_INIT_HIGH)) != 0)
1033 && ((flags & GPIO_ACTIVE_LOW) != 0)) {
1034 flags ^= GPIO_OUTPUT_INIT_LOW | GPIO_OUTPUT_INIT_HIGH;
1035 }
1036
1037 flags &= ~GPIO_OUTPUT_INIT_LOGICAL;
1038
1039 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
1040 "Unsupported pin");
1041
1042 if ((flags & GPIO_ACTIVE_LOW) != 0) {
1043 data->invert |= (gpio_port_pins_t)BIT(pin);
1044 } else {
1045 data->invert &= ~(gpio_port_pins_t)BIT(pin);
1046 }
1047
1048 ret = api->pin_configure(port, pin, flags);
1049 SYS_PORT_TRACING_FUNC_EXIT(gpio_pin, configure, port, pin, ret);
1050 return ret;
1051}
1052
1064static inline int gpio_pin_configure_dt(const struct gpio_dt_spec *spec,
1065 gpio_flags_t extra_flags)
1066{
1067 return gpio_pin_configure(spec->port,
1068 spec->pin,
1069 spec->dt_flags | extra_flags);
1070}
1071
1090__syscall int gpio_port_get_direction(const struct device *port, gpio_port_pins_t map,
1091 gpio_port_pins_t *inputs, gpio_port_pins_t *outputs);
1092
1093#ifdef CONFIG_GPIO_GET_DIRECTION
1094static inline int z_impl_gpio_port_get_direction(const struct device *port, gpio_port_pins_t map,
1095 gpio_port_pins_t *inputs,
1096 gpio_port_pins_t *outputs)
1097{
1098 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1099 int ret;
1100
1101 SYS_PORT_TRACING_FUNC_ENTER(gpio_port, get_direction, port, map, inputs, outputs);
1102
1103 if (api->port_get_direction == NULL) {
1104 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, get_direction, port, -ENOSYS);
1105 return -ENOSYS;
1106 }
1107
1108 ret = api->port_get_direction(port, map, inputs, outputs);
1109 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, get_direction, port, ret);
1110 return ret;
1111}
1112#endif /* CONFIG_GPIO_GET_DIRECTION */
1113
1126static inline int gpio_pin_is_input(const struct device *port, gpio_pin_t pin)
1127{
1128 int rv;
1129 gpio_port_pins_t pins;
1130 __unused const struct gpio_driver_config *cfg =
1131 (const struct gpio_driver_config *)port->config;
1132
1133 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U, "Unsupported pin");
1134
1135 rv = gpio_port_get_direction(port, BIT(pin), &pins, NULL);
1136 if (rv < 0) {
1137 return rv;
1138 }
1139
1140 return (int)!!((gpio_port_pins_t)BIT(pin) & pins);
1141}
1142
1154static inline int gpio_pin_is_input_dt(const struct gpio_dt_spec *spec)
1155{
1156 return gpio_pin_is_input(spec->port, spec->pin);
1157}
1158
1171static inline int gpio_pin_is_output(const struct device *port, gpio_pin_t pin)
1172{
1173 int rv;
1174 gpio_port_pins_t pins;
1175 __unused const struct gpio_driver_config *cfg =
1176 (const struct gpio_driver_config *)port->config;
1177
1178 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U, "Unsupported pin");
1179
1180 rv = gpio_port_get_direction(port, BIT(pin), NULL, &pins);
1181 if (rv < 0) {
1182 return rv;
1183 }
1184
1185 return (int)!!((gpio_port_pins_t)BIT(pin) & pins);
1186}
1187
1199static inline int gpio_pin_is_output_dt(const struct gpio_dt_spec *spec)
1200{
1201 return gpio_pin_is_output(spec->port, spec->pin);
1202}
1203
1219__syscall int gpio_pin_get_config(const struct device *port, gpio_pin_t pin,
1221
1222#ifdef CONFIG_GPIO_GET_CONFIG
1223static inline int z_impl_gpio_pin_get_config(const struct device *port,
1224 gpio_pin_t pin,
1226{
1227 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1228 int ret;
1229
1230 SYS_PORT_TRACING_FUNC_ENTER(gpio_pin, get_config, port, pin, *flags);
1231
1232 if (api->pin_get_config == NULL) {
1233 SYS_PORT_TRACING_FUNC_EXIT(gpio_pin, get_config, port, pin, -ENOSYS);
1234 return -ENOSYS;
1235 }
1236
1237 ret = api->pin_get_config(port, pin, flags);
1238 SYS_PORT_TRACING_FUNC_EXIT(gpio_pin, get_config, port, pin, ret);
1239 return ret;
1240}
1241#endif
1242
1255static inline int gpio_pin_get_config_dt(const struct gpio_dt_spec *spec,
1257{
1258 return gpio_pin_get_config(spec->port, spec->pin, flags);
1259}
1260
1278__syscall int gpio_port_get_raw(const struct device *port,
1279 gpio_port_value_t *value);
1280
1281static inline int z_impl_gpio_port_get_raw(const struct device *port, gpio_port_value_t *value)
1282{
1283 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1284 int ret;
1285
1286 SYS_PORT_TRACING_FUNC_ENTER(gpio_port, get_raw, port, value);
1287
1288 ret = api->port_get_raw(port, value);
1289 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, get_raw, port, ret);
1290 return ret;
1291}
1292
1311static inline int gpio_port_get(const struct device *port,
1312 gpio_port_value_t *value)
1313{
1314 const struct gpio_driver_data *const data =
1315 (const struct gpio_driver_data *)port->data;
1316 int ret;
1317
1318 ret = gpio_port_get_raw(port, value);
1319 if (ret == 0) {
1320 *value ^= data->invert;
1321 }
1322
1323 return ret;
1324}
1325
1343__syscall int gpio_port_set_masked_raw(const struct device *port,
1344 gpio_port_pins_t mask,
1345 gpio_port_value_t value);
1346
1347static inline int z_impl_gpio_port_set_masked_raw(const struct device *port,
1348 gpio_port_pins_t mask,
1349 gpio_port_value_t value)
1350{
1351 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1352 int ret;
1353
1354 SYS_PORT_TRACING_FUNC_ENTER(gpio_port, set_masked_raw, port, mask, value);
1355
1356 ret = api->port_set_masked_raw(port, mask, value);
1357 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, set_masked_raw, port, ret);
1358 return ret;
1359}
1360
1381static inline int gpio_port_set_masked(const struct device *port,
1382 gpio_port_pins_t mask,
1383 gpio_port_value_t value)
1384{
1385 const struct gpio_driver_data *const data =
1386 (const struct gpio_driver_data *)port->data;
1387
1388 value ^= data->invert;
1389
1390 return gpio_port_set_masked_raw(port, mask, value);
1391}
1392
1403__syscall int gpio_port_set_bits_raw(const struct device *port,
1404 gpio_port_pins_t pins);
1405
1406static inline int z_impl_gpio_port_set_bits_raw(const struct device *port,
1407 gpio_port_pins_t pins)
1408{
1409 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1410 int ret;
1411
1412 SYS_PORT_TRACING_FUNC_ENTER(gpio_port, set_bits_raw, port, pins);
1413
1414 ret = api->port_set_bits_raw(port, pins);
1415 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, set_bits_raw, port, ret);
1416 return ret;
1417}
1418
1429static inline int gpio_port_set_bits(const struct device *port,
1430 gpio_port_pins_t pins)
1431{
1432 return gpio_port_set_masked(port, pins, pins);
1433}
1434
1445__syscall int gpio_port_clear_bits_raw(const struct device *port,
1446 gpio_port_pins_t pins);
1447
1448static inline int z_impl_gpio_port_clear_bits_raw(const struct device *port,
1449 gpio_port_pins_t pins)
1450{
1451 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1452 int ret;
1453
1454 SYS_PORT_TRACING_FUNC_ENTER(gpio_port, clear_bits_raw, port, pins);
1455
1456 ret = api->port_clear_bits_raw(port, pins);
1457 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, clear_bits_raw, port, ret);
1458 return ret;
1459}
1460
1471static inline int gpio_port_clear_bits(const struct device *port,
1472 gpio_port_pins_t pins)
1473{
1474 return gpio_port_set_masked(port, pins, 0);
1475}
1476
1487__syscall int gpio_port_toggle_bits(const struct device *port,
1488 gpio_port_pins_t pins);
1489
1490static inline int z_impl_gpio_port_toggle_bits(const struct device *port,
1491 gpio_port_pins_t pins)
1492{
1493 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1494 int ret;
1495
1496 SYS_PORT_TRACING_FUNC_ENTER(gpio_port, toggle_bits, port, pins);
1497
1498 ret = api->port_toggle_bits(port, pins);
1499 SYS_PORT_TRACING_FUNC_EXIT(gpio_port, toggle_bits, port, ret);
1500 return ret;
1501}
1502
1514static inline int gpio_port_set_clr_bits_raw(const struct device *port,
1515 gpio_port_pins_t set_pins,
1516 gpio_port_pins_t clear_pins)
1517{
1518 __ASSERT((set_pins & clear_pins) == 0, "Set and Clear pins overlap");
1519
1520 return gpio_port_set_masked_raw(port, set_pins | clear_pins, set_pins);
1521}
1522
1534static inline int gpio_port_set_clr_bits(const struct device *port,
1535 gpio_port_pins_t set_pins,
1536 gpio_port_pins_t clear_pins)
1537{
1538 __ASSERT((set_pins & clear_pins) == 0, "Set and Clear pins overlap");
1539
1540 return gpio_port_set_masked(port, set_pins | clear_pins, set_pins);
1541}
1542
1558static inline int gpio_pin_get_raw(const struct device *port, gpio_pin_t pin)
1559{
1560 __unused const struct gpio_driver_config *const cfg =
1561 (const struct gpio_driver_config *)port->config;
1562 gpio_port_value_t value;
1563 int ret;
1564
1565 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
1566 "Unsupported pin");
1567
1568 ret = gpio_port_get_raw(port, &value);
1569 if (ret == 0) {
1570 ret = (value & (gpio_port_pins_t)BIT(pin)) != 0 ? 1 : 0;
1571 }
1572
1573 return ret;
1574}
1575
1595static inline int gpio_pin_get(const struct device *port, gpio_pin_t pin)
1596{
1597 __unused const struct gpio_driver_config *const cfg =
1598 (const struct gpio_driver_config *)port->config;
1599 gpio_port_value_t value;
1600 int ret;
1601
1602 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
1603 "Unsupported pin");
1604
1605 ret = gpio_port_get(port, &value);
1606 if (ret == 0) {
1607 ret = (value & (gpio_port_pins_t)BIT(pin)) != 0 ? 1 : 0;
1608 }
1609
1610 return ret;
1611}
1612
1623static inline int gpio_pin_get_dt(const struct gpio_dt_spec *spec)
1624{
1625 return gpio_pin_get(spec->port, spec->pin);
1626}
1627
1643static inline int gpio_pin_set_raw(const struct device *port, gpio_pin_t pin,
1644 int value)
1645{
1646 __unused const struct gpio_driver_config *const cfg =
1647 (const struct gpio_driver_config *)port->config;
1648 int ret;
1649
1650 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
1651 "Unsupported pin");
1652
1653 if (value != 0) {
1654 ret = gpio_port_set_bits_raw(port, (gpio_port_pins_t)BIT(pin));
1655 } else {
1657 }
1658
1659 return ret;
1660}
1661
1683static inline int gpio_pin_set(const struct device *port, gpio_pin_t pin,
1684 int value)
1685{
1686 __unused const struct gpio_driver_config *const cfg =
1687 (const struct gpio_driver_config *)port->config;
1688 const struct gpio_driver_data *const data =
1689 (const struct gpio_driver_data *)port->data;
1690
1691 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
1692 "Unsupported pin");
1693
1694 if (data->invert & (gpio_port_pins_t)BIT(pin)) {
1695 value = (value != 0) ? 0 : 1;
1696 }
1697
1698 return gpio_pin_set_raw(port, pin, value);
1699}
1700
1712static inline int gpio_pin_set_dt(const struct gpio_dt_spec *spec, int value)
1713{
1714 return gpio_pin_set(spec->port, spec->pin, value);
1715}
1716
1727static inline int gpio_pin_toggle(const struct device *port, gpio_pin_t pin)
1728{
1729 __unused const struct gpio_driver_config *const cfg =
1730 (const struct gpio_driver_config *)port->config;
1731
1732 __ASSERT((cfg->port_pin_mask & (gpio_port_pins_t)BIT(pin)) != 0U,
1733 "Unsupported pin");
1734
1735 return gpio_port_toggle_bits(port, (gpio_port_pins_t)BIT(pin));
1736}
1737
1748static inline int gpio_pin_toggle_dt(const struct gpio_dt_spec *spec)
1749{
1750 return gpio_pin_toggle(spec->port, spec->pin);
1751}
1752
1759static inline void gpio_init_callback(struct gpio_callback *callback,
1761 gpio_port_pins_t pin_mask)
1762{
1763 SYS_PORT_TRACING_FUNC_ENTER(gpio, init_callback, callback, handler, pin_mask);
1764
1765 __ASSERT(callback, "Callback pointer should not be NULL");
1766 __ASSERT(handler, "Callback handler pointer should not be NULL");
1767
1768 callback->handler = handler;
1769 callback->pin_mask = pin_mask;
1770
1771 SYS_PORT_TRACING_FUNC_EXIT(gpio, init_callback, callback);
1772}
1773
1788static inline int gpio_add_callback(const struct device *port,
1789 struct gpio_callback *callback)
1790{
1791 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1792 int ret;
1793
1794 SYS_PORT_TRACING_FUNC_ENTER(gpio, add_callback, port, callback);
1795
1796 if (api->manage_callback == NULL) {
1797 SYS_PORT_TRACING_FUNC_EXIT(gpio, add_callback, port, -ENOSYS);
1798 return -ENOSYS;
1799 }
1800
1801 ret = api->manage_callback(port, callback, true);
1802 SYS_PORT_TRACING_FUNC_EXIT(gpio, add_callback, port, ret);
1803 return ret;
1804}
1805
1817static inline int gpio_add_callback_dt(const struct gpio_dt_spec *spec,
1818 struct gpio_callback *callback)
1819{
1820 return gpio_add_callback(spec->port, callback);
1821}
1822
1841static inline int gpio_remove_callback(const struct device *port,
1842 struct gpio_callback *callback)
1843{
1844 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, port);
1845 int ret;
1846
1847 SYS_PORT_TRACING_FUNC_ENTER(gpio, remove_callback, port, callback);
1848
1849 if (api->manage_callback == NULL) {
1850 SYS_PORT_TRACING_FUNC_EXIT(gpio, remove_callback, port, -ENOSYS);
1851 return -ENOSYS;
1852 }
1853
1854 ret = api->manage_callback(port, callback, false);
1855 SYS_PORT_TRACING_FUNC_EXIT(gpio, remove_callback, port, ret);
1856 return ret;
1857}
1858
1870static inline int gpio_remove_callback_dt(const struct gpio_dt_spec *spec,
1871 struct gpio_callback *callback)
1872{
1873 return gpio_remove_callback(spec->port, callback);
1874}
1875
1890__syscall int gpio_get_pending_int(const struct device *dev);
1891
1892static inline int z_impl_gpio_get_pending_int(const struct device *dev)
1893{
1894 const struct gpio_driver_api *api = DEVICE_API_GET(gpio, dev);
1895 int ret;
1896
1897 SYS_PORT_TRACING_FUNC_ENTER(gpio, get_pending_int, dev);
1898
1899 if (api->get_pending_int == NULL) {
1900 SYS_PORT_TRACING_FUNC_EXIT(gpio, get_pending_int, dev, -ENOSYS);
1901 return -ENOSYS;
1902 }
1903
1904 ret = api->get_pending_int(dev);
1905 SYS_PORT_TRACING_FUNC_EXIT(gpio, get_pending_int, dev, ret);
1906 return ret;
1907}
1908
1912
1913#ifdef __cplusplus
1914}
1915#endif
1916
1917#include <zephyr/syscalls/gpio.h>
1918
1919#endif /* ZEPHYR_INCLUDE_DRIVERS_GPIO_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1375
#define GPIO_INT_ENABLE_DISABLE_ONLY_VALUE
System error numbers.
bool device_is_ready(const struct device *dev)
Verify that a device is ready for use.
static int gpio_add_callback(const struct device *port, struct gpio_callback *callback)
Add an application callback.
Definition gpio.h:1788
#define GPIO_OUTPUT
Enables pin as output, no change to the output state.
Definition gpio.h:58
static int gpio_pin_get_raw(const struct device *port, gpio_pin_t pin)
Get physical level of an input pin.
Definition gpio.h:1558
int gpio_pin_get_config(const struct device *port, gpio_pin_t pin, gpio_flags_t *flags)
Get a configuration of a single pin.
static int gpio_pin_is_input(const struct device *port, gpio_pin_t pin)
Check if pin is configured for input.
Definition gpio.h:1126
static int gpio_pin_get(const struct device *port, gpio_pin_t pin)
Get logical level of an input pin.
Definition gpio.h:1595
int gpio_port_set_bits_raw(const struct device *port, gpio_port_pins_t pins)
Set physical level of selected output pins to high.
static int gpio_pin_is_output_dt(const struct gpio_dt_spec *spec)
Check if a single pin from gpio_dt_spec is configured for output.
Definition gpio.h:1199
static int gpio_pin_interrupt_configure_dt(const struct gpio_dt_spec *spec, gpio_flags_t flags)
Configure pin interrupts from a gpio_dt_spec.
Definition gpio.h:971
static int gpio_remove_callback_dt(const struct gpio_dt_spec *spec, struct gpio_callback *callback)
Remove an application callback.
Definition gpio.h:1870
static int gpio_pin_toggle_dt(const struct gpio_dt_spec *spec)
Toggle pin level from a gpio_dt_spec.
Definition gpio.h:1748
uint8_t gpio_pin_t
Provides a type to hold a GPIO pin index.
Definition gpio.h:262
static int gpio_pin_is_output(const struct device *port, gpio_pin_t pin)
Check if pin is configured for output.
Definition gpio.h:1171
int gpio_get_pending_int(const struct device *dev)
Function to get pending interrupts.
static int gpio_pin_configure_dt(const struct gpio_dt_spec *spec, gpio_flags_t extra_flags)
Configure a single pin from a gpio_dt_spec and some extra flags.
Definition gpio.h:1064
static int gpio_pin_set_dt(const struct gpio_dt_spec *spec, int value)
Set logical level of a output pin from a gpio_dt_spec.
Definition gpio.h:1712
static int gpio_add_callback_dt(const struct gpio_dt_spec *spec, struct gpio_callback *callback)
Add an application callback.
Definition gpio.h:1817
static int gpio_port_set_bits(const struct device *port, gpio_port_pins_t pins)
Set logical level of selected output pins to active.
Definition gpio.h:1429
uint32_t gpio_flags_t
Provides a type to hold GPIO configuration flags.
Definition gpio.h:282
#define GPIO_ACTIVE_LOW
GPIO pin is active (has logical value '1') in low state.
Definition gpio.h:24
#define GPIO_INT_WAKEUP
Configures GPIO interrupt to wakeup the system from low power mode.
Definition gpio.h:83
static int gpio_port_set_clr_bits_raw(const struct device *port, gpio_port_pins_t set_pins, gpio_port_pins_t clear_pins)
Set physical level of selected output pins.
Definition gpio.h:1514
static int gpio_port_set_clr_bits(const struct device *port, gpio_port_pins_t set_pins, gpio_port_pins_t clear_pins)
Set logical level of selected output pins.
Definition gpio.h:1534
static void gpio_init_callback(struct gpio_callback *callback, gpio_callback_handler_t handler, gpio_port_pins_t pin_mask)
Helper to initialize a struct gpio_callback properly.
Definition gpio.h:1759
static int gpio_pin_is_input_dt(const struct gpio_dt_spec *spec)
Check if a single pin from gpio_dt_spec is configured for input.
Definition gpio.h:1154
#define GPIO_INPUT
Enables pin as input.
Definition gpio.h:55
uint32_t gpio_port_pins_t
Identifies a set of pins associated with a port.
Definition gpio.h:241
static int gpio_pin_get_config_dt(const struct gpio_dt_spec *spec, gpio_flags_t *flags)
Get a configuration of a single pin from a gpio_dt_spec.
Definition gpio.h:1255
int gpio_port_toggle_bits(const struct device *port, gpio_port_pins_t pins)
Toggle level of selected output pins.
#define GPIO_INT_DISABLE
Disables GPIO pin interrupt.
Definition gpio.h:108
int gpio_pin_interrupt_configure(const struct device *port, gpio_pin_t pin, gpio_flags_t flags)
Configure pin interrupt.
int gpio_port_clear_bits_raw(const struct device *port, gpio_port_pins_t pins)
Set physical level of selected output pins to low.
int gpio_port_set_masked_raw(const struct device *port, gpio_port_pins_t mask, gpio_port_value_t value)
Set physical level of output pins in a port.
#define GPIO_PULL_UP
Enables GPIO pin pull-up.
Definition gpio.h:73
static int gpio_pin_get_dt(const struct gpio_dt_spec *spec)
Get logical level of an input pin from a gpio_dt_spec.
Definition gpio.h:1623
static int gpio_pin_toggle(const struct device *port, gpio_pin_t pin)
Toggle pin level.
Definition gpio.h:1727
static bool gpio_is_ready_dt(const struct gpio_dt_spec *spec)
Validate that GPIO port is ready.
Definition gpio.h:854
uint32_t gpio_port_value_t
Provides values for a set of pins associated with a port.
Definition gpio.h:254
static int gpio_pin_set(const struct device *port, gpio_pin_t pin, int value)
Set logical level of an output pin.
Definition gpio.h:1683
static int gpio_port_clear_bits(const struct device *port, gpio_port_pins_t pins)
Set logical level of selected output pins to inactive.
Definition gpio.h:1471
static int gpio_remove_callback(const struct device *port, struct gpio_callback *callback)
Remove an application callback.
Definition gpio.h:1841
static int gpio_port_set_masked(const struct device *port, gpio_port_pins_t mask, gpio_port_value_t value)
Set logical level of output pins in a port.
Definition gpio.h:1381
int gpio_port_get_direction(const struct device *port, gpio_port_pins_t map, gpio_port_pins_t *inputs, gpio_port_pins_t *outputs)
Get direction of select pins in a port.
uint16_t gpio_dt_flags_t
Provides a type to hold GPIO devicetree flags.
Definition gpio.h:274
#define GPIO_PULL_DOWN
Enable GPIO pin pull-down.
Definition gpio.h:76
static int gpio_pin_set_raw(const struct device *port, gpio_pin_t pin, int value)
Set physical level of an output pin.
Definition gpio.h:1643
int gpio_port_get_raw(const struct device *port, gpio_port_value_t *value)
Get physical level of all input pins in a port.
static int gpio_port_get(const struct device *port, gpio_port_value_t *value)
Get logical level of all input pins in a port.
Definition gpio.h:1311
int gpio_pin_configure(const struct device *port, gpio_pin_t pin, gpio_flags_t flags)
Configure a single pin.
void(* gpio_callback_handler_t)(const struct device *port, struct gpio_callback *cb, gpio_port_pins_t pins)
Define the application callback handler function signature.
Definition gpio.h:734
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:39
#define SYS_PORT_TRACING_FUNC_ENTER(type, func,...)
Tracing macro for the entry into a function that might or might not return a value.
Definition tracing_macros.h:257
#define SYS_PORT_TRACING_FUNC_EXIT(type, func,...)
Tracing macro for when a function ends its execution.
Definition tracing_macros.h:283
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define NULL
Definition iar_missing_defs.h:20
flags
Definition parser.h:97
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
void * data
Address of the device instance private data.
Definition device.h:523
const void * config
Address of device instance config information.
Definition device.h:517
GPIO callback structure.
Definition gpio.h:748
sys_snode_t node
This is meant to be used in the driver and the user should not mess with it (see drivers/gpio/gpio_ut...
Definition gpio.h:752
gpio_port_pins_t pin_mask
A mask of pins the callback is interested in, if 0 the callback will never be called.
Definition gpio.h:763
gpio_callback_handler_t handler
Actual callback function being called when relevant.
Definition gpio.h:755
This structure is common to all GPIO drivers and is expected to be the first element in the object po...
Definition gpio.h:698
gpio_port_pins_t port_pin_mask
Mask identifying pins supported by the controller.
Definition gpio.h:704
This structure is common to all GPIO drivers and is expected to be the first element in the driver's ...
Definition gpio.h:711
gpio_port_pins_t invert
Mask identifying pins that are configured as active low.
Definition gpio.h:717
Container for GPIO pin information specified in devicetree.
Definition gpio.h:296
const struct device * port
GPIO device controlling the pin.
Definition gpio.h:298
gpio_pin_t pin
The pin's number on the device.
Definition gpio.h:300
gpio_dt_flags_t dt_flags
The pin's configuration flags as specified in devicetree.
Definition gpio.h:302
Main header file for tracing subsystem API.