You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
107 lines
4.1 KiB
107 lines
4.1 KiB
/* |
|
* Copyright (c) 2021 Telink Semiconductor |
|
* |
|
* SPDX-License-Identifier: Apache-2.0 |
|
*/ |
|
|
|
#ifndef ZEPHYR_DRIVERS_IEEE802154_IEEE802154_B91_H_ |
|
#define ZEPHYR_DRIVERS_IEEE802154_IEEE802154_B91_H_ |
|
|
|
/* Timeouts */ |
|
#define B91_TX_WAIT_TIME_MS (10) |
|
#define B91_ACK_WAIT_TIME_MS (10) |
|
|
|
/* Received data parsing */ |
|
#define B91_PAYLOAD_OFFSET (5) |
|
#define B91_PAYLOAD_MIN (5) |
|
#define B91_PAYLOAD_MAX (127) |
|
#define B91_FRAME_TYPE_OFFSET (0) |
|
#define B91_FRAME_TYPE_MASK (0x07) |
|
#define B91_DEST_ADDR_TYPE_OFFSET (1) |
|
#define B91_DEST_ADDR_TYPE_MASK (0x0c) |
|
#define B91_DEST_ADDR_TYPE_SHORT (8) |
|
#define B91_DEST_ADDR_TYPE_IEEE (0x0c) |
|
#define B91_PAN_ID_OFFSET (3) |
|
#define B91_PAN_ID_SIZE (2) |
|
#define B91_DEST_ADDR_OFFSET (5) |
|
#define B91_SHORT_ADDRESS_SIZE (2) |
|
#define B91_IEEE_ADDRESS_SIZE (8) |
|
#define B91_LENGTH_OFFSET (4) |
|
#define B91_RSSI_OFFSET (11) |
|
#define B91_BROADCAST_ADDRESS ((uint8_t [2]) { 0xff, 0xff }) |
|
#define B91_ACK_FRAME_LEN (3) |
|
#define B91_ACK_TYPE (2) |
|
#define B91_ACK_REQUEST (1 << 5) |
|
#define B91_DSN_OFFSET (2) |
|
#define B91_FCS_LENGTH (2) |
|
|
|
/* Generic */ |
|
#define B91_TRX_LENGTH (256) |
|
#define B91_RSSI_TO_LQI_SCALE (3) |
|
#define B91_RSSI_TO_LQI_MIN (-87) |
|
#define B91_CCA_TIME_MAX_US (200) |
|
#define B91_LOGIC_CHANNEL_TO_PHYSICAL(p) (((p) - 10) * 5) |
|
|
|
/* TX power lookup table */ |
|
#define B91_TX_POWER_MIN (-30) |
|
#define B91_TX_POWER_MAX (9) |
|
static const uint8_t b91_tx_pwr_lt[] = { |
|
RF_POWER_N30dBm, /* -30.0 dBm: -30 */ |
|
RF_POWER_N30dBm, /* -30.0 dBm: -29 */ |
|
RF_POWER_N30dBm, /* -30.0 dBm: -28 */ |
|
RF_POWER_N30dBm, /* -30.0 dBm: -27 */ |
|
RF_POWER_N30dBm, /* -30.0 dBm: -26 */ |
|
RF_POWER_N23p54dBm, /* -23.5 dBm: -25 */ |
|
RF_POWER_N23p54dBm, /* -23.5 dBm: -24 */ |
|
RF_POWER_N23p54dBm, /* -23.5 dBm: -23 */ |
|
RF_POWER_N23p54dBm, /* -23.5 dBm: -22 */ |
|
RF_POWER_N23p54dBm, /* -23.5 dBm: -21 */ |
|
RF_POWER_N17p83dBm, /* -17.8 dBm: -20 */ |
|
RF_POWER_N17p83dBm, /* -17.8 dBm: -19 */ |
|
RF_POWER_N17p83dBm, /* -17.8 dBm: -18 */ |
|
RF_POWER_N17p83dBm, /* -17.8 dBm: -17 */ |
|
RF_POWER_N17p83dBm, /* -17.8 dBm: -16 */ |
|
RF_POWER_N12p06dBm, /* -12.0 dBm: -15 */ |
|
RF_POWER_N12p06dBm, /* -12.0 dBm: -14 */ |
|
RF_POWER_N12p06dBm, /* -12.0 dBm: -13 */ |
|
RF_POWER_N12p06dBm, /* -12.0 dBm: -12 */ |
|
RF_POWER_N12p06dBm, /* -12.0 dBm: -11 */ |
|
RF_POWER_N8p78dBm, /* -8.7 dBm: -10 */ |
|
RF_POWER_N8p78dBm, /* -8.7 dBm: -9 */ |
|
RF_POWER_N8p78dBm, /* -8.7 dBm: -8 */ |
|
RF_POWER_N6p54dBm, /* -6.5 dBm: -7 */ |
|
RF_POWER_N6p54dBm, /* -6.5 dBm: -6 */ |
|
RF_POWER_N4p77dBm, /* -4.7 dBm: -5 */ |
|
RF_POWER_N4p77dBm, /* -4.7 dBm: -4 */ |
|
RF_POWER_N3p37dBm, /* -3.3 dBm: -3 */ |
|
RF_POWER_N2p01dBm, /* -2.0 dBm: -2 */ |
|
RF_POWER_N1p37dBm, /* -1.3 dBm: -1 */ |
|
RF_POWER_P0p01dBm, /* 0.0 dBm: 0 */ |
|
RF_POWER_P0p80dBm, /* 0.8 dBm: 1 */ |
|
RF_POWER_P2p32dBm, /* 2.3 dBm: 2 */ |
|
RF_POWER_P3p25dBm, /* 3.2 dBm: 3 */ |
|
RF_POWER_P4p35dBm, /* 4.3 dBm: 4 */ |
|
RF_POWER_P5p68dBm, /* 5.6 dBm: 5 */ |
|
RF_POWER_P5p68dBm, /* 5.6 dBm: 6 */ |
|
RF_POWER_P6p98dBm, /* 6.9 dBm: 7 */ |
|
RF_POWER_P8p05dBm, /* 8.0 dBm: 8 */ |
|
RF_POWER_P9p11dBm, /* 9.1 dBm: 9 */ |
|
}; |
|
|
|
/* data structure */ |
|
struct b91_data { |
|
uint8_t mac_addr[B91_IEEE_ADDRESS_SIZE]; |
|
uint8_t rx_buffer[B91_TRX_LENGTH]; |
|
uint8_t tx_buffer[B91_TRX_LENGTH]; |
|
struct net_if *iface; |
|
struct k_sem tx_wait; |
|
struct k_sem ack_wait; |
|
uint8_t filter_pan_id[B91_PAN_ID_SIZE]; |
|
uint8_t filter_short_addr[B91_SHORT_ADDRESS_SIZE]; |
|
uint8_t filter_ieee_addr[B91_IEEE_ADDRESS_SIZE]; |
|
bool is_started; |
|
bool ack_handler_en; |
|
uint16_t current_channel; |
|
}; |
|
|
|
#endif
|
|
|