2015-04-23 18:36:55 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Alaeddine Weslati <alaeddine.weslati@inria.fr>
|
|
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-08-09 21:24:55 +02:00
|
|
|
* @ingroup drivers_at86rf2xx
|
2015-04-23 18:36:55 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Internal interfaces for AT86RF2xx drivers
|
|
|
|
*
|
|
|
|
* @author Alaeddine Weslati <alaeddine.weslati@inria.fr>
|
|
|
|
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2015-08-09 21:24:55 +02:00
|
|
|
#ifndef AT86RF2XX_INTERNAL_H_
|
|
|
|
#define AT86RF2XX_INTERNAL_H_
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2015-08-09 21:24:55 +02:00
|
|
|
#include "at86rf2xx.h"
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Read from a register at address `addr` from device `dev`.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
* @param[in] addr address of the register to read
|
|
|
|
*
|
|
|
|
* @return the value of the specified register
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
uint8_t at86rf2xx_reg_read(const at86rf2xx_t *dev, const uint8_t addr);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Write to a register at address `addr` from device `dev`.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] addr address of the register to write
|
|
|
|
* @param[in] value value to write to the given register
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_reg_write(const at86rf2xx_t *dev, const uint8_t addr,
|
|
|
|
const uint8_t value);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Read a chunk of data from the SRAM of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
* @param[in] offset starting address to read from [valid 0x00-0x7f]
|
|
|
|
* @param[out] data buffer to read data into
|
|
|
|
* @param[in] len number of bytes to read from SRAM
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_sram_read(const at86rf2xx_t *dev,
|
|
|
|
const uint8_t offset,
|
|
|
|
uint8_t *data,
|
|
|
|
const size_t len);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Write a chunk of data into the SRAM of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to write to
|
|
|
|
* @param[in] offset address in the SRAM to write to [valid 0x00-0x7f]
|
|
|
|
* @param[in] data data to copy into SRAM
|
|
|
|
* @param[in] len number of bytes to write to SRAM
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_sram_write(const at86rf2xx_t *dev,
|
|
|
|
const uint8_t offset,
|
|
|
|
const uint8_t *data,
|
|
|
|
const size_t len);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Read the internal frame buffer of the given device
|
|
|
|
*
|
|
|
|
* Reading the frame buffer returns some extra bytes that are not accessible
|
|
|
|
* through reading the RAM directly.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
* @param[out] data buffer to copy the data to
|
|
|
|
* @param[in] len number of bytes to read from the frame buffer
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
void at86rf2xx_fb_read(const at86rf2xx_t *dev,
|
|
|
|
uint8_t *data, const size_t len);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
2015-09-29 17:05:13 +02:00
|
|
|
/**
|
|
|
|
* @brief Cancel ongoing transactions and switch to TRX_OFF state
|
|
|
|
*
|
|
|
|
* @param[in] dev device to manipulate
|
|
|
|
*/
|
|
|
|
void at86rf2xx_force_trx_off(const at86rf2xx_t *dev);
|
|
|
|
|
2015-04-23 18:36:55 +02:00
|
|
|
/**
|
|
|
|
* @brief Convenience function for reading the status of the given device
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read the status from
|
|
|
|
*
|
|
|
|
* @return internal status of the given device
|
|
|
|
*/
|
2015-08-09 21:24:55 +02:00
|
|
|
uint8_t at86rf2xx_get_status(const at86rf2xx_t *dev);
|
2015-04-23 18:36:55 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-08-09 21:24:55 +02:00
|
|
|
#endif /* AT86RF2XX_INTERNAL_H_ */
|
2015-04-23 18:36:55 +02:00
|
|
|
/** @} */
|