| /* 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 device *spi; |
| struct spi_config spi_cfg; |
| 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 cc1200_context *ctx, bool read, u8_t addr, |
| void *data, size_t length, bool extended, bool burst); |
| |
| static inline u8_t _cc1200_read_single_reg(struct cc1200_context *ctx, |
| u8_t addr, bool extended) |
| { |
| u8_t val; |
| |
| if (_cc1200_access_reg(ctx, true, addr, &val, 1, extended, false)) { |
| return val; |
| } |
| |
| return 0; |
| } |
| |
| static inline bool _cc1200_write_single_reg(struct cc1200_context *ctx, |
| u8_t addr, u8_t val, bool extended) |
| { |
| return _cc1200_access_reg(ctx, false, addr, &val, 1, extended, false); |
| } |
| |
| static inline bool _cc1200_instruct(struct cc1200_context *ctx, u8_t addr) |
| { |
| return _cc1200_access_reg(ctx, false, addr, NULL, 0, false, false); |
| } |
| |
| #define DEFINE_REG_READ(__reg_name, __reg_addr, __ext) \ |
| static inline u8_t read_reg_##__reg_name(struct cc1200_context *ctx) \ |
| { \ |
| /*SYS_LOG_DBG("");*/ \ |
| return _cc1200_read_single_reg(ctx, __reg_addr, __ext); \ |
| } |
| |
| #define DEFINE_REG_WRITE(__reg_name, __reg_addr, __ext) \ |
| static inline bool write_reg_##__reg_name(struct cc1200_context *ctx, \ |
| u8_t val) \ |
| { \ |
| /*SYS_LOG_DBG("");*/ \ |
| return _cc1200_write_single_reg(ctx, __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 cc1200_context *ctx) \ |
| { \ |
| /*SYS_LOG_DBG("");*/ \ |
| return _cc1200_instruct(ctx, __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__ */ |