/* * 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