1 /*
2  * Copyright (c) 2019 Brett Witherspoon
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  *
6  * References are to the IEEE 802.15.4-2020 standard.
7  */
8 
9 #ifndef ZEPHYR_DRIVERS_IEEE802154_IEEE802154_CC13XX_CC26XX_H_
10 #define ZEPHYR_DRIVERS_IEEE802154_IEEE802154_CC13XX_CC26XX_H_
11 
12 #include <zephyr/kernel.h>
13 #include <zephyr/net/net_if.h>
14 #include <zephyr/net/ieee802154.h>
15 #include <zephyr/net/ieee802154_radio.h>
16 
17 #include <ti/drivers/rf/RF.h>
18 
19 #include <driverlib/rf_common_cmd.h>
20 #include <driverlib/rf_data_entry.h>
21 #include <driverlib/rf_ieee_cmd.h>
22 #include <driverlib/rf_mailbox.h>
23 
24 /* For O-QPSK the physical and MAC timing symbol rates are the same, see section 12.3.3. */
25 #define IEEE802154_2450MHZ_OQPSK_SYMBOLS_PER_SECOND                                                \
26 	IEEE802154_PHY_SYMBOLS_PER_SECOND(IEEE802154_PHY_OQPSK_780_TO_2450MHZ_SYMBOL_PERIOD_NS)
27 
28 /* PHY PIB attribute phyCcaMode - CCA Mode 3: Carrier sense with energy above threshold, see
29  * section 11.3, table 11-2 and section 10.2.8
30  */
31 #define IEEE802154_PHY_CCA_MODE 3
32 
33 #define IEEE802154_PHY_SHR_DURATION 10 /* in symbols, 8 preamble and 2 SFD, see section 12.1.2 */
34 
35 #define IEEE802154_PHY_SYMBOLS_PER_OCTET 2 /* see section 12.2.1 */
36 
37 /* ACK is 2 bytes for PHY header + 2 bytes MAC header + 2 bytes MAC footer */
38 #define IEEE802154_ACK_FRAME_OCTETS 6
39 
40 /* IEEE 802.15.4-2006 MAC PIB attributes (7.4.2)
41  *
42  * The macAckWaitDuration attribute does not include aUnitBackoffPeriod for
43  * non-beacon enabled PANs (See IEEE 802.15.4-2006 7.5.6.4.2)
44  */
45 #define IEEE802154_MAC_ACK_WAIT_DURATION                                                           \
46 	(IEEE802154_PHY_A_TURNAROUND_TIME_DEFAULT + IEEE802154_PHY_SHR_DURATION +                  \
47 	 IEEE802154_ACK_FRAME_OCTETS * IEEE802154_PHY_SYMBOLS_PER_OCTET)
48 
49 #define CC13XX_CC26XX_RAT_CYCLES_PER_SECOND 4000000
50 
51 #define CC13XX_CC26XX_NUM_RX_BUF 2
52 
53 /* Three additional bytes for length, RSSI and correlation values from CPE. */
54 #define CC13XX_CC26XX_RX_BUF_SIZE (IEEE802154_MAX_PHY_PACKET_SIZE + 3)
55 
56 #define CC13XX_CC26XX_CPE0_IRQ (INT_RFC_CPE_0 - 16)
57 #define CC13XX_CC26XX_CPE1_IRQ (INT_RFC_CPE_1 - 16)
58 
59 #define CC13XX_CC26XX_RECEIVER_SENSITIVITY -100
60 #define CC13XX_CC26XX_INVALID_RSSI INT8_MIN
61 
62 struct ieee802154_cc13xx_cc26xx_data {
63 	RF_Handle rf_handle;
64 	RF_Object rf_object;
65 
66 	struct net_if *iface;
67 
68 	uint8_t mac[8]; /* in big endian */
69 
70 	struct k_mutex tx_mutex;
71 
72 	dataQueue_t rx_queue;
73 	rfc_dataEntryPointer_t rx_entry[CC13XX_CC26XX_NUM_RX_BUF];
74 	uint8_t rx_data[CC13XX_CC26XX_NUM_RX_BUF]
75 		    [CC13XX_CC26XX_RX_BUF_SIZE] __aligned(4);
76 
77 	volatile rfc_CMD_FS_t cmd_fs;
78 	volatile rfc_CMD_IEEE_CCA_REQ_t cmd_ieee_cca_req;
79 	volatile rfc_CMD_IEEE_RX_t cmd_ieee_rx;
80 	volatile rfc_CMD_IEEE_CSMA_t cmd_ieee_csma;
81 	volatile rfc_CMD_IEEE_TX_t cmd_ieee_tx;
82 	volatile rfc_CMD_IEEE_RX_ACK_t cmd_ieee_rx_ack;
83 #if defined(CONFIG_SOC_CC1352R) || defined(CONFIG_SOC_CC2652R) || \
84 	defined(CONFIG_SOC_CC1352R7) || defined(CONFIG_SOC_CC2652R7)
85 	volatile rfc_CMD_RADIO_SETUP_t cmd_radio_setup;
86 #elif defined(CONFIG_SOC_CC1352P) || defined(CONFIG_SOC_CC2652P) || \
87 	defined(CONFIG_SOC_CC1352P7) || defined(CONFIG_SOC_CC2652P7)
88 	volatile rfc_CMD_RADIO_SETUP_PA_t cmd_radio_setup;
89 #else
90 	BUILD_ASSERT(false, "unknown model");
91 #endif /* CONFIG_SOC_CCxx52x */
92 
93 	volatile int16_t saved_cmdhandle;
94 };
95 
96 #endif /* ZEPHYR_DRIVERS_IEEE802154_IEEE802154_CC13XX_CC26XX_H_ */
97