2015-08-26 10:21:26 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
* 2015 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-07-02 23:21:36 +02:00
|
|
|
* @defgroup drivers_cc110x CC1100/CC1101 radio driver
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_netdev
|
2017-07-02 23:21:36 +02:00
|
|
|
* @brief Driver for TI CC1100/CC1101 radios
|
2015-08-26 10:21:26 +02:00
|
|
|
* @{
|
|
|
|
* @file
|
|
|
|
* @brief Public interface for cc110x driver
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CC110X_H
|
|
|
|
#define CC110X_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "periph/spi.h"
|
|
|
|
#include "periph/gpio.h"
|
2015-11-19 16:37:16 +01:00
|
|
|
#include "cc110x-internal.h"
|
2015-10-31 11:20:26 +01:00
|
|
|
#include "net/gnrc/nettype.h"
|
2015-08-26 10:21:26 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Struct for holding cc110x IO parameters
|
2015-08-26 10:21:26 +02:00
|
|
|
*/
|
|
|
|
typedef struct cc110x_params {
|
|
|
|
spi_t spi; /**< what */
|
|
|
|
gpio_t cs; /**< does */
|
|
|
|
gpio_t gdo0; /**< this */
|
|
|
|
gpio_t gdo1; /**< look */
|
|
|
|
gpio_t gdo2; /**< like */
|
|
|
|
} cc110x_params_t;
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Forward declaration
|
2015-08-26 10:21:26 +02:00
|
|
|
*/
|
|
|
|
typedef struct cc110x cc110x_t;
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Struct for holding cc110x device state
|
2015-08-26 10:21:26 +02:00
|
|
|
*/
|
|
|
|
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 */
|
2015-10-31 11:20:26 +01:00
|
|
|
#ifdef MODULE_GNRC_NETIF
|
|
|
|
gnrc_nettype_t proto; /**< protocol the radio expects */
|
|
|
|
#endif
|
2015-08-26 10:21:26 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Setup cc110x device parameters
|
2015-08-26 10:21:26 +02:00
|
|
|
*
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Set cc110x channel number
|
2015-08-26 10:21:26 +02:00
|
|
|
*
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Send raw cc110x packet
|
2015-08-26 10:21:26 +02:00
|
|
|
*
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Set cc110x radio address
|
2015-08-26 10:21:26 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev device to query
|
|
|
|
*
|
|
|
|
* @return nr of currently set address
|
|
|
|
*/
|
|
|
|
uint8_t cc110x_get_address(cc110x_t *dev);
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Set cc110x radio address
|
2015-08-26 10:21:26 +02:00
|
|
|
*
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Set cc110x monitor mode setting
|
2015-08-26 10:21:26 +02:00
|
|
|
*
|
|
|
|
* @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 */
|
|
|
|
/** @} */
|