131 lines
3.7 KiB
C
131 lines
3.7 KiB
C
|
/* ieee802154_cc1200.h - Registers definition for TI CC1200 */
|
||
|
|
||
|
/*
|
||
|
* Copyright (c) 2017 Intel Corporation.
|
||
|
*
|
||
|
* SPDX-License-Identifier: Apache-2.0
|
||
|
*/
|
||
|
|
||
|
#ifndef __IEEE802154_CC1200_H__
|
||
|
#define __IEEE802154_CC1200_H__
|
||
|
|
||
|
#include <linker/sections.h>
|
||
|
#include <atomic.h>
|
||
|
#include <spi.h>
|
||
|
|
||
|
#include <ieee802154/cc1200.h>
|
||
|
|
||
|
/* Runtime context structure
|
||
|
***************************
|
||
|
*/
|
||
|
|
||
|
struct cc1200_context {
|
||
|
struct net_if *iface;
|
||
|
/**************************/
|
||
|
struct cc1200_gpio_configuration *gpios;
|
||
|
struct gpio_callback rx_tx_cb;
|
||
|
struct spi_config spi;
|
||
|
u8_t mac_addr[8];
|
||
|
/************RF************/
|
||
|
const struct cc1200_rf_registers_set *rf_settings;
|
||
|
/************TX************/
|
||
|
struct k_sem tx_sync;
|
||
|
atomic_t tx;
|
||
|
atomic_t tx_start;
|
||
|
/************RX************/
|
||
|
K_THREAD_STACK_MEMBER(rx_stack,
|
||
|
CONFIG_IEEE802154_CC1200_RX_STACK_SIZE);
|
||
|
struct k_thread rx_thread;
|
||
|
struct k_sem rx_lock;
|
||
|
atomic_t rx;
|
||
|
};
|
||
|
|
||
|
#include "ieee802154_cc1200_regs.h"
|
||
|
|
||
|
/* Registers useful routines
|
||
|
***************************
|
||
|
*/
|
||
|
|
||
|
bool _cc1200_access_reg(struct spi_config *spi, bool read, u8_t addr,
|
||
|
void *data, size_t length, bool extended, bool burst);
|
||
|
|
||
|
static inline u8_t _cc1200_read_single_reg(struct spi_config *spi,
|
||
|
u8_t addr, bool extended)
|
||
|
{
|
||
|
u8_t val;
|
||
|
|
||
|
if (_cc1200_access_reg(spi, true, addr, &val, 1, extended, false)) {
|
||
|
return val;
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static inline bool _cc1200_write_single_reg(struct spi_config *spi,
|
||
|
u8_t addr, u8_t val, bool extended)
|
||
|
{
|
||
|
return _cc1200_access_reg(spi, false, addr, &val, 1, extended, false);
|
||
|
}
|
||
|
|
||
|
static inline bool _cc1200_instruct(struct spi_config *spi, u8_t addr)
|
||
|
{
|
||
|
return _cc1200_access_reg(spi, false, addr, NULL, 0, false, false);
|
||
|
}
|
||
|
|
||
|
#define DEFINE_REG_READ(__reg_name, __reg_addr, __ext) \
|
||
|
static inline u8_t read_reg_##__reg_name(struct spi_config *spi) \
|
||
|
{ \
|
||
|
/*SYS_LOG_DBG("");*/ \
|
||
|
return _cc1200_read_single_reg(spi, __reg_addr, __ext); \
|
||
|
}
|
||
|
|
||
|
#define DEFINE_REG_WRITE(__reg_name, __reg_addr, __ext) \
|
||
|
static inline bool write_reg_##__reg_name(struct spi_config *spi, \
|
||
|
u8_t val) \
|
||
|
{ \
|
||
|
/*SYS_LOG_DBG("");*/ \
|
||
|
return _cc1200_write_single_reg(spi, __reg_addr, \
|
||
|
val, __ext); \
|
||
|
}
|
||
|
|
||
|
DEFINE_REG_WRITE(iocfg3, CC1200_REG_IOCFG3, false)
|
||
|
DEFINE_REG_WRITE(iocfg2, CC1200_REG_IOCFG2, false)
|
||
|
DEFINE_REG_WRITE(iocfg0, CC1200_REG_IOCFG0, false)
|
||
|
DEFINE_REG_WRITE(pa_cfg1, CC1200_REG_PA_CFG1, false)
|
||
|
DEFINE_REG_WRITE(pkt_len, CC1200_REG_PKT_LEN, false)
|
||
|
|
||
|
DEFINE_REG_READ(fs_cfg, CC1200_REG_FS_CFG, false)
|
||
|
DEFINE_REG_READ(rssi0, CC1200_REG_RSSI0, true)
|
||
|
DEFINE_REG_READ(pa_cfg1, CC1200_REG_PA_CFG1, false)
|
||
|
DEFINE_REG_READ(num_txbytes, CC1200_REG_NUM_TXBYTES, true)
|
||
|
DEFINE_REG_READ(num_rxbytes, CC1200_REG_NUM_RXBYTES, true)
|
||
|
|
||
|
|
||
|
/* Instructions useful routines
|
||
|
******************************
|
||
|
*/
|
||
|
|
||
|
#define DEFINE_STROBE_INSTRUCTION(__ins_name, __ins_addr) \
|
||
|
static inline bool instruct_##__ins_name(struct spi_config *spi) \
|
||
|
{ \
|
||
|
/*SYS_LOG_DBG("");*/ \
|
||
|
return _cc1200_instruct(spi, __ins_addr); \
|
||
|
}
|
||
|
|
||
|
DEFINE_STROBE_INSTRUCTION(sres, CC1200_INS_SRES)
|
||
|
DEFINE_STROBE_INSTRUCTION(sfstxon, CC1200_INS_SFSTXON)
|
||
|
DEFINE_STROBE_INSTRUCTION(sxoff, CC1200_INS_SXOFF)
|
||
|
DEFINE_STROBE_INSTRUCTION(scal, CC1200_INS_SCAL)
|
||
|
DEFINE_STROBE_INSTRUCTION(srx, CC1200_INS_SRX)
|
||
|
DEFINE_STROBE_INSTRUCTION(stx, CC1200_INS_STX)
|
||
|
DEFINE_STROBE_INSTRUCTION(sidle, CC1200_INS_SIDLE)
|
||
|
DEFINE_STROBE_INSTRUCTION(safc, CC1200_INS_SAFC)
|
||
|
DEFINE_STROBE_INSTRUCTION(swor, CC1200_INS_SWOR)
|
||
|
DEFINE_STROBE_INSTRUCTION(spwd, CC1200_INS_SPWD)
|
||
|
DEFINE_STROBE_INSTRUCTION(sfrx, CC1200_INS_SFRX)
|
||
|
DEFINE_STROBE_INSTRUCTION(sftx, CC1200_INS_SFTX)
|
||
|
DEFINE_STROBE_INSTRUCTION(sworrst, CC1200_INS_SWORRST)
|
||
|
DEFINE_STROBE_INSTRUCTION(snop, CC1200_INS_SNOP)
|
||
|
|
||
|
#endif /* __IEEE802154_CC1200_H__ */
|