mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
157 lines
5.2 KiB
C
157 lines
5.2 KiB
C
|
/******************************************************************************
|
||
|
Copyright 2008, Freie Universitaet Berlin (FUB). All rights reserved.
|
||
|
|
||
|
These sources were developed at the Freie Universitaet Berlin, Computer Systems
|
||
|
and Telematics group (http://cst.mi.fu-berlin.de).
|
||
|
-------------------------------------------------------------------------------
|
||
|
This file is part of FeuerWare.
|
||
|
|
||
|
This program is free software: you can redistribute it and/or modify it under
|
||
|
the terms of the GNU General Public License as published by the Free Software
|
||
|
Foundation, either version 3 of the License, or (at your option) any later
|
||
|
version.
|
||
|
|
||
|
FeuerWare is distributed in the hope that it will be useful, but WITHOUT
|
||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License along with
|
||
|
this program. If not, see http://www.gnu.org/licenses/ .
|
||
|
--------------------------------------------------------------------------------
|
||
|
For further information and questions please use the web site
|
||
|
http://scatterweb.mi.fu-berlin.de
|
||
|
and the mailinglist (subscription via web site)
|
||
|
scatterweb@lists.spline.inf.fu-berlin.de
|
||
|
*******************************************************************************/
|
||
|
|
||
|
/**
|
||
|
* @ingroup dev_cc110x
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @file
|
||
|
* @internal
|
||
|
* @brief TI Chipcon CC110x physical radio driver
|
||
|
*
|
||
|
* @author Freie Universität Berlin, Computer Systems & Telematics, FeuerWhere project
|
||
|
* @author Thomas Hillebrandt <hillebra@inf.fu-berlin.de>
|
||
|
* @author Heiko Will <hwill@inf.fu-berlin.de>
|
||
|
* @version $Revision: 1285 $
|
||
|
*
|
||
|
* @note $Id: cc1100_phy.h 1285 2009-08-27 13:22:42Z hillebra $
|
||
|
*/
|
||
|
#ifndef CC1100_PHY_H_
|
||
|
#define CC1100_PHY_H_
|
||
|
|
||
|
#include <stdbool.h>
|
||
|
#include <stdint.h>
|
||
|
//#include "cc1100.h"
|
||
|
#include "cc1100-internal.h"
|
||
|
#include "cc1100-interface.h"
|
||
|
|
||
|
#define MAX_DATA_LENGTH (0x3A) ///< Maximum data length of layer 0 = 58 Bytes.
|
||
|
|
||
|
/**
|
||
|
* @brief CC1100 layer 0 protocol
|
||
|
*
|
||
|
* <pre>
|
||
|
---------------------------------------------------
|
||
|
| | | | | |
|
||
|
| Length | Address | PhySrc | Flags | Data |
|
||
|
| | | | | |
|
||
|
---------------------------------------------------
|
||
|
1 byte 1 byte 1 byte 1 byte <= 58 bytes
|
||
|
|
||
|
Flags:
|
||
|
Bit | Meaning
|
||
|
--------------------
|
||
|
7:4 | -
|
||
|
3:1 | Protocol
|
||
|
0 | Identification
|
||
|
</pre>
|
||
|
Notes:
|
||
|
\li length & address are given by CC1100
|
||
|
\li Identification is increased is used to scan duplicates. It must be increased
|
||
|
for each new packet and kept for packet retransmissions.
|
||
|
*/
|
||
|
typedef struct __attribute__ ((packed)) cc1100_packet_layer0_t
|
||
|
{
|
||
|
uint8_t length; ///< Length of the packet (without length byte)
|
||
|
uint8_t address; ///< Destination address
|
||
|
uint8_t phy_src; ///< Source address (physical source)
|
||
|
uint8_t flags; ///< Flags
|
||
|
uint8_t data[MAX_DATA_LENGTH]; ///< Data (high layer protocol)
|
||
|
} cc1100_packet_layer0_t;
|
||
|
|
||
|
typedef struct cc1100_wor_config_t
|
||
|
{
|
||
|
uint16_t rx_interval; ///< RX polling interval in milliseconds
|
||
|
float rx_time_ms; ///< WOR_RX_TIME in milliseconds
|
||
|
uint8_t rx_time_reg; ///< WOR_RX_TIME (CC1100 "MCSM2.RX_TIME" register value)
|
||
|
uint8_t wor_evt_0; ///< CC1100 WOREVT0 register value
|
||
|
uint8_t wor_evt_1; ///< CC1100 WOREVT1 register value
|
||
|
uint8_t wor_ctrl; ///< CC1100 WORCTRL register value
|
||
|
} cc1100_wor_config_t;
|
||
|
|
||
|
/*---------------------------------------------------------------------------*/
|
||
|
// CC1100 Wake-On-Radio configuration
|
||
|
/*---------------------------------------------------------------------------*/
|
||
|
|
||
|
extern uint16_t cc1100_burst_count;
|
||
|
extern uint8_t cc1100_retransmission_count_uc;
|
||
|
extern uint8_t cc1100_retransmission_count_bc;
|
||
|
extern cc1100_wor_config_t cc1100_wor_config;
|
||
|
|
||
|
/*---------------------------------------------------------------------------*/
|
||
|
// CC1100 physical radio driver API
|
||
|
/*---------------------------------------------------------------------------*/
|
||
|
|
||
|
/**
|
||
|
* @brief Initialize the physical radio layer.
|
||
|
*/
|
||
|
void cc1100_phy_init(void);
|
||
|
|
||
|
/**
|
||
|
* Lock radio for exclusive access. If no lock could be gained,
|
||
|
* the current process is blocked and waits for release of lock.
|
||
|
*
|
||
|
* This function can be used by MAC for locking the radio, the
|
||
|
* ::cc1100_send function will automatically lock the radio.
|
||
|
*/
|
||
|
void cc1100_phy_mutex_lock(void);
|
||
|
|
||
|
/**
|
||
|
* Unlock radio. Must always be called after ::cc1100_phy_mutex_lock.
|
||
|
* If ::cc1100_send is called, it will automatically unlock the radio
|
||
|
* at the end of transmission.
|
||
|
*/
|
||
|
void cc1100_phy_mutex_unlock(void);
|
||
|
|
||
|
/**
|
||
|
* @brief Calculate and store Wake-On-Radio settings.
|
||
|
*
|
||
|
* Calculates WOR settings for a given RX interval in
|
||
|
* milliseconds and stores the values in global configuration.
|
||
|
* <p>
|
||
|
* Does not change settings if not applicable.
|
||
|
*
|
||
|
* @param millis Desired RX interval in milliseconds [50..60000].
|
||
|
*
|
||
|
* @return The burst count (number of packets in a burst transfer)
|
||
|
* or -1 if an error occurred (e.g. RX interval invalid).
|
||
|
*/
|
||
|
int cc1100_phy_calc_wor_settings(uint16_t millis);
|
||
|
|
||
|
/**
|
||
|
* @brief Handler function for incoming packets.
|
||
|
*
|
||
|
* This handler function must be called in the receive
|
||
|
* interrupt service routine.
|
||
|
*/
|
||
|
void cc1100_phy_rx_handler(void);
|
||
|
|
||
|
/** @} */
|
||
|
|
||
|
#endif /* CC1100_PHY_H_ */
|