2013-05-02 08:45:47 +02:00
|
|
|
/**
|
|
|
|
* cc2420.h - Definitions for CC2420 functions.
|
|
|
|
* Copyright (C) 2013 Milan Babel <babel@inf.fu-berlin.de>
|
2014-05-07 13:23:41 +02:00
|
|
|
* Copyright (C) 2014 Kévin Roussel <Kevin.Roussel@inria.fr>
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
2013-05-02 08:45:47 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup CC2420
|
|
|
|
* @{
|
|
|
|
* @file
|
|
|
|
* @brief Definitions for CC2420 functions
|
|
|
|
* @author Milan Babel <babel@inf.fu-berlin.de>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Definition of the cc2420 layer 0 protocol
|
|
|
|
* <pre>
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
| | | | | | | |
|
|
|
|
| Length | FCF | Seq No. |Address | PhySrc | Data | FCS |
|
|
|
|
| | | | | | | |
|
|
|
|
---------------------------------------------------------------------------
|
|
|
|
1 byte 2 bytes 1 byte 2/8 bytes 2/8 bytes <=118 bytes 2 bytes
|
|
|
|
|
|
|
|
A 5 byte SHR will be generated and added in hardware.
|
|
|
|
SHR contains a preable sequence and a start of delimiter,
|
|
|
|
|
|
|
|
Length does not contain SHR and Length,
|
|
|
|
first bit of length has to be 0 (length has only 7bit)
|
|
|
|
|
|
|
|
Address fields can be in total between 4 and 20 bytes
|
|
|
|
FCS contain a hardware generated CRC sum with the polynom x^16+x^12+x^5+1
|
|
|
|
When receiving a package FCS will be checked by hardware, the first FCS byte will be replaced by RSSI,
|
|
|
|
followed by a CRC OK bit and the unsigned 7 bit correlation value.
|
|
|
|
FCF:
|
2014-07-31 20:49:35 +02:00
|
|
|
Bit | Meaning
|
|
|
|
--------------------
|
|
|
|
0-2 | Frame Type
|
|
|
|
3 | Security Enabled
|
|
|
|
4 | Frame Pending
|
|
|
|
5 | Acknowledge request
|
|
|
|
6 | PAN ID Compression Field
|
|
|
|
7-9 | Reserved
|
|
|
|
10-11 | Destination addressing mode
|
|
|
|
12-13 | Reserved
|
|
|
|
14-15 | Source addressing mode
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
For the cc2420 bit 0 is the most right bit and bit 15 is the most left bit.
|
|
|
|
But the 2 FCF bytes have to be transmitted littel endian (byte 15 to 8 first than 7 to 0)
|
|
|
|
|
|
|
|
Addressing mode value:
|
|
|
|
|
|
|
|
Bit | Meaning
|
|
|
|
---------------------
|
|
|
|
00 | PAN identifier and address field are not present.
|
|
|
|
01 | Reserved.
|
|
|
|
10 | Address field contains a 16 bit short address.
|
|
|
|
11 | Address field contains a 64 bit extended address.
|
|
|
|
|
|
|
|
Frame type value:
|
|
|
|
|
|
|
|
Bit | Meaning
|
|
|
|
---------------------
|
|
|
|
000 | Beacon
|
|
|
|
001 | Data
|
|
|
|
010 | Acknowledgment
|
|
|
|
011 | MAC command
|
|
|
|
1xx | Reserved
|
|
|
|
</pre>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CC2420_H
|
|
|
|
#define CC2420_H
|
|
|
|
|
2014-03-25 14:27:00 +01:00
|
|
|
#include <stdbool.h>
|
|
|
|
|
2014-07-06 22:57:56 +02:00
|
|
|
#include "kernel_types.h"
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "ieee802154_frame.h"
|
|
|
|
#include "cc2420_settings.h"
|
2013-05-02 08:45:47 +02:00
|
|
|
|
2014-05-07 13:23:41 +02:00
|
|
|
#include "radio_driver.h"
|
2014-01-31 09:52:33 +01:00
|
|
|
|
2013-05-02 08:45:47 +02:00
|
|
|
#define CC2420_MAX_PKT_LENGTH 127
|
|
|
|
#define CC2420_MAX_DATA_LENGTH (118)
|
|
|
|
|
|
|
|
#define CC2420_BROADCAST_ADDRESS (0xFFFF)
|
|
|
|
|
|
|
|
#define CC2420_MAX_UID (0xFFFE)
|
|
|
|
#define CC2420_MIN_UID (0x0000)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Structure to represent a cc2420 packet.
|
|
|
|
*/
|
|
|
|
typedef struct __attribute__ ((packed)) {
|
2014-07-31 20:49:35 +02:00
|
|
|
/* @{ */
|
|
|
|
uint8_t length; /** < the length of the frame of the frame including fcs*/
|
2013-05-02 08:45:47 +02:00
|
|
|
ieee802154_frame_t frame; /** < the ieee802154 frame */
|
|
|
|
int8_t rssi; /** < the rssi value */
|
|
|
|
uint8_t lqi; /** < the link quality indicator */
|
2014-05-07 13:23:41 +02:00
|
|
|
bool crc; /** < 1 if crc was successfull, 0 otherwise */
|
2013-05-02 08:45:47 +02:00
|
|
|
/* @} */
|
|
|
|
} cc2420_packet_t;
|
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Initialize the CC2420 transceiver.
|
|
|
|
*/
|
|
|
|
void cc2420_initialize(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Init the CC2420 for use with RIOT's transceiver module.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @param[in] tpid The PID of the transceiver thread.
|
|
|
|
*/
|
|
|
|
|
2014-07-06 22:57:56 +02:00
|
|
|
void cc2420_init(kernel_pid_t tpid);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Turn CC2420 on.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* @return true if the radio was correctly turned on; false otherwise.
|
2013-05-02 08:45:47 +02:00
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
bool cc2420_on(void);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Turn CC2420 off.
|
|
|
|
*/
|
|
|
|
void cc2420_off(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Indicate if the CC2420 is on.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* @return true if the radio transceiver is on (active); false otherwise.
|
|
|
|
*/
|
|
|
|
bool cc2420_is_on(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Switches the CC2420 into receive mode.
|
2013-05-02 08:45:47 +02:00
|
|
|
*/
|
|
|
|
void cc2420_switch_to_rx(void);
|
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Turns monitor (promiscuous) mode on or off.
|
|
|
|
*
|
|
|
|
* @param[in] mode The desired mode:
|
|
|
|
* true for monitor (promiscuous) mode;
|
|
|
|
* false for normal (auto address-decoding) mode.
|
|
|
|
*/
|
|
|
|
void cc2420_set_monitor(bool mode);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Indicate if the CC2420 is in monitor (promiscuous) mode.
|
|
|
|
*
|
|
|
|
* @return true if the transceiver is in monitor (promiscuous) mode;
|
|
|
|
* false if it is in normal (auto address-decoding) mode.
|
|
|
|
*/
|
|
|
|
bool cc2420_get_monitor(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the channel of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @param[in] chan The desired channel, valid channels are from 11 to 26.
|
|
|
|
*
|
|
|
|
* @return The tuned channel after calling, or -1 on error.
|
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
int cc2420_set_channel(unsigned int chan);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Get the channel of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @return The tuned channel.
|
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
unsigned int cc2420_get_channel(void);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Sets the short address of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @param[in] addr The desired address.
|
|
|
|
*
|
|
|
|
* @return The set address after calling.
|
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
uint16_t cc2420_set_address(uint16_t addr);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Gets the current short address of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @return The current short address.
|
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
uint16_t cc2420_get_address(void);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Sets the IEEE long address of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @param[in] addr The desired address.
|
|
|
|
*
|
|
|
|
* @return The set address after calling.
|
|
|
|
*/
|
|
|
|
uint64_t cc2420_set_address_long(uint64_t addr);
|
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Gets the current IEEE long address of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @return The current IEEE long address.
|
|
|
|
*/
|
|
|
|
uint64_t cc2420_get_address_long(void);
|
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Sets the pan ID of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @param[in] pan The desired pan ID.
|
|
|
|
*
|
|
|
|
* @return The set pan ID after calling.
|
|
|
|
*/
|
|
|
|
uint16_t cc2420_set_pan(uint16_t pan);
|
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Gets the current IEEE long address of the CC2420.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
|
|
|
* @return The current IEEE long address.
|
|
|
|
*/
|
|
|
|
uint16_t cc2420_get_pan(void);
|
|
|
|
|
2014-05-07 13:23:41 +02:00
|
|
|
/**
|
|
|
|
* @brief Sets the output (TX) power of the CC2420.
|
|
|
|
*
|
|
|
|
* @param[in] pow The desired TX (output) power in dBm,
|
|
|
|
* valid values are -25 to 0; other values
|
|
|
|
* will be "saturated" into this range.
|
|
|
|
*
|
|
|
|
* @return The set TX (output) power after calling.
|
|
|
|
*/
|
|
|
|
int cc2420_set_tx_power(int pow);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Gets the current output (TX) power of the CC2420.
|
|
|
|
*
|
|
|
|
* @return The current TX (output) power.
|
|
|
|
*/
|
|
|
|
int cc2420_get_tx_power(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Checks if the radio medium is available/clear to send
|
|
|
|
* ("Clear Channel Assessment" a.k.a. CCA).
|
|
|
|
*
|
|
|
|
* @return a `true` value if radio medium is clear (available),
|
|
|
|
* a `false` value otherwise.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
bool cc2420_channel_clear(void);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Interrupt handler, gets fired when a RX overflow happens.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void cc2420_rxoverflow_irq(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Interrupt handler, gets fired when bytes in the RX FIFO are present.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void cc2420_rx_irq(void);
|
|
|
|
|
2014-05-07 13:23:41 +02:00
|
|
|
/**
|
|
|
|
* @brief Sets the function called back when a packet is received.
|
|
|
|
* (Low-level mechanism, parallel to the `transceiver` module).
|
|
|
|
*
|
|
|
|
* @param[in] recv_cb callback function for 802.15.4 packet arrival;
|
|
|
|
* pass `NULL` to deactivate packet reception.
|
|
|
|
*/
|
|
|
|
void cc2420_set_recv_callback(receive_802154_packet_callback_t recv_cb);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief RX handler, process data from the RX FIFO.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void cc2420_rx_handler(void);
|
|
|
|
|
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Prepare the CC2420 TX buffer to send with the given packet.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* @param[in] kind Kind of packet to transmit.
|
|
|
|
* @param[in] dest Address of the node to which the packet is sent.
|
|
|
|
* @param[in] use_long_addr `true` to use the 64-bit address mode
|
|
|
|
* with `dest` param; `false` to use
|
|
|
|
* "short" PAN-centric mode.
|
|
|
|
* @param[in] wants_ack `true` to request an acknowledgement
|
|
|
|
* from the receiving node for this packet;
|
|
|
|
* `false` otherwise.
|
|
|
|
* @param[in] buf Pointer to the buffer containing the payload
|
|
|
|
* of the 802.15.4 packet to transmit.
|
|
|
|
* The frame header (i.e.: FCS, sequence number,
|
|
|
|
* src and dest PAN and addresses) is inserted
|
|
|
|
* using values in accord with `kind` parameter
|
|
|
|
* and transceiver configuration.
|
|
|
|
* @param[in] len Length (in bytes) of the outgoing packet payload.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* @return `true` if the transceiver TX buffer was loaded correctly;
|
|
|
|
* `false` otherwise (transceiver error).
|
|
|
|
*/
|
|
|
|
radio_tx_status_t cc2420_load_tx_buf(ieee802154_packet_kind_t kind,
|
|
|
|
ieee802154_node_addr_t dest,
|
|
|
|
bool use_long_addr,
|
|
|
|
bool wants_ack,
|
|
|
|
void *buf,
|
|
|
|
unsigned int len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Transmit the data loaded into the CC2420 TX buffer.
|
2013-05-02 08:45:47 +02:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* @return The outcome of this packet's transmission.
|
|
|
|
* @see radio_tx_status_t
|
2013-05-02 08:45:47 +02:00
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
radio_tx_status_t cc2420_transmit_tx_buf(void);
|
2013-05-02 08:45:47 +02:00
|
|
|
|
2014-03-25 14:27:00 +01:00
|
|
|
/**
|
2014-05-07 13:23:41 +02:00
|
|
|
* @brief Transmit the given IEEE 802.15.4 packet,
|
|
|
|
* by calling successively functions`load_tx()`
|
|
|
|
* and `transmit()`.
|
|
|
|
*
|
|
|
|
* @param[in] kind Kind of packet to transmit.
|
|
|
|
* @param[in] dest Address of the node to which the packet is sent.
|
|
|
|
* @param[in] use_long_addr `true` to use the 64-bit address mode
|
|
|
|
* with `dest` param; `false` to use
|
|
|
|
* "short" PAN-centric mode.
|
|
|
|
* @param[in] wants_ack `true` to request an acknowledgement
|
|
|
|
* from the receiving node for this packet;
|
|
|
|
* `false` otherwise.
|
|
|
|
* @param[in] buf Pointer to the buffer containing the payload
|
|
|
|
* of the 802.15.4 packet to transmit.
|
|
|
|
* The frame header (i.e.: FCS, sequence number,
|
|
|
|
* src and dest PAN and addresses) is inserted
|
|
|
|
* using values in accord with `kind` parameter
|
|
|
|
* and transceiver configuration.
|
|
|
|
* @param[in] len Length (in bytes) of the outgoing packet payload.
|
|
|
|
*
|
|
|
|
* @return The outcome of this packet's transmission.
|
|
|
|
* @see radio_tx_status_t
|
|
|
|
*/
|
|
|
|
radio_tx_status_t cc2420_do_send(ieee802154_packet_kind_t kind,
|
|
|
|
ieee802154_node_addr_t dest,
|
|
|
|
bool use_long_addr,
|
|
|
|
bool wants_ack,
|
|
|
|
void *buf,
|
|
|
|
unsigned int len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Send function, sends a cc2420_packet_t over the air.
|
2014-03-25 14:27:00 +01:00
|
|
|
*
|
2014-05-07 13:23:41 +02:00
|
|
|
* @param[in] *packet The Packet which will be send.
|
|
|
|
*
|
|
|
|
* @return The count of bytes which are send or -1 on error
|
2014-03-25 14:27:00 +01:00
|
|
|
*
|
|
|
|
*/
|
2014-05-07 13:23:41 +02:00
|
|
|
int16_t cc2420_send(cc2420_packet_t *packet);
|
2014-03-25 14:27:00 +01:00
|
|
|
|
2013-05-02 08:45:47 +02:00
|
|
|
/**
|
|
|
|
* The PID of the transceiver thread.
|
|
|
|
*/
|
2014-07-06 22:57:56 +02:00
|
|
|
extern kernel_pid_t transceiver_pid;
|
2013-05-02 08:45:47 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* RX Packet Buffer, read from the transceiver, filled by the cc2420_rx_handler.
|
|
|
|
*/
|
|
|
|
extern cc2420_packet_t cc2420_rx_buffer[CC2420_RX_BUF_SIZE];
|
|
|
|
|
|
|
|
|
2014-05-07 13:23:41 +02:00
|
|
|
/** Utility macro: get CC2420's status byte */
|
|
|
|
#define cc2420_status_byte() cc2420_strobe(NOBYTE)
|
|
|
|
|
|
|
|
|
|
|
|
/* setter functions wrappers, to maintain compatibility with both
|
|
|
|
ieee802154_radio_driver_t and transceiver module */
|
|
|
|
|
|
|
|
static inline void do_set_channel(unsigned int chan) {
|
|
|
|
cc2420_set_channel(chan);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void do_set_address(uint16_t addr) {
|
|
|
|
cc2420_set_address(addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void do_set_long_address(uint64_t addr) {
|
|
|
|
cc2420_set_address_long(addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void do_set_pan_id(uint16_t pan) {
|
|
|
|
cc2420_set_pan(pan);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void do_set_tx_power(int pow) {
|
|
|
|
cc2420_set_tx_power(pow);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CC2420 low-level radio driver definition.
|
|
|
|
*/
|
|
|
|
extern const ieee802154_radio_driver_t cc2420_radio_driver;
|
|
|
|
|
|
|
|
|
2013-05-02 08:45:47 +02:00
|
|
|
#endif
|