131 lines
3.5 KiB
C
131 lines
3.5 KiB
C
|
/*
|
||
|
Copyright (c) 2007 Stefan Engelke <mbox@stefanengelke.de>
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person
|
||
|
obtaining a copy of this software and associated documentation
|
||
|
files (the "Software"), to deal in the Software without
|
||
|
restriction, including without limitation the rights to use, copy,
|
||
|
modify, merge, publish, distribute, sublicense, and/or sell copies
|
||
|
of the Software, and to permit persons to whom the Software is
|
||
|
furnished to do so, subject to the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be
|
||
|
included in all copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||
|
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||
|
DEALINGS IN THE SOFTWARE.
|
||
|
|
||
|
$Id$
|
||
|
*/
|
||
|
|
||
|
/* Memory Map */
|
||
|
#define CONFIG 0x00
|
||
|
#define EN_AA 0x01
|
||
|
#define EN_RXADDR 0x02
|
||
|
#define SETUP_AW 0x03
|
||
|
#define SETUP_RETR 0x04
|
||
|
#define RF_CH 0x05
|
||
|
#define RF_SETUP 0x06
|
||
|
#define STATUS 0x07
|
||
|
#define OBSERVE_TX 0x08
|
||
|
#define CD 0x09
|
||
|
#define RX_ADDR_P0 0x0A
|
||
|
#define RX_ADDR_P1 0x0B
|
||
|
#define RX_ADDR_P2 0x0C
|
||
|
#define RX_ADDR_P3 0x0D
|
||
|
#define RX_ADDR_P4 0x0E
|
||
|
#define RX_ADDR_P5 0x0F
|
||
|
#define TX_ADDR 0x10
|
||
|
#define RX_PW_P0 0x11
|
||
|
#define RX_PW_P1 0x12
|
||
|
#define RX_PW_P2 0x13
|
||
|
#define RX_PW_P3 0x14
|
||
|
#define RX_PW_P4 0x15
|
||
|
#define RX_PW_P5 0x16
|
||
|
#define FIFO_STATUS 0x17
|
||
|
#define DYNPD 0x1C
|
||
|
|
||
|
/* Bit Mnemonics */
|
||
|
|
||
|
/* configuratio nregister */
|
||
|
#define MASK_RX_DR 6
|
||
|
#define MASK_TX_DS 5
|
||
|
#define MASK_MAX_RT 4
|
||
|
#define EN_CRC 3
|
||
|
#define CRCO 2
|
||
|
#define PWR_UP 1
|
||
|
#define PRIM_RX 0
|
||
|
|
||
|
/* enable auto acknowledgment */
|
||
|
#define ENAA_P5 5
|
||
|
#define ENAA_P4 4
|
||
|
#define ENAA_P3 3
|
||
|
#define ENAA_P2 2
|
||
|
#define ENAA_P1 1
|
||
|
#define ENAA_P0 0
|
||
|
|
||
|
/* enable rx addresses */
|
||
|
#define ERX_P5 5
|
||
|
#define ERX_P4 4
|
||
|
#define ERX_P3 3
|
||
|
#define ERX_P2 2
|
||
|
#define ERX_P1 1
|
||
|
#define ERX_P0 0
|
||
|
|
||
|
/* setup of address width */
|
||
|
#define AW 0 /* 2 bits */
|
||
|
|
||
|
/* setup of auto re-transmission */
|
||
|
#define ARD 4 /* 4 bits */
|
||
|
#define ARC 0 /* 4 bits */
|
||
|
|
||
|
/* RF setup register */
|
||
|
#define PLL_LOCK 4
|
||
|
#define RF_DR 3
|
||
|
#define RF_PWR 1 /* 2 bits */
|
||
|
|
||
|
/* general status register */
|
||
|
#define RX_DR 6
|
||
|
#define TX_DS 5
|
||
|
#define MAX_RT 4
|
||
|
#define RX_P_NO 1 /* 3 bits */
|
||
|
#define TX_FULL 0
|
||
|
|
||
|
/* transmit observe register */
|
||
|
#define PLOS_CNT 4 /* 4 bits */
|
||
|
#define ARC_CNT 0 /* 4 bits */
|
||
|
|
||
|
/* fifo status */
|
||
|
#define TX_REUSE 6
|
||
|
#define FIFO_FULL 5
|
||
|
#define TX_EMPTY 4
|
||
|
#define RX_FULL 1
|
||
|
#define RX_EMPTY 0
|
||
|
|
||
|
/* dynamic length */
|
||
|
#define DPL_P0 0
|
||
|
#define DPL_P1 1
|
||
|
#define DPL_P2 2
|
||
|
#define DPL_P3 3
|
||
|
#define DPL_P4 4
|
||
|
#define DPL_P5 5
|
||
|
|
||
|
/* Instruction Mnemonics */
|
||
|
#define R_REGISTER 0x00 /* last 4 bits will indicate reg. address */
|
||
|
#define W_REGISTER 0x20 /* last 4 bits will indicate reg. address */
|
||
|
#define REGISTER_MASK 0x1F
|
||
|
#define R_RX_PAYLOAD 0x61
|
||
|
#define W_TX_PAYLOAD 0xA0
|
||
|
#define FLUSH_TX 0xE1
|
||
|
#define FLUSH_RX 0xE2
|
||
|
#define REUSE_TX_PL 0xE3
|
||
|
#define ACTIVATE 0x50
|
||
|
#define R_RX_PL_WID 0x60
|
||
|
#define NOP 0xFF
|