/* * Copyright (C) 2014 Freie Universität Berlin * 2015 Kaspar Schleiser * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @defgroup drivers_cc110x CC1100/CC1101 radio driver * @ingroup drivers_netdev * @brief Driver for TI CC1100/CC1101 radios * @{ * @file * @brief Public interface for cc110x driver * @author Kaspar Schleiser */ #ifndef CC110X_H #define CC110X_H #ifdef __cplusplus extern "C" { #endif #include "periph/spi.h" #include "periph/gpio.h" #include "cc110x-internal.h" #include "net/gnrc/nettype.h" /** * @brief Struct for holding cc110x IO parameters */ typedef struct cc110x_params { spi_t spi; /**< SPI bus the CC110x is connected to */ gpio_t cs; /**< GPIO connected to the chip select pin of the CC110x */ gpio_t gdo0; /**< GPIO connected to the GDO0 pin of the CC110x */ gpio_t gdo1; /**< GPIO connected to the GDO1 pin of the CC110x */ gpio_t gdo2; /**< GPIO connected to the GDO2 pin of the CC110x */ } cc110x_params_t; /** * @brief Forward declaration */ typedef struct cc110x cc110x_t; /** * @brief Struct for holding cc110x device state */ struct cc110x { cc110x_params_t params; /**< cc110x IO configuration */ cc110x_statistic_t cc110x_statistic; /**< Statistic values for debugging */ uint8_t radio_state; /**< Radio state */ uint8_t radio_channel; /**< current Radio channel */ uint8_t radio_address; /**< current Radio address */ cc110x_pkt_buf_t pkt_buf; /**< RX/TX buffer */ void (*isr_cb)(cc110x_t *dev, void* arg); /**< isr callback */ void *isr_cb_arg; /**< isr callback argument */ #ifdef MODULE_GNRC_NETIF gnrc_nettype_t proto; /**< protocol the radio expects */ #endif }; /** * @brief Setup cc110x device parameters * * @param[in] dev device struct to set up * @param[in] params struct holding parameters * * @return always succeeds */ int cc110x_setup(cc110x_t *dev, const cc110x_params_t *params); /** * @brief Set cc110x channel number * * @param[in] dev device to work on * @param[in] channr guess what * * @return nr of set channel on success * @return -1 on error */ int16_t cc110x_set_channel(cc110x_t *dev, uint8_t channr); /** * @brief Send raw cc110x packet * * @param[in] dev Device to send on * @param[in] packet ptr to packet to be sent * * @return size of packet on success * @return <0 on error */ int cc110x_send(cc110x_t *dev, cc110x_pkt_t *packet); /** * @brief Set cc110x radio address * * @param[in] dev device to query * * @return nr of currently set address */ uint8_t cc110x_get_address(cc110x_t *dev); /** * @brief Set cc110x radio address * * @param[in] dev device to work on * @param[in] address new address * * @return address set on success * @return 0 on error */ uint8_t cc110x_set_address(cc110x_t *dev, uint8_t address); /** * @brief Set cc110x monitor mode setting * * @param[in] dev device to work on * @param[in] mode mode to set (0 or 1) */ void cc110x_set_monitor(cc110x_t *dev, uint8_t mode); #ifdef __cplusplus } #endif #endif /* CC110X_H */ /** @} */