Created
April 30, 2014 01:11
-
-
Save amcjen/8264b056c88b765307ee to your computer and use it in GitHub Desktop.
at86rf212.h
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* \file at86rf212.h | |
* | |
* \brief AT86RF212 registers description and interface | |
* | |
* Copyright (C) 2012 Atmel Corporation. All rights reserved. | |
* | |
* \asf_license_start | |
* | |
* Redistribution and use in source and binary forms, with or without | |
* modification, are permitted provided that the following conditions are met: | |
* | |
* 1. Redistributions of source code must retain the above copyright notice, | |
* this list of conditions and the following disclaimer. | |
* | |
* 2. Redistributions in binary form must reproduce the above copyright notice, | |
* this list of conditions and the following disclaimer in the documentation | |
* and/or other materials provided with the distribution. | |
* | |
* 3. The name of Atmel may not be used to endorse or promote products derived | |
* from this software without specific prior written permission. | |
* | |
* 4. This software may only be redistributed and used in connection with an | |
* Atmel microcontroller product. | |
* | |
* THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED | |
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE | |
* EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR | |
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | |
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN | |
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |
* POSSIBILITY OF SUCH DAMAGE. | |
* | |
* \asf_license_stop | |
* | |
* $Id: at86rf212.h 5223 2012-09-10 16:47:17Z ataradov $ | |
* | |
*/ | |
#ifndef _AT86RF212_H_ | |
#define _AT86RF212_H_ | |
#include <stdint.h> | |
#include <stdbool.h> | |
#include "halPhy.h" | |
/***************************************************************************** | |
*****************************************************************************/ | |
#define AES_BLOCK_SIZE 16 | |
#define AES_CORE_CYCLE_TIME 24 // us | |
/***************************************************************************** | |
*****************************************************************************/ | |
enum | |
{ | |
TRAC_STATUS_SUCCESS = 0, | |
TRAC_STATUS_SUCCESS_DATA_PENDING = 1, | |
TRAC_STATUS_SUCCESS_WAIT_FOR_ACK = 2, | |
TRAC_STATUS_CHANNEL_ACCESS_FAILURE = 3, | |
TRAC_STATUS_NO_ACK = 5, | |
TRAC_STATUS_INVALID = 7, | |
}; | |
enum | |
{ | |
TRX_STATUS_REG = 0x01, | |
TRX_STATE_REG = 0x02, | |
TRX_CTRL_0_REG = 0x03, | |
TRX_CTRL_1_REG = 0x04, | |
PHY_TX_PWR_REG = 0x05, | |
PHY_RSSI_REG = 0x06, | |
PHY_ED_LEVEL_REG = 0x07, | |
PHY_CC_CCA_REG = 0x08, | |
CCA_THRESH_REG = 0x09, | |
TRX_CTRL_2_REG = 0x0c, | |
ANT_DIV_REG = 0x0d, | |
IRQ_MASK_REG = 0x0e, | |
IRQ_STATUS_REG = 0x0f, | |
VREG_CTRL_REG = 0x10, | |
BATMON_REG = 0x11, | |
XOSC_CTRL_REG = 0x12, | |
CC_CTRL_0_REG = 0x13, | |
CC_CTRL_1_REG = 0x14, | |
RX_SYN_REG = 0x15, | |
RF_CTRL_0_REG = 0x16, | |
XAH_CTRL_1_REG = 0x17, | |
FTN_CTRL_REG = 0x18, | |
RF_CTRL_1_REG = 0x19, | |
PLL_CF_REG = 0x1a, | |
PLL_DCU_REG = 0x1b, | |
PART_NUM_REG = 0x1c, | |
VERSION_NUM_REG = 0x1d, | |
MAN_ID_0_REG = 0x1e, | |
MAN_ID_1_REG = 0x1f, | |
SHORT_ADDR_0_REG = 0x20, | |
SHORT_ADDR_1_REG = 0x21, | |
PAN_ID_0_REG = 0x22, | |
PAN_ID_1_REG = 0x23, | |
IEEE_ADDR_0_REG = 0x24, | |
IEEE_ADDR_1_REG = 0x25, | |
IEEE_ADDR_2_REG = 0x26, | |
IEEE_ADDR_3_REG = 0x27, | |
IEEE_ADDR_4_REG = 0x28, | |
IEEE_ADDR_5_REG = 0x29, | |
IEEE_ADDR_6_REG = 0x2a, | |
IEEE_ADDR_7_REG = 0x2b, | |
CSMA_SEED_0_REG = 0x2d, | |
CSMA_SEED_1_REG = 0x2e, | |
CSMA_BE_REG = 0x2f, | |
AES_STATUS_REG = 0x82, | |
AES_CTRL_REG = 0x83, | |
AES_KEY_REG = 0x84, | |
AES_STATE_REG = 0x84, | |
AES_CTRL_MIRROR_REG = 0x94, | |
}; | |
enum | |
{ | |
RF_CMD_REG_W = ((1<<7) | (1<<6)), | |
RF_CMD_REG_R = ((1<<7) | (0<<6)), | |
RF_CMD_FRAME_W = ((0<<7) | (1<<6) | (1<<5)), | |
RF_CMD_FRAME_R = ((0<<7) | (0<<6) | (1<<5)), | |
RF_CMD_SRAM_W = ((0<<7) | (1<<6) | (0<<5)), | |
RF_CMD_SRAM_R = ((0<<7) | (0<<6) | (0<<5)), | |
}; | |
enum | |
{ | |
TRX_CMD_NOP = 0, | |
TRX_CMD_TX_START = 2, | |
TRX_CMD_FORCE_TRX_OFF = 3, | |
TRX_CMD_FORCE_PLL_ON = 4, | |
TRX_CMD_RX_ON = 6, | |
TRX_CMD_TRX_OFF = 8, | |
TRX_CMD_PLL_ON = 9, | |
TRX_CMD_RX_AACK_ON = 22, | |
TRX_CMD_TX_ARET_ON = 25, | |
}; | |
enum | |
{ | |
TRX_STATUS_P_ON = 0, | |
TRX_STATUS_BUSY_RX = 1, | |
TRX_STATUS_BUSY_TX = 2, | |
TRX_STATUS_RX_ON = 6, | |
TRX_STATUS_TRX_OFF = 8, | |
TRX_STATUS_PLL_ON = 9, | |
TRX_STATUS_SLEEP = 15, | |
TRX_STATUS_BUSY_RX_AACK = 17, | |
TRX_STATUS_BUSY_TX_ARET = 18, | |
TRX_STATUS_RX_AACK_ON = 22, | |
TRX_STATUS_TX_ARET_ON = 25, | |
TRX_STATUS_RX_ON_NOCLK = 28, | |
TRX_STATUS_RX_AACK_ON_NOCLK = 29, | |
TRX_STATUS_BUSY_RX_AACK_NOCLK = 30, | |
TRX_STATUS_STATE_TRANSITION_IN_PROGRESS = 31, | |
TRX_STATUS_TRX_STATUS_MASK = 0x1f, | |
}; | |
enum | |
{ | |
PLL_LOCK_MASK = (1 << 0), | |
PLL_UNLOCK_MASK = (1 << 1), | |
RX_START_MASK = (1 << 2), | |
TRX_END_MASK = (1 << 3), | |
CCA_ED_DONE_MASK = (1 << 4), | |
TRX_UR_MASK = (1 << 6), | |
BAT_LOW_MASK = (1 << 7), | |
}; | |
enum | |
{ | |
AES_CTRL_DIR = 3, | |
AES_CTRL_MODE = 4, | |
AES_CTRL_REQUEST = 7, | |
}; | |
enum | |
{ | |
AES_STATUS_DONE = 0, | |
AES_STATUS_ER = 7, | |
}; | |
typedef enum PHY_State_t | |
{ | |
PHY_STATE_INITIAL, | |
PHY_STATE_IDLE, | |
PHY_STATE_SLEEP, | |
PHY_STATE_TX_WAIT_END, | |
PHY_STATE_TX_CONFIRM, | |
PHY_STATE_RX_IND, | |
PHY_STATE_ED_WAIT, | |
PHY_STATE_ED_DONE, | |
} PHY_State_t; | |
/***************************************************************************** | |
*****************************************************************************/ | |
extern volatile PHY_State_t phyState; | |
extern volatile uint8_t phyTxStatus; | |
extern volatile int8_t phyRxRssi; | |
/***************************************************************************** | |
*****************************************************************************/ | |
INLINE void phyWriteRegisterInline(uint8_t reg, uint8_t value) | |
{ | |
HAL_PhySpiSelect(); | |
HAL_PhySpiWriteByteInline(RF_CMD_REG_W | reg); | |
HAL_PhySpiWriteByteInline(value); | |
HAL_PhySpiDeselect(); | |
} | |
/***************************************************************************** | |
*****************************************************************************/ | |
INLINE uint8_t phyReadRegisterInline(uint8_t reg) | |
{ | |
uint8_t value; | |
HAL_PhySpiSelect(); | |
HAL_PhySpiWriteByteInline(RF_CMD_REG_R | reg); | |
value = HAL_PhySpiWriteByteInline(0); | |
HAL_PhySpiDeselect(); | |
return value; | |
} | |
/***************************************************************************** | |
*****************************************************************************/ | |
INLINE void phyInterruptHandler(void) | |
{ | |
uint8_t irq; | |
irq = phyReadRegisterInline(IRQ_STATUS_REG); | |
if (0 == (irq & (TRX_END_MASK | CCA_ED_DONE_MASK))) | |
return; | |
if (PHY_STATE_TX_WAIT_END == phyState) | |
{ | |
phyWriteRegisterInline(TRX_STATE_REG, TRX_CMD_PLL_ON); | |
phyTxStatus = (phyReadRegisterInline(TRX_STATE_REG) >> 5) & 0x07; | |
phyState = PHY_STATE_TX_CONFIRM; | |
} | |
else if (PHY_STATE_IDLE == phyState) | |
{ | |
phyWriteRegisterInline(TRX_STATE_REG, TRX_CMD_PLL_ON); | |
phyRxRssi = (int8_t)phyReadRegisterInline(PHY_ED_LEVEL_REG); | |
phyState = PHY_STATE_RX_IND; | |
} | |
#ifdef PHY_ENABLE_ENERGY_DETECTION | |
else if (PHY_STATE_ED_WAIT == phyState) | |
{ | |
phyRxRssi = (int8_t)phyReadRegisterInline(PHY_ED_LEVEL_REG); | |
phyState = PHY_STATE_ED_DONE; | |
} | |
#endif | |
} | |
#endif // _AT86RF212_H_ |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment