/* * Copyright (c) 2015 Intel Corporation * * SPDX-License-Identifier: Apache-2.0 */ #include #include "board.h" #include #include #include #if defined(CONFIG_IEEE802154_CC2520_LEGACY) || \ defined(CONFIG_IEEE802154_CC2520) || \ defined(CONFIG_IEEE802154_CC2520_RAW) #include #include static struct cc2520_gpio_configuration cc2520_gpios[CC2520_GPIO_IDX_MAX] = { { .dev = NULL, .pin = CC2520_GPIO_VREG_EN, }, { .dev = NULL, .pin = CC2520_GPIO_RESET, }, { .dev = NULL, .pin = CC2520_GPIO_FIFO, }, { .dev = NULL, .pin = CC2520_GPIO_CCA, }, { .dev = NULL, .pin = CC2520_GPIO_SFD, }, { .dev = NULL, .pin = CC2520_GPIO_FIFOP, }, }; struct cc2520_gpio_configuration *cc2520_configure_gpios(void) { const int flags_noint_out = GPIO_DIR_OUT; const int flags_noint_in = GPIO_DIR_IN; const int flags_int_in = (GPIO_DIR_IN | GPIO_INT | GPIO_INT_EDGE | GPIO_INT_ACTIVE_HIGH | GPIO_INT_DEBOUNCE); struct device *gpio; gpio = device_get_binding(CONFIG_IEEE802154_CC2520_GPIO_1_NAME); gpio_pin_configure(gpio, cc2520_gpios[CC2520_GPIO_IDX_VREG_EN].pin, flags_noint_out); gpio_pin_configure(gpio, cc2520_gpios[CC2520_GPIO_IDX_RESET].pin, flags_noint_out); cc2520_gpios[CC2520_GPIO_IDX_VREG_EN].dev = gpio; cc2520_gpios[CC2520_GPIO_IDX_RESET].dev = gpio; gpio = device_get_binding(CONFIG_IEEE802154_CC2520_GPIO_0_NAME); gpio_pin_configure(gpio, cc2520_gpios[CC2520_GPIO_IDX_SFD].pin, flags_int_in); gpio_pin_configure(gpio, cc2520_gpios[CC2520_GPIO_IDX_FIFOP].pin, flags_int_in); gpio_pin_configure(gpio, cc2520_gpios[CC2520_GPIO_IDX_FIFO].pin, flags_noint_in); gpio_pin_configure(gpio, cc2520_gpios[CC2520_GPIO_IDX_CCA].pin, flags_noint_in); cc2520_gpios[CC2520_GPIO_IDX_FIFOP].dev = gpio; cc2520_gpios[CC2520_GPIO_IDX_FIFO].dev = gpio; cc2520_gpios[CC2520_GPIO_IDX_SFD].dev = gpio; cc2520_gpios[CC2520_GPIO_IDX_CCA].dev = gpio; return cc2520_gpios; } #endif /* CONFIG_IEEE802154_CC2520_LEGACY || CONFIG_IEEE802154_CC2520 || * CONFIG_IEEE802154_CC2520_RAW */