cc110x.h 3.31 KB
/*
 * 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.
 */

/**
 * @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 <kaspar@schleiser.de>
 */

#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;          /**< what */
    gpio_t cs;          /**< does */
    gpio_t gdo0;        /**< this */
    gpio_t gdo1;        /**< look */
    gpio_t gdo2;        /**< like */
} 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 */
/** @} */