wlan_mlo_t2lm.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833
  1. /*
  2. * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. /**
  17. * DOC: contains T2LM APIs
  18. */
  19. #ifndef _WLAN_MLO_T2LM_H_
  20. #define _WLAN_MLO_T2LM_H_
  21. #include <wlan_cmn_ieee80211.h>
  22. #include <wlan_mlo_mgr_public_structs.h>
  23. #ifdef WMI_AP_SUPPORT
  24. #include <wlan_cmn.h>
  25. #endif
  26. struct mlo_vdev_host_tid_to_link_map_resp;
  27. struct wlan_mlo_dev_context;
  28. /* Max T2LM TIDS count */
  29. #define T2LM_MAX_NUM_TIDS 8
  30. #ifdef WMI_AP_SUPPORT
  31. /* Max no. of Preferred links */
  32. #define MAX_PREFERRED_LINKS 4
  33. #endif
  34. /* Max T2LM callback handlers */
  35. #define MAX_T2LM_HANDLERS 50
  36. #define T2LM_EXPECTED_DURATION_MAX_VALUE 0xFFFFFF
  37. /* Mapping switch time represented as bits 10 to 25 of the TSF value */
  38. #define WLAN_T2LM_MAPPING_SWITCH_TSF_BITS 0x3FFFC00
  39. /* There is a delay involved to receive and process the beacon/probe response
  40. * T2LM IE from AP. To match mapping switch timer expiry in both AP and STA,
  41. * advance timer expiry in STA by 100ms (= 98 * 1024 / 1000 = 100).
  42. */
  43. #define WLAN_T2LM_MAPPING_SWITCH_TIME_DELAY 98
  44. /**
  45. * enum wlan_t2lm_direction - Indicates the direction for which TID-to-link
  46. * mapping is available.
  47. *
  48. * @WLAN_T2LM_DL_DIRECTION: Downlink
  49. * @WLAN_T2LM_UL_DIRECTION: Uplink
  50. * @WLAN_T2LM_BIDI_DIRECTION: Both downlink and uplink
  51. * @WLAN_T2LM_MAX_DIRECTION: Max direction, this is used only internally
  52. * @WLAN_T2LM_INVALID_DIRECTION: Invalid, this is used only internally to check
  53. * if the mapping present in wlan_t2lm_info
  54. * structure is valid or not.
  55. */
  56. enum wlan_t2lm_direction {
  57. WLAN_T2LM_DL_DIRECTION,
  58. WLAN_T2LM_UL_DIRECTION,
  59. WLAN_T2LM_BIDI_DIRECTION,
  60. WLAN_T2LM_MAX_DIRECTION,
  61. WLAN_T2LM_INVALID_DIRECTION,
  62. };
  63. #ifdef WMI_AP_SUPPORT
  64. /**
  65. * enum wlan_link_band_caps - Represents the band capability of
  66. * a link.
  67. *
  68. * @WLAN_LINK_BAND_INVALID: Invalid band
  69. * @WLAN_LINK_BAND_2GHZ: 2GHz link
  70. * @WLAN_LINK_BAND_5GHZ: 5GHz link
  71. * @WLAN_LINK_BAND_5GHZ_LOW: 5GHz Low band link
  72. * @WLAN_LINK_BAND_5GHZ_HIGH: 5GHz High band link
  73. * @WLAN_LINK_BAND_6GHZ: 6GHz link
  74. * @WLAN_LINK_BAND_6GHZ_LOW: 6GHz Low band link
  75. * @WLAN_LINK_BAND_6GHZ_HIGH: 6GHz High band link
  76. */
  77. enum wlan_link_band_caps {
  78. WLAN_LINK_BAND_INVALID = 0,
  79. WLAN_LINK_BAND_2GHZ = 1,
  80. WLAN_LINK_BAND_5GHZ = 2,
  81. WLAN_LINK_BAND_5GHZ_LOW = 3,
  82. WLAN_LINK_BAND_5GHZ_HIGH = 4,
  83. WLAN_LINK_BAND_6GHZ = 5,
  84. WLAN_LINK_BAND_6GHZ_LOW = 6,
  85. WLAN_LINK_BAND_6GHZ_HIGH = 7,
  86. };
  87. /**
  88. * struct wlan_link_preference - Preferred link structure
  89. * @num_pref_links: non-zero values indicate that preferred link order
  90. * is present.
  91. * @pref_order: Preferred links in order.it is in form of hardware link id.
  92. * @timeout: timeout values for all the access categories.
  93. * @tlt_characterization_params: Bitmask to select Tx-Link Tuple from ordered
  94. * list.
  95. * Bit 0-15: Each bit maps to the corresponding Link ID
  96. * Bit 16-31: Reserved
  97. */
  98. struct wlan_link_preference {
  99. uint8_t num_pref_links;
  100. uint8_t pref_order[MAX_PREFERRED_LINKS];
  101. uint32_t timeout[WIFI_AC_MAX];
  102. uint32_t tlt_characterization_params;
  103. };
  104. /**
  105. * struct wlan_t2lm_of_tids - TID-to-link mapping for a given direction
  106. * @direction: direction from 'enum wlan_t2lm_direction'
  107. * @t2lm_provisioned_links: Link mapping for all the TIDs.
  108. * It is in form of enum wlan_link_band_caps.
  109. */
  110. struct wlan_t2lm_of_tids {
  111. enum wlan_t2lm_direction direction;
  112. enum wlan_link_band_caps t2lm_provisioned_links[T2LM_MAX_NUM_TIDS];
  113. };
  114. /**
  115. * struct wlan_preferred_links - Preferred link structure
  116. * @peer_mld_mac_addr: STA MLD macaddr
  117. * @num_t2lm_of_tids: non-zero value indicates that this structure is
  118. * carrying the TID-to-link mapping.It indicates for how many directions,
  119. * the TID-to-link mapping is present.
  120. * @homogeneous_mapping: non-zero value indicates the provided mapping
  121. * is homogeneous.
  122. * @t2lm: Valid TID-to-link mapping for the directions
  123. * @num_pref_links: non-zero values indicate that preferred link order is
  124. * present.
  125. * @preffered_link_order: Preferred links in order.
  126. * The links will be represented interms of wlan_link_band_caps enum.
  127. * @timeout: Timeout values for all the access categories.
  128. */
  129. struct wlan_preferred_links {
  130. uint8_t peer_mld_mac_addr[6];
  131. uint8_t num_t2lm_of_tids;
  132. int8_t homogeneous_mapping;
  133. struct wlan_t2lm_of_tids t2lm[WLAN_T2LM_MAX_DIRECTION];
  134. uint8_t num_pref_links;
  135. enum wlan_link_band_caps preffered_link_order[MAX_PREFERRED_LINKS];
  136. uint32_t timeout[WIFI_AC_MAX];
  137. };
  138. #endif
  139. /**
  140. * struct wlan_t2lm_info - TID-to-Link mapping information for the frames
  141. * transmitted on the uplink, downlink and bidirectional.
  142. *
  143. * @direction: 0 - Downlink, 1 - uplink 2 - Both uplink and downlink
  144. * @default_link_mapping: value 1 indicates the default T2LM, where all the TIDs
  145. * are mapped to all the links.
  146. * value 0 indicates the preferred T2LM mapping
  147. * @mapping_switch_time_present: Indicates if mapping switch time field present
  148. * in the T2LM IE
  149. * @expected_duration_present: Indicates if expected duration present in the
  150. * T2LM IE
  151. * @mapping_switch_time: Mapping switch time of this T2LM IE
  152. * @expected_duration: Expected duration of this T2LM IE
  153. * @ieee_link_map_tid: Indicates ieee link id mapping of all the TIDS
  154. * @hw_link_map_tid: Indicates hw link id mapping of all the TIDS
  155. * @timer_started: flag to check if T2LM timer is started for this T2LM IE
  156. */
  157. struct wlan_t2lm_info {
  158. enum wlan_t2lm_direction direction;
  159. bool default_link_mapping;
  160. bool mapping_switch_time_present;
  161. bool expected_duration_present;
  162. uint16_t mapping_switch_time;
  163. uint32_t expected_duration;
  164. uint16_t ieee_link_map_tid[T2LM_MAX_NUM_TIDS];
  165. uint16_t hw_link_map_tid[T2LM_MAX_NUM_TIDS];
  166. bool timer_started;
  167. };
  168. /**
  169. * enum wlan_t2lm_category - T2LM category
  170. *
  171. * @WLAN_T2LM_CATEGORY_NONE: none
  172. * @WLAN_T2LM_CATEGORY_REQUEST: T2LM request
  173. * @WLAN_T2LM_CATEGORY_RESPONSE: T2LM response
  174. * @WLAN_T2LM_CATEGORY_TEARDOWN: T2LM teardown
  175. * @WLAN_T2LM_CATEGORY_INVALID: Invalid
  176. */
  177. enum wlan_t2lm_category {
  178. WLAN_T2LM_CATEGORY_NONE = 0,
  179. WLAN_T2LM_CATEGORY_REQUEST = 1,
  180. WLAN_T2LM_CATEGORY_RESPONSE = 2,
  181. WLAN_T2LM_CATEGORY_TEARDOWN = 3,
  182. WLAN_T2LM_CATEGORY_INVALID,
  183. };
  184. /**
  185. * enum wlan_t2lm_tx_status - Status code applicable for the T2LM frames
  186. * transmitted by the current peer.
  187. *
  188. * @WLAN_T2LM_TX_STATUS_NONE: Status code is not applicable
  189. * @WLAN_T2LM_TX_STATUS_SUCCESS: AP/STA successfully transmitted the T2LM frame
  190. * @WLAN_T2LM_TX_STATUS_FAILURE: Tx failure received from the FW.
  191. * @WLAN_T2LM_TX_STATUS_RX_TIMEOUT: T2LM response frame not received from the
  192. * peer for the transmitted T2LM request frame.
  193. * @WLAN_T2LM_TX_STATUS_INVALID: Invalid status code
  194. */
  195. enum wlan_t2lm_tx_status {
  196. WLAN_T2LM_TX_STATUS_NONE = 0,
  197. WLAN_T2LM_TX_STATUS_SUCCESS = 1,
  198. WLAN_T2LM_TX_STATUS_FAILURE = 2,
  199. WLAN_T2LM_TX_STATUS_RX_TIMEOUT = 3,
  200. WLAN_T2LM_TX_STATUS_INVALID,
  201. };
  202. /**
  203. * enum wlan_t2lm_resp_frm_type - T2LM status corresponds to T2LM response frame
  204. *
  205. * @WLAN_T2LM_RESP_TYPE_SUCCESS: T2LM mapping provided in the T2LM request is
  206. * accepted either by the AP or STA
  207. * @WLAN_T2LM_RESP_TYPE_DENIED_TID_TO_LINK_MAPPING: T2LM Request denied because
  208. * the requested TID-to-link mapping is unacceptable.
  209. * @WLAN_T2LM_RESP_TYPE_PREFERRED_TID_TO_LINK_MAPPING: T2LM Request rejected and
  210. * preferred TID-to-link mapping is suggested.
  211. * @WLAN_T2LM_RESP_TYPE_INVALID: Status code is not applicable.
  212. */
  213. enum wlan_t2lm_resp_frm_type {
  214. WLAN_T2LM_RESP_TYPE_SUCCESS = 0,
  215. WLAN_T2LM_RESP_TYPE_DENIED_TID_TO_LINK_MAPPING = 133,
  216. WLAN_T2LM_RESP_TYPE_PREFERRED_TID_TO_LINK_MAPPING = 134,
  217. WLAN_T2LM_RESP_TYPE_INVALID,
  218. };
  219. /**
  220. * enum wlan_t2lm_enable - TID-to-link negotiation supported by the mlo peer
  221. *
  222. * @WLAN_T2LM_NOT_SUPPORTED: T2LM is not supported by the MLD
  223. * @WLAN_T2LM_MAP_ALL_TIDS_TO_SAME_LINK_SET: MLD only supports the mapping of
  224. * all TIDs to the same link set.
  225. * @WLAN_T2LM_MAP_RESERVED: reserved value
  226. * @WLAN_T2LM_MAP_EACH_TID_TO_SAME_OR_DIFFERENET_LINK_SET: MLD supports the
  227. * mapping of each TID to the same or different link set (Disjoint mapping).
  228. * @WLAN_T2LM_ENABLE_INVALID: invalid
  229. */
  230. enum wlan_t2lm_enable {
  231. WLAN_T2LM_NOT_SUPPORTED = 0,
  232. WLAN_T2LM_MAP_ALL_TIDS_TO_SAME_LINK_SET = 1,
  233. WLAN_T2LM_MAP_RESERVED = 2,
  234. WLAN_T2LM_MAP_EACH_TID_TO_SAME_OR_DIFFERENET_LINK_SET = 3,
  235. WLAN_T2LM_ENABLE_INVALID,
  236. };
  237. /**
  238. * struct wlan_prev_t2lm_negotiated_info - Previous successful T2LM negotiation
  239. * is saved here.
  240. *
  241. * @dialog_token: Save the dialog token used in T2LM request and response frame.
  242. * @t2lm_info: Provides the TID to LINK mapping information
  243. * @link_preference: Provides the preferred link information
  244. */
  245. struct wlan_prev_t2lm_negotiated_info {
  246. uint16_t dialog_token;
  247. struct wlan_t2lm_info t2lm_info[WLAN_T2LM_MAX_DIRECTION];
  248. #ifdef WMI_AP_SUPPORT
  249. struct wlan_link_preference link_preference;
  250. #endif
  251. };
  252. /**
  253. * struct wlan_t2lm_onging_negotiation_info - Current ongoing T2LM negotiation
  254. * (information about transmitted T2LM request/response frame)
  255. *
  256. * @category: T2LM category as T2LM request frame
  257. * @dialog_token: Save the dialog token used in T2LM request and response frame.
  258. * @t2lm_info: Provides the TID-to-link mapping info for UL/DL/BiDi
  259. * @t2lm_tx_status: Status code corresponds to the transmitted T2LM frames
  260. * @t2lm_resp_type: T2LM status corresponds to T2LM response frame.
  261. * @link_preference: Provides the preferred link information
  262. * @t2lm_info_present: It will show the t2lm_info present or not
  263. * @pref_link_present: It will show the preference link is present or not
  264. * @ml_grp_id: MLO Group id which it belongs to
  265. */
  266. struct wlan_t2lm_onging_negotiation_info {
  267. enum wlan_t2lm_category category;
  268. uint8_t dialog_token;
  269. struct wlan_t2lm_info t2lm_info[WLAN_T2LM_MAX_DIRECTION];
  270. enum wlan_t2lm_tx_status t2lm_tx_status;
  271. enum wlan_t2lm_resp_frm_type t2lm_resp_type;
  272. #ifdef WMI_AP_SUPPORT
  273. struct wlan_link_preference link_preference;
  274. bool t2lm_info_present;
  275. bool pref_link_present;
  276. uint8_t ml_grp_id;
  277. #endif
  278. };
  279. /**
  280. * struct wlan_mlo_peer_t2lm_policy - TID-to-link mapping information
  281. *
  282. * @self_gen_dialog_token: self generated dialog token used to send T2LM request
  283. * frame;
  284. * @t2lm_enable_val: TID-to-link enable value supported by this peer.
  285. * @t2lm_negotiated_info: Previous successful T2LM negotiation is saved here.
  286. * @ongoing_tid_to_link_mapping: This has the ongoing TID-to-link mapping info
  287. * transmitted by this peer to the connected peer.
  288. */
  289. struct wlan_mlo_peer_t2lm_policy {
  290. uint8_t self_gen_dialog_token;
  291. enum wlan_t2lm_enable t2lm_enable_val;
  292. struct wlan_prev_t2lm_negotiated_info t2lm_negotiated_info;
  293. struct wlan_t2lm_onging_negotiation_info ongoing_tid_to_link_mapping;
  294. };
  295. /**
  296. * struct wlan_mlo_t2lm_ie - T2LM information
  297. *
  298. * @disabled_link_bitmap: Bitmap of disabled links. This is used to update the
  299. * disabled link field of RNR IE
  300. * @t2lm: T2LM info structure
  301. */
  302. struct wlan_mlo_t2lm_ie {
  303. uint16_t disabled_link_bitmap;
  304. struct wlan_t2lm_info t2lm;
  305. };
  306. /*
  307. * In a beacon or probe response frame, at max two T2LM IEs can be present
  308. * first one to represent the already existing mapping and the other one
  309. * represents the new T2LM mapping that is yet to establish.
  310. */
  311. #define WLAN_MAX_T2LM_IE 2
  312. /**
  313. * struct wlan_t2lm_timer - T2LM timer information
  314. *
  315. * @t2lm_timer: T2LM timer
  316. * @timer_interval: T2LM Timer value
  317. * @timer_started: T2LM timer started or not
  318. * @timer_out_time: T2LM timer target out time
  319. * @t2lm_dev_lock: lock to access struct
  320. */
  321. struct wlan_t2lm_timer {
  322. qdf_timer_t t2lm_timer;
  323. uint32_t timer_interval;
  324. uint32_t timer_out_time;
  325. bool timer_started;
  326. #ifdef WLAN_MLO_USE_SPINLOCK
  327. qdf_spinlock_t t2lm_dev_lock;
  328. #else
  329. qdf_mutex_t t2lm_dev_lock;
  330. #endif
  331. };
  332. struct wlan_mlo_dev_context;
  333. /**
  334. * typedef wlan_mlo_t2lm_link_update_handler - T2LM handler API to notify the
  335. * link update.
  336. * @mldev: Pointer to mlo_dev_context
  337. * @arg: ieee_link_map
  338. *
  339. * Return: QDF_STATUS
  340. */
  341. typedef QDF_STATUS (*wlan_mlo_t2lm_link_update_handler)(
  342. struct wlan_mlo_dev_context *mldev, void *arg);
  343. /**
  344. * struct wlan_t2lm_context - T2LM IE information
  345. *
  346. * @established_t2lm: Indicates the already established broadcast T2LM IE
  347. * advertised by the AP in beacon/probe response frames.
  348. * In this T2LM IE, expected duration flag is set to 1 and
  349. * mapping switch time present flag is set to 0 when the
  350. * mapping is non-default.
  351. * @upcoming_t2lm: Indicates the new broadcast T2LM IE advertised by the AP in
  352. * beacon/probe response frames. STA needs to use this mapping
  353. * when expected duration in the established T2LM is expires.
  354. * @t2lm_timer: T2LM timer information
  355. * @t2lm_dev_lock: t2lm dev context lock
  356. * @tsf: time sync func value received via beacon
  357. * @link_update_handler: handler to update T2LM link
  358. * @is_valid_handler: T2LM handler is valid or not
  359. */
  360. struct wlan_t2lm_context {
  361. struct wlan_mlo_t2lm_ie established_t2lm;
  362. struct wlan_mlo_t2lm_ie upcoming_t2lm;
  363. struct wlan_t2lm_timer t2lm_timer;
  364. #ifdef WLAN_MLO_USE_SPINLOCK
  365. qdf_spinlock_t t2lm_dev_lock;
  366. #else
  367. qdf_mutex_t t2lm_dev_lock;
  368. #endif
  369. uint64_t tsf;
  370. wlan_mlo_t2lm_link_update_handler
  371. link_update_handler[MAX_T2LM_HANDLERS];
  372. bool is_valid_handler[MAX_T2LM_HANDLERS];
  373. };
  374. #ifdef WLAN_FEATURE_11BE
  375. #define t2lm_alert(format, args...) \
  376. QDF_TRACE_FATAL(QDF_MODULE_ID_T2LM, format, ## args)
  377. #define t2lm_err(format, args...) \
  378. QDF_TRACE_ERROR(QDF_MODULE_ID_T2LM, format, ## args)
  379. #define t2lm_warn(format, args...) \
  380. QDF_TRACE_WARN(QDF_MODULE_ID_T2LM, format, ## args)
  381. #define t2lm_info(format, args...) \
  382. QDF_TRACE_INFO(QDF_MODULE_ID_T2LM, format, ## args)
  383. #define t2lm_debug(format, args...) \
  384. QDF_TRACE_DEBUG(QDF_MODULE_ID_T2LM, format, ## args)
  385. #define t2lm_rl_debug(format, args...) \
  386. QDF_TRACE_DEBUG_RL(QDF_MODULE_ID_T2LM, format, ## args)
  387. #define WLAN_T2LM_MAX_NUM_LINKS 16
  388. #ifdef WLAN_MLO_USE_SPINLOCK
  389. /**
  390. * t2lm_dev_lock_create - Create T2LM device mutex/spinlock
  391. * @t2lm_ctx: T2LM context
  392. *
  393. * Creates mutex/spinlock
  394. *
  395. * Return: void
  396. */
  397. static inline void
  398. t2lm_dev_lock_create(struct wlan_t2lm_context *t2lm_ctx)
  399. {
  400. qdf_spinlock_create(&t2lm_ctx->t2lm_dev_lock);
  401. }
  402. /**
  403. * t2lm_dev_lock_destroy - Destroy T2LM mutex/spinlock
  404. * @t2lm_ctx: T2LM context
  405. *
  406. * Destroy mutex/spinlock
  407. *
  408. * Return: void
  409. */
  410. static inline void
  411. t2lm_dev_lock_destroy(struct wlan_t2lm_context *t2lm_ctx)
  412. {
  413. qdf_spinlock_destroy(&t2lm_ctx->t2lm_dev_lock);
  414. }
  415. /**
  416. * t2lm_dev_lock_acquire - acquire T2LM mutex/spinlock
  417. * @t2lm_ctx: T2LM context
  418. *
  419. * acquire mutex/spinlock
  420. *
  421. * return: void
  422. */
  423. static inline
  424. void t2lm_dev_lock_acquire(struct wlan_t2lm_context *t2lm_ctx)
  425. {
  426. qdf_spin_lock_bh(&t2lm_ctx->t2lm_dev_lock);
  427. }
  428. /**
  429. * t2lm_dev_lock_release - release T2LM dev mutex/spinlock
  430. * @t2lm_ctx: T2LM context
  431. *
  432. * release mutex/spinlock
  433. *
  434. * return: void
  435. */
  436. static inline
  437. void t2lm_dev_lock_release(struct wlan_t2lm_context *t2lm_ctx)
  438. {
  439. qdf_spin_unlock_bh(&t2lm_ctx->t2lm_dev_lock);
  440. }
  441. #else /* WLAN_MLO_USE_SPINLOCK */
  442. static inline
  443. void t2lm_dev_lock_create(struct wlan_t2lm_context *t2lm_ctx)
  444. {
  445. qdf_mutex_create(&t2lm_ctx->t2lm_dev_lock);
  446. }
  447. static inline
  448. void t2lm_dev_lock_destroy(struct wlan_t2lm_context *t2lm_ctx)
  449. {
  450. qdf_mutex_destroy(&t2lm_ctx->t2lm_dev_lock);
  451. }
  452. static inline void t2lm_dev_lock_acquire(struct wlan_t2lm_context *t2lm_ctx)
  453. {
  454. qdf_mutex_acquire(&t2lm_ctx->t2lm_dev_lock);
  455. }
  456. static inline void t2lm_dev_lock_release(struct wlan_t2lm_context *t2lm_ctx)
  457. {
  458. qdf_mutex_release(&t2lm_ctx->t2lm_dev_lock);
  459. }
  460. #endif
  461. /**
  462. * wlan_register_t2lm_link_update_notify_handler() - API to register the
  463. * handlers to receive link update notification
  464. * @handler: handler for T2LM link update
  465. * @mldev: Pointer to mlo context
  466. *
  467. * Return: Index on which handler is registered
  468. */
  469. int wlan_register_t2lm_link_update_notify_handler(
  470. wlan_mlo_t2lm_link_update_handler handler,
  471. struct wlan_mlo_dev_context *mldev);
  472. /**
  473. * wlan_unregister_t2lm_link_update_notify_handler() - API to unregister the
  474. * T2LM related handlers
  475. * @mldev: Pointer to mlo context
  476. * @index: Index on which the handler was registered
  477. *
  478. * Return: None
  479. */
  480. void wlan_unregister_t2lm_link_update_notify_handler(
  481. struct wlan_mlo_dev_context *mldev, uint8_t index);
  482. /**
  483. * wlan_mlo_dev_t2lm_notify_link_update() - API to call the registered handlers
  484. * when there is a link update happens using T2LM
  485. * @mldev: Pointer to mlo context
  486. *
  487. * Return: QDF_STATUS
  488. */
  489. QDF_STATUS wlan_mlo_dev_t2lm_notify_link_update(
  490. struct wlan_mlo_dev_context *mldev);
  491. /**
  492. * wlan_mlo_parse_t2lm_ie() - API to parse the T2LM IE
  493. * @t2lm: Pointer to T2LM structure
  494. * @ie: Pointer to T2LM IE
  495. *
  496. * Return: QDF_STATUS
  497. */
  498. QDF_STATUS wlan_mlo_parse_t2lm_ie(
  499. struct wlan_t2lm_onging_negotiation_info *t2lm, uint8_t *ie);
  500. /**
  501. * wlan_mlo_add_t2lm_ie() - API to add TID-to-link mapping IE
  502. * @frm: Pointer to buffer
  503. * @t2lm: Pointer to t2lm mapping structure
  504. * @vdev: Pointer to vdev structure
  505. *
  506. * Return: Updated frame pointer
  507. */
  508. uint8_t *wlan_mlo_add_t2lm_ie(uint8_t *frm,
  509. struct wlan_t2lm_onging_negotiation_info *t2lm,
  510. struct wlan_objmgr_vdev *vdev);
  511. /**
  512. * wlan_mlo_vdev_tid_to_link_map_event() - API to process the revceived T2LM
  513. * event.
  514. * @psoc: psoc object
  515. * @event: Pointer to received T2LM info
  516. *
  517. * Return: QDF_STATUS
  518. */
  519. QDF_STATUS wlan_mlo_vdev_tid_to_link_map_event(
  520. struct wlan_objmgr_psoc *psoc,
  521. struct mlo_vdev_host_tid_to_link_map_resp *event);
  522. /**
  523. * wlan_mlo_parse_t2lm_action_frame() - API to parse T2LM action frame
  524. * @t2lm: Pointer to T2LM structure
  525. * @action_frm: Pointer to action frame
  526. * @category: T2LM action frame category
  527. *
  528. * Return: 0 - success, else failure
  529. */
  530. int wlan_mlo_parse_t2lm_action_frame(
  531. struct wlan_t2lm_onging_negotiation_info *t2lm,
  532. struct wlan_action_frame *action_frm,
  533. enum wlan_t2lm_category category);
  534. /**
  535. * wlan_mlo_add_t2lm_action_frame() - API to add T2LM action frame
  536. * @frm: Pointer to a frame to add T2LM IE
  537. * @args: T2LM action frame related info
  538. * @buf: Pointer to T2LM IE values
  539. * @category: T2LM action frame category
  540. *
  541. * Return: Pointer to the updated frame buffer
  542. */
  543. uint8_t *wlan_mlo_add_t2lm_action_frame(
  544. uint8_t *frm, struct wlan_action_frame_args *args,
  545. uint8_t *buf, enum wlan_t2lm_category category);
  546. /**
  547. * wlan_mlo_parse_bcn_prbresp_t2lm_ie() - API to parse the T2LM IE from beacon/
  548. * probe response frame
  549. * @t2lm_ctx: T2LM context
  550. * @ie: Pointer to T2LM IE
  551. *
  552. * Return: QDF_STATUS
  553. */
  554. QDF_STATUS wlan_mlo_parse_bcn_prbresp_t2lm_ie(
  555. struct wlan_t2lm_context *t2lm_ctx, uint8_t *ie);
  556. /**
  557. * wlan_mlo_parse_t2lm_info() - Parse T2LM IE fields
  558. * @ie: Pointer to T2LM IE
  559. * @t2lm: Pointer to T2LM structure
  560. *
  561. * Return: QDF_STATUS
  562. */
  563. QDF_STATUS wlan_mlo_parse_t2lm_info(uint8_t *ie,
  564. struct wlan_t2lm_info *t2lm);
  565. /**
  566. * wlan_mlo_add_t2lm_info_ie() - Add T2LM IE for UL/DL/Bidirection
  567. * @frm: Pointer to buffer
  568. * @t2lm: Pointer to t2lm mapping structure
  569. * @vdev: Pointer to vdev structure
  570. *
  571. * Return: Updated frame pointer
  572. */
  573. uint8_t *wlan_mlo_add_t2lm_info_ie(uint8_t *frm, struct wlan_t2lm_info *t2lm,
  574. struct wlan_objmgr_vdev *vdev);
  575. /**
  576. * wlan_mlo_t2lm_timer_init() - API to initialize t2lm timer
  577. * @vdev: Pointer to vdev
  578. *
  579. * Return: qdf status
  580. */
  581. QDF_STATUS
  582. wlan_mlo_t2lm_timer_init(struct wlan_objmgr_vdev *vdev);
  583. /**
  584. * wlan_mlo_t2lm_timer_deinit() - API to deinit t2lm timer
  585. * @vdev: Pointer to vdev
  586. *
  587. * Return: qdf status
  588. */
  589. QDF_STATUS
  590. wlan_mlo_t2lm_timer_deinit(struct wlan_objmgr_vdev *vdev);
  591. /**
  592. * wlan_mlo_t2lm_timer_start() - API to start T2LM timer
  593. * @vdev: Pointer to vdev
  594. * @interval: T2LM timer interval
  595. *
  596. * Return: qdf status
  597. */
  598. QDF_STATUS
  599. wlan_mlo_t2lm_timer_start(struct wlan_objmgr_vdev *vdev,
  600. uint32_t interval);
  601. /**
  602. * wlan_mlo_t2lm_timer_stop() - API to stop TID-to-link mapping timer
  603. * @vdev: Pointer to vdev
  604. *
  605. * Return: qdf status
  606. */
  607. QDF_STATUS
  608. wlan_mlo_t2lm_timer_stop(struct wlan_objmgr_vdev *vdev);
  609. /**
  610. * wlan_mlo_t2lm_timer_expiry_handler() - API to handle t2lm timer expiry
  611. * @vdev: Pointer to vdev structure
  612. *
  613. * Return: none
  614. */
  615. void
  616. wlan_mlo_t2lm_timer_expiry_handler(void *vdev);
  617. /**
  618. * wlan_handle_t2lm_timer() - API to handle TID-to-link mapping timer
  619. * @vdev: Pointer to vdev
  620. *
  621. * Return: qdf status
  622. */
  623. QDF_STATUS
  624. wlan_handle_t2lm_timer(struct wlan_objmgr_vdev *vdev);
  625. /**
  626. * wlan_process_bcn_prbrsp_t2lm_ie() - API to process the received T2LM IE from
  627. * beacon/probe response.
  628. * @vdev: Pointer to vdev
  629. * @rx_t2lm_ie: Received T2LM IE
  630. * @tsf: Local TSF value
  631. *
  632. * Return QDF_STATUS
  633. */
  634. QDF_STATUS wlan_process_bcn_prbrsp_t2lm_ie(struct wlan_objmgr_vdev *vdev,
  635. struct wlan_t2lm_context *rx_t2lm_ie,
  636. uint64_t tsf);
  637. /**
  638. * wlan_send_tid_to_link_mapping() - API to send T2LM info received from beacon,
  639. * probe response or action frame to FW.
  640. *
  641. * @vdev: Pointer to vdev
  642. * @t2lm: T2LM info
  643. *
  644. * Return QDF_STATUS
  645. */
  646. QDF_STATUS wlan_send_tid_to_link_mapping(struct wlan_objmgr_vdev *vdev,
  647. struct wlan_t2lm_info *t2lm);
  648. #else
  649. static inline QDF_STATUS wlan_mlo_parse_t2lm_ie(
  650. struct wlan_t2lm_onging_negotiation_info *t2lm, uint8_t *ie)
  651. {
  652. return QDF_STATUS_E_FAILURE;
  653. }
  654. static inline
  655. int8_t *wlan_mlo_add_t2lm_ie(uint8_t *frm,
  656. struct wlan_t2lm_onging_negotiation_info *t2lm,
  657. struct wlan_objmgr_vdev *vdev)
  658. {
  659. return frm;
  660. }
  661. static inline
  662. int wlan_mlo_parse_t2lm_action_frame(
  663. struct wlan_t2lm_onging_negotiation_info *t2lm,
  664. struct wlan_action_frame *action_frm,
  665. enum wlan_t2lm_category category)
  666. {
  667. return 0;
  668. }
  669. static inline
  670. uint8_t *wlan_mlo_add_t2lm_action_frame(
  671. uint8_t *frm, struct wlan_action_frame_args *args,
  672. uint8_t *buf, enum wlan_t2lm_category category)
  673. {
  674. return frm;
  675. }
  676. static inline
  677. QDF_STATUS wlan_mlo_parse_bcn_prbresp_t2lm_ie(
  678. struct wlan_t2lm_context *t2lm_ctx, uint8_t *ie)
  679. {
  680. return QDF_STATUS_E_FAILURE;
  681. }
  682. static inline
  683. QDF_STATUS wlan_mlo_parse_t2lm_info(uint8_t *ie,
  684. struct wlan_t2lm_info *t2lm)
  685. {
  686. return QDF_STATUS_E_FAILURE;
  687. }
  688. static inline
  689. uint8_t *wlan_mlo_add_t2lm_info_ie(uint8_t *frm, struct wlan_t2lm_info *t2lm,
  690. struct wlan_objmgr_vdev *vdev)
  691. {
  692. return frm;
  693. }
  694. static inline QDF_STATUS
  695. wlan_mlo_t2lm_timer_init(struct wlan_objmgr_vdev *vdev)
  696. {
  697. return QDF_STATUS_E_NOSUPPORT;
  698. }
  699. static inline QDF_STATUS
  700. wlan_mlo_t2lm_timer_deinit(struct wlan_objmgr_vdev *vdev)
  701. {
  702. return QDF_STATUS_E_NOSUPPORT;
  703. }
  704. static inline QDF_STATUS
  705. wlan_mlo_t2lm_timer_start(struct wlan_objmgr_vdev *vdev,
  706. uint32_t interval)
  707. {
  708. return QDF_STATUS_E_NOSUPPORT;
  709. }
  710. static inline QDF_STATUS
  711. wlan_mlo_t2lm_timer_stop(struct wlan_objmgr_vdev *vdev)
  712. {
  713. return QDF_STATUS_E_NOSUPPORT;
  714. }
  715. static inline void
  716. wlan_mlo_t2lm_timer_expiry_handler(void *vdev)
  717. {}
  718. static inline QDF_STATUS
  719. wlan_handle_t2lm_timer(struct wlan_objmgr_vdev *vdev)
  720. {
  721. return QDF_STATUS_E_NOSUPPORT;
  722. }
  723. static inline QDF_STATUS
  724. wlan_process_bcn_prbrsp_t2lm_ie(struct wlan_objmgr_vdev *vdev,
  725. struct wlan_t2lm_context *rx_t2lm_ie,
  726. uint64_t tsf)
  727. {
  728. return QDF_STATUS_SUCCESS;
  729. }
  730. static inline
  731. int wlan_register_t2lm_link_update_notify_handler(
  732. wlan_mlo_t2lm_link_update_handler handler,
  733. struct wlan_mlo_dev_context *mldev)
  734. {
  735. return 0;
  736. }
  737. static inline
  738. void wlan_unregister_t2lm_link_update_notify_handler(
  739. struct wlan_mlo_dev_context *mldev, uint8_t index)
  740. {
  741. }
  742. static inline QDF_STATUS wlan_mlo_dev_t2lm_notify_link_update(
  743. struct wlan_mlo_dev_context *mldev)
  744. {
  745. return QDF_STATUS_SUCCESS;
  746. }
  747. static inline
  748. QDF_STATUS wlan_send_tid_to_link_mapping(struct wlan_objmgr_vdev *vdev,
  749. struct wlan_t2lm_info *t2lm)
  750. {
  751. return QDF_STATUS_SUCCESS;
  752. }
  753. #endif /* WLAN_FEATURE_11BE */
  754. #endif /* _WLAN_MLO_T2LM_H_ */