2010-09-22 15:10:42 +02:00
|
|
|
/******************************************************************************
|
2013-08-16 10:20:23 +02:00
|
|
|
* Copyright 2008, Freie Universitaet Berlin (FUB). All rights reserved.
|
|
|
|
*
|
|
|
|
* These sources were developed at the Freie Universitaet Berlin, Computer Systems
|
2010-09-22 15:10:42 +02:00
|
|
|
and Telematics group (http://cst.mi.fu-berlin.de).
|
2013-08-16 10:20:23 +02:00
|
|
|
* ----------------------------------------------------------------------------
|
|
|
|
* This file is part of RIOT.
|
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* 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.
|
2013-08-16 10:20:23 +02:00
|
|
|
*
|
2010-09-22 15:10:42 +02:00
|
|
|
*******************************************************************************/
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @ingroup dev_cc110x
|
2010-09-22 15:10:42 +02:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief TI Chipcon CC110x public interface
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @author Thomas Hillebrandt <hillebra@inf.fu-berlin.de>
|
2010-09-22 15:10:42 +02:00
|
|
|
* @version $Revision: 2283 $
|
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @note $Id: cc1100-interface.h 2283 2010-06-15 14:02:27Z hillebra $
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CC1100INTERFACE_H_
|
|
|
|
#define CC1100INTERFACE_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "radio/radio.h"
|
|
|
|
|
2014-07-31 20:49:35 +02:00
|
|
|
#define CC1100_BROADCAST_ADDRESS (0x00) ///< CC1100 broadcast address
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-07-31 20:49:35 +02:00
|
|
|
#define MAX_UID (0xFF) ///< Maximum UID of a node is 255
|
|
|
|
#define MIN_UID (0x01) ///< Minimum UID of a node is 1
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-07-31 20:49:35 +02:00
|
|
|
#define MIN_CHANNR (0) ///< Minimum channel number
|
|
|
|
#define MAX_CHANNR (24) ///< Maximum channel number
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-07-31 20:49:35 +02:00
|
|
|
#define MIN_OUTPUT_POWER (0) ///< Minimum output power value
|
|
|
|
#define MAX_OUTPUT_POWER (11) ///< Maximum output power value
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-07-31 20:49:35 +02:00
|
|
|
#define CC1100_MODE_WOR (0) ///< Usable radio mode: Wake-On-Radio
|
|
|
|
#define CC1100_MODE_CONSTANT_RX (1) ///< Usable radio mode: Constant receive
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2012-03-01 22:12:25 +01:00
|
|
|
#define CC1100_MAX_DATA_LENGTH (58)
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
// Define default radio mode to constant RX if no
|
2014-02-10 15:28:55 +01:00
|
|
|
// application specific setting is available.
|
2010-09-22 15:10:42 +02:00
|
|
|
#ifndef CC1100_RADIO_MODE
|
2013-06-28 17:53:21 +02:00
|
|
|
#ifdef MODULE_RPL
|
|
|
|
#warning RPL currently works with CC1100_MODE_WOR
|
|
|
|
#endif
|
2013-06-21 22:36:48 +02:00
|
|
|
#define CC1100_RADIO_MODE CC1100_MODE_CONSTANT_RX
|
2010-09-22 15:10:42 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/// CC1100 radio interface
|
|
|
|
extern const radio_t radio_cc1100;
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Initialize radio layer.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* Initialize the radio layer, must be called before radio can be used.
|
|
|
|
*/
|
|
|
|
void cc1100_init(void);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Get the radio mode.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return Either CC1100_MODE_CONSTANT_RX or CC1100_MODE_WOR.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
uint8_t cc1100_get_mode(void);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Set the radio mode.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* Sets the radio mode with optional mode data. If the radio mode is WOR,
|
|
|
|
* the optional mode data is the RX interval in milliseconds. Must be called
|
|
|
|
* only after CC1100 is initialized.
|
|
|
|
*
|
|
|
|
* @param mode New radio mode (one of the constants defined in this file).
|
|
|
|
* @param opt_mode_data Desired RX interval in milliseconds [50..60000].
|
|
|
|
*
|
|
|
|
* @return true if mode could be applied; false otherwise (stays in previous mode).
|
|
|
|
*/
|
|
|
|
bool cc1100_set_mode(uint8_t mode, uint16_t opt_mode_data);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Get the average transmission duration (till ACK received).
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return The average transmission duration of one packet in milliseconds.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
int cc1100_get_avg_transmission_duration(void);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Get the radio address.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return The current address of the radio.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
radio_address_t cc1100_get_address(void);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Set the radio address.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param address The new radio address.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return true if address could be set; false otherwise.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
bool cc1100_set_address(radio_address_t address);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Get the current channel number.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return The current channel number used.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
uint8_t cc1100_get_channel(void);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Set the channel to use.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param channr The new channel number (between MIN_CHANNR and MAX_CHANNR) to use.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return true if channel could be set; false otherwise.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
bool cc1100_set_channel(uint8_t channr);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Set current output power in dBm.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param pa_idx New output power setting, valid values
|
2010-09-22 15:10:42 +02:00
|
|
|
* are from MIN_OUTPUT_POWER (lowest output power, -52 dBm)
|
|
|
|
* to MAX_OUTPUT_POWER (highest output power, +10 dBm).
|
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return true if output power could be set; false otherwise.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
bool cc1100_set_output_power(uint8_t pa_idx);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Set a packet monitor at this layer.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* All incoming packets will be passed to this packet monitor before
|
|
|
|
* packet gets processed by a specific handler. The work in the monitor
|
|
|
|
* should take as less time as possible (no waiting or intense I/O).
|
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param monitor The packet monitor or NULL if the current packet
|
2010-09-22 15:10:42 +02:00
|
|
|
* monitor should be removed.
|
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return true if this layer supports packet monitoring; false otherwise.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
bool cc1100_set_packet_monitor(packet_monitor_t monitor);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Set a packet handler for a given protocol.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param protocol The protocol identifier (3-bit value > 0, 1 reserved for LL-ACK).
|
|
|
|
* @param handler The packet handler called if a packet of given protocol is received.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return -1 if an error occurs (e.g. handler table full) else >= 0.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
int cc1100_set_packet_handler(protocol_t protocol, packet_handler_t handler);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Send data to given destination address with acknowledgment.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* The maximum payload length are 58 bytes!
|
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param addr The destination address.
|
|
|
|
* @param protocol The protocol identifier of the transmitted data.
|
|
|
|
* @param priority Ignored (always highest).
|
|
|
|
* @param payload The data to be send.
|
|
|
|
* @param payload_len The length of the data in bytes.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return A negative value if operation failed; if operation succeeded (ACK received) the number of transmitted bytes.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
2014-07-07 00:35:29 +02:00
|
|
|
int cc1100_send(radio_address_t addr, protocol_t protocol, int priority, char *payload, radio_packet_length_t payload_len);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Send data to given destination address with acknowledgment and CSMA/CA.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* The maximum payload length are 58 bytes!
|
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @param address The destination address.
|
|
|
|
* @param protocol The protocol identifier of the transmitted data.
|
|
|
|
* @param priority The MAC priority to send with. One of {PRIORITY_ALARM, PRIORITY_WARNING, PRIORITY_DATA}.
|
|
|
|
* @param payload The data to be send.
|
|
|
|
* @param payload_len The length of the data in bytes.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:49:35 +02:00
|
|
|
* @return A negative value if operation failed; if operation succeeded (ACK received) else the number of transmitted bytes.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
2014-07-07 00:35:29 +02:00
|
|
|
int cc1100_send_csmaca(radio_address_t address, protocol_t protocol, int priority, char *payload, radio_packet_length_t payload_len);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Print current radio configuration.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
void cc1100_print_config(void);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:49:35 +02:00
|
|
|
* @brief Print radio statistics.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
void cc1100_print_statistic(void);
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
#endif /* CC1100INTERFACE_H_ */
|