mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 10:32:44 +01:00
238 lines
5.2 KiB
C
238 lines
5.2 KiB
C
/*
|
|
* Copyright (C) 2016 Phytec Messtechnik GmbH
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup drivers_kw2xrf
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Internal function interfaces for kw2xrf driver
|
|
*
|
|
* @author Johann Fischer <j.fischer@phytec.de>
|
|
*/
|
|
|
|
#ifndef KW2XRF_INTERN_H
|
|
#define KW2XRF_INTERN_H
|
|
|
|
#include <stdint.h>
|
|
#include "kw2xrf.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Power Modes
|
|
*/
|
|
typedef enum {
|
|
KW2XRF_HIBERNATE = 0,
|
|
KW2XRF_DOZE,
|
|
KW2XRF_IDLE,
|
|
KW2XRF_AUTODOZE,
|
|
} kw2xrf_powermode_t;
|
|
|
|
/**
|
|
* @brief Set a certain bit of a kw2xrf register
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] reg address of register
|
|
* @param[in] bit set this bit
|
|
*/
|
|
static inline void kw2xrf_set_dreg_bit(kw2xrf_t *dev, uint8_t reg, uint8_t bit)
|
|
{
|
|
uint8_t tmp = kw2xrf_read_dreg(dev, reg);
|
|
tmp |= bit;
|
|
kw2xrf_write_dreg(dev, reg, tmp);
|
|
}
|
|
|
|
/**
|
|
* @brief Clear a certain bit of a kw2xrf register
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] reg address of register
|
|
* @param[in] bit set this bit
|
|
*/
|
|
static inline void kw2xrf_clear_dreg_bit(kw2xrf_t *dev, uint8_t reg, uint8_t bit)
|
|
{
|
|
uint8_t tmp = kw2xrf_read_dreg(dev, reg);
|
|
tmp &= ~bit;
|
|
kw2xrf_write_dreg(dev, reg, tmp);
|
|
}
|
|
|
|
/**
|
|
* @brief Enable any transceiver interrupt to assert IRQ_B
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
static inline void kw2xrf_enable_irq_b(kw2xrf_t *dev)
|
|
{
|
|
kw2xrf_clear_dreg_bit(dev, MKW2XDM_PHY_CTRL4, MKW2XDM_PHY_CTRL4_TRCV_MSK);
|
|
}
|
|
|
|
/**
|
|
* @brief Mask all transceiver interrupts to assert IRQ_B
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
static inline void kw2xrf_mask_irq_b(kw2xrf_t *dev)
|
|
{
|
|
kw2xrf_set_dreg_bit(dev, MKW2XDM_PHY_CTRL4, MKW2XDM_PHY_CTRL4_TRCV_MSK);
|
|
}
|
|
|
|
/**
|
|
* @brief Disable all interrupts on transceiver
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_disable_interrupts(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_update_overwrites(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_set_out_clk(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Set power mode for device
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] pm power mode value
|
|
*/
|
|
void kw2xrf_set_power_mode(kw2xrf_t *dev, kw2xrf_powermode_t pm);
|
|
|
|
/**
|
|
* @brief
|
|
*
|
|
* @param[in] dev
|
|
*
|
|
* @return
|
|
*/
|
|
int kw2xrf_can_switch_to_idle(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Timebase values
|
|
*/
|
|
typedef enum kw2xrf_timer_timebase {
|
|
KW2XRF_TIMEBASE_500000HZ = 2,
|
|
KW2XRF_TIMEBASE_250000HZ,
|
|
KW2XRF_TIMEBASE_125000HZ,
|
|
KW2XRF_TIMEBASE_62500HZ,
|
|
KW2XRF_TIMEBASE_31250HZ,
|
|
KW2XRF_TIMEBASE_15625HZ,
|
|
} kw2xrf_timer_timebase_t;
|
|
|
|
/**
|
|
* @brief Initialize the Event Timer Block (up counter)
|
|
*
|
|
* The Event Timer Block provides:
|
|
* - Abort an RX and CCA sequence at pre-determined time
|
|
* - Latches "timestamp" value during packet reception
|
|
* - Initiates timer-triggered sequences
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] tb timer base value
|
|
*/
|
|
void kw2xrf_timer_init(kw2xrf_t *dev, kw2xrf_timer_timebase_t tb);
|
|
|
|
/**
|
|
* @brief Enable start sequence time
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_timer2_seq_start_on(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Disable start sequence timer
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_timer2_seq_start_off(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Enable abort sequence timer
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_timer3_seq_abort_on(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Disable abort sequence timer
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_timer3_seq_abort_off(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Use T2CMP or T2PRIMECMP to Trigger Transceiver Operations
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] timeout timeout value
|
|
*/
|
|
void kw2xrf_trigger_tx_ops_enable(kw2xrf_t *dev, uint32_t timeout);
|
|
|
|
/**
|
|
* @brief Disable Trigger for Transceiver Operations
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_trigger_tx_ops_disable(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Use T3CMP to Abort an RX operation
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] timeout timeout value
|
|
*/
|
|
void kw2xrf_abort_rx_ops_enable(kw2xrf_t *dev, uint32_t timeout);
|
|
|
|
/**
|
|
* @brief Disable Trigger to Abort an RX operation
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_abort_rx_ops_disable(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Enable sequence timeout
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
* @param[in] timeout timeout value
|
|
*/
|
|
void kw2xrf_seq_timeout_on(kw2xrf_t *dev, uint32_t timeout);
|
|
|
|
/**
|
|
* @brief Disable sequence timeout
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*/
|
|
void kw2xrf_seq_timeout_off(kw2xrf_t *dev);
|
|
|
|
/**
|
|
* @brief Returns Timestamp of the actual received packet
|
|
*
|
|
* @param[in] dev kw2xrf device descriptor
|
|
*
|
|
* @return timestamp value
|
|
*/
|
|
uint32_t kw2xrf_get_timestamp(kw2xrf_t *dev);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* KW2XRF_INTERN_H */
|
|
/** @} */
|