os_if_son.h 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748
  1. /*
  2. * Copyright (c) 2021, The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  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 : os_if_son.h
  18. *
  19. * WLAN Host Device Driver file for son (Self Organizing Network)
  20. * support.
  21. *
  22. */
  23. #ifndef _OS_IF_SON_H_
  24. #define _OS_IF_SON_H_
  25. #include <qdf_types.h>
  26. #include <wlan_objmgr_vdev_obj.h>
  27. #include <wlan_objmgr_psoc_obj.h>
  28. #include <wlan_objmgr_pdev_obj.h>
  29. #include <wlan_reg_ucfg_api.h>
  30. #include <ieee80211_external.h>
  31. #define INVALID_WIDTH 0xFF
  32. /**
  33. * struct son_callbacks - struct containing callback to non-converged driver
  34. * @os_if_is_acs_in_progress: whether acs is in progress or not
  35. * @os_if_set_chan_ext_offset: set chan extend offset
  36. * @os_if_get_chan_ext_offset: get chan extend offset
  37. * @os_if_set_bandwidth: set band width
  38. * @os_if_get_bandwidth: get band width
  39. * @os_if_set_chan: set chan
  40. * @os_if_set_country_code: set country code
  41. * @os_if_set_candidate_freq: set freq to switch after radar detection
  42. * @os_if_get_candidate_freq: get freq to switch after radar detection
  43. * @os_if_set_phymode: set phy mode
  44. * @os_if_get_phymode: get phy mode
  45. * @os_if_get_rx_nss: Gets number of RX spatial streams
  46. * @os_if_set_acl_policy: set acl policy
  47. * @os_if_get_acl_policy: get acl policy
  48. * @os_if_add_acl_mac: add mac to acl
  49. * @os_if_del_acl_mac: del mac from acl
  50. * @os_if_kickout_mac: kickout sta with given mac
  51. * @os_if_set_chwidth: set chan width
  52. * @os_if_get_chwidth: get chan width
  53. * @os_if_get_sta_list: get sta list
  54. * @os_if_get_sta_space: get sta space
  55. * @os_if_deauth_sta: Deauths the target peer
  56. * @os_if_modify_acl: Add/Del target peer in ACL
  57. * @os_if_get_vdev_by_netdev: Get vdev from net device
  58. * @os_if_trigger_objmgr_object_creation: Trigger objmgr object creation
  59. * @os_if_trigger_objmgr_object_deletion: Trigger objmgr object deletion
  60. * @os_if_start_acs: Trigger ACS
  61. * @os_if_set_acs_channels: Set channel list for ACS
  62. * @os_if_get_acs_report: Gets the ACS report
  63. */
  64. struct son_callbacks {
  65. uint32_t (*os_if_is_acs_in_progress)(struct wlan_objmgr_vdev *vdev);
  66. int (*os_if_set_chan_ext_offset)(
  67. struct wlan_objmgr_vdev *vdev,
  68. enum sec20_chan_offset son_chan_ext_offset);
  69. enum sec20_chan_offset (*os_if_get_chan_ext_offset)(
  70. struct wlan_objmgr_vdev *vdev);
  71. int (*os_if_set_bandwidth)(struct wlan_objmgr_vdev *vdev,
  72. uint32_t son_bandwidth);
  73. uint32_t (*os_if_get_bandwidth)(struct wlan_objmgr_vdev *vdev);
  74. int (*os_if_set_chan)(struct wlan_objmgr_vdev *vdev, int chan,
  75. enum wlan_band_id son_band);
  76. uint32_t (*os_if_get_sta_count)(struct wlan_objmgr_vdev *vdev);
  77. int (*os_if_set_country_code)(struct wlan_objmgr_vdev *vdev,
  78. char *country_code);
  79. int (*os_if_set_candidate_freq)(struct wlan_objmgr_vdev *vdev,
  80. qdf_freq_t freq);
  81. qdf_freq_t (*os_if_get_candidate_freq)(struct wlan_objmgr_vdev *vdev);
  82. int (*os_if_set_phymode)(struct wlan_objmgr_vdev *vdev,
  83. enum ieee80211_phymode mode);
  84. enum ieee80211_phymode (*os_if_get_phymode)(
  85. struct wlan_objmgr_vdev *vdev);
  86. uint8_t (*os_if_get_rx_nss)(struct wlan_objmgr_vdev *vdev);
  87. QDF_STATUS (*os_if_set_acl_policy)(struct wlan_objmgr_vdev *vdev,
  88. ieee80211_acl_cmd son_acl_policy);
  89. ieee80211_acl_cmd (*os_if_get_acl_policy)(
  90. struct wlan_objmgr_vdev *vdev);
  91. int (*os_if_add_acl_mac)(struct wlan_objmgr_vdev *vdev,
  92. struct qdf_mac_addr *acl_mac);
  93. int (*os_if_del_acl_mac)(struct wlan_objmgr_vdev *vdev,
  94. struct qdf_mac_addr *acl_mac);
  95. int (*os_if_kickout_mac)(struct wlan_objmgr_vdev *vdev,
  96. struct qdf_mac_addr *acl_mac);
  97. int (*os_if_set_chwidth)(struct wlan_objmgr_vdev *vdev,
  98. enum ieee80211_cwm_width son_chwidth);
  99. enum ieee80211_cwm_width (*os_if_get_chwidth)(
  100. struct wlan_objmgr_vdev *vdev);
  101. void (*os_if_get_sta_list)(struct wlan_objmgr_vdev *vdev,
  102. struct ieee80211req_sta_info *req,
  103. uint32_t *space);
  104. uint32_t (*os_if_get_sta_space)(struct wlan_objmgr_vdev *vdev);
  105. void (*os_if_deauth_sta)(struct wlan_objmgr_vdev *vdev,
  106. uint8_t *peer_mac,
  107. bool ignore_frame);
  108. void (*os_if_modify_acl)(struct wlan_objmgr_vdev *vdev,
  109. uint8_t *peer_mac,
  110. bool allow_auth);
  111. struct wlan_objmgr_vdev *(*os_if_get_vdev_by_netdev)
  112. (struct net_device *dev);
  113. QDF_STATUS (*os_if_trigger_objmgr_object_creation)
  114. (enum wlan_umac_comp_id id);
  115. QDF_STATUS (*os_if_trigger_objmgr_object_deletion)
  116. (enum wlan_umac_comp_id id);
  117. int (*os_if_start_acs)(struct wlan_objmgr_vdev *vdev, uint8_t enable);
  118. int (*os_if_set_acs_channels)(struct wlan_objmgr_vdev *vdev,
  119. struct ieee80211req_athdbg *req);
  120. int (*os_if_get_acs_report)(struct wlan_objmgr_vdev *vdev,
  121. struct ieee80211_acs_dbg *acs_r);
  122. };
  123. /**
  124. * enum os_if_son_vendor_cmd_type - Enum to specify get/set command
  125. * @OS_IF_SON_VENDOR_GET_CMD: Get type command called from wificonfiguration
  126. * vendor command handler
  127. * @OS_IF_SON_VENDOR_SET_CMD: Set type command called from wificonfiguration
  128. * vendor command handler
  129. * @OS_IF_SON_VENDOR_MAX_CMD: Max cmd type
  130. */
  131. enum os_if_son_vendor_cmd_type {
  132. OS_IF_SON_VENDOR_GET_CMD,
  133. OS_IF_SON_VENDOR_SET_CMD,
  134. OS_IF_SON_VENDOR_MAX_CMD,
  135. };
  136. /**
  137. * struct os_if_son_rx_ops - Contains cb for os_if rx ops used by SON
  138. * @parse_generic_nl_cmd: Callback for parsing generic nl vendor commands
  139. */
  140. struct os_if_son_rx_ops {
  141. int (*parse_generic_nl_cmd)(struct wiphy *wiphy,
  142. struct wireless_dev *wdev, void *params,
  143. enum os_if_son_vendor_cmd_type type);
  144. };
  145. /**
  146. * struct wlan_os_if_son_ops - Contains cb for os_if txrx ops used by SON
  147. * @son_osif_rx_ops: structure to contain rx ops
  148. */
  149. struct wlan_os_if_son_ops {
  150. struct os_if_son_rx_ops son_osif_rx_ops;
  151. };
  152. /**
  153. * wlan_os_if_son_ops_register_cb() - Set son os_if ops cb
  154. * @handler: son os_if ops cb table
  155. *
  156. * Return: void
  157. */
  158. void
  159. wlan_os_if_son_ops_register_cb(void (*handler)(struct wlan_os_if_son_ops *));
  160. /**
  161. * os_if_son_register_osif_ops() - Register son os_if ops with os_if
  162. *
  163. * Return: void
  164. */
  165. void os_if_son_register_osif_ops(void);
  166. /**
  167. * os_if_son_register_lmac_if_ops() - Register son lmac_if rx_ops with lmac
  168. * @psoc: objmrg psoc handle
  169. *
  170. * Register son lmac_if rx_ops with lmac to be called by SON DLKM
  171. *
  172. * Return: void
  173. */
  174. void os_if_son_register_lmac_if_ops(struct wlan_objmgr_psoc *psoc);
  175. /**
  176. * os_if_son_register_hdd_callbacks() - register son hdd callback
  177. * @psoc: psoc
  178. * @cb_obj: pointer to callback
  179. *
  180. * Return: void
  181. */
  182. void os_if_son_register_hdd_callbacks(struct wlan_objmgr_psoc *psoc,
  183. struct son_callbacks *cb_obj);
  184. /**
  185. * os_if_son_get_freq() - get freq
  186. * @vdev: vdev
  187. *
  188. * Return: freq of given vdev
  189. */
  190. qdf_freq_t os_if_son_get_freq(struct wlan_objmgr_vdev *vdev);
  191. /**
  192. * os_if_son_is_acs_in_progress() - whether ACS in progress or not
  193. * @vdev: vdev
  194. *
  195. * Return: true if ACS is in progress
  196. */
  197. uint32_t os_if_son_is_acs_in_progress(struct wlan_objmgr_vdev *vdev);
  198. /**
  199. * os_if_son_is_cac_in_progress() - whether CAC is in progress or not
  200. * @vdev: vdev
  201. *
  202. * Return: true if CAC is in progress
  203. */
  204. uint32_t os_if_son_is_cac_in_progress(struct wlan_objmgr_vdev *vdev);
  205. /**
  206. * os_if_son_set_chan_ext_offset() - set chan extend offset
  207. * @vdev: vdev
  208. * @son_chan_ext_offset son chan extend offset
  209. *
  210. * Return: 0 on success, negative errno on failure
  211. */
  212. int os_if_son_set_chan_ext_offset(struct wlan_objmgr_vdev *vdev,
  213. enum sec20_chan_offset son_chan_ext_offset);
  214. /**
  215. * os_if_son_get_chan_ext_offset() - get chan extend offset
  216. * @vdev: vdev
  217. *
  218. * Return: enum sec20_chan_offset
  219. */
  220. enum sec20_chan_offset os_if_son_get_chan_ext_offset(
  221. struct wlan_objmgr_vdev *vdev);
  222. /**
  223. * os_if_son_set_bandwidth() - set band width
  224. * @vdev: vdev
  225. * @son_bandwidth: band width
  226. *
  227. * Return: 0 on success, negative errno on failure
  228. */
  229. int os_if_son_set_bandwidth(struct wlan_objmgr_vdev *vdev,
  230. uint32_t son_bandwidth);
  231. /**
  232. * os_if_son_get_bandwidth() - get band width
  233. * @vdev: vdev
  234. *
  235. * Return: band width
  236. */
  237. uint32_t os_if_son_get_bandwidth(struct wlan_objmgr_vdev *vdev);
  238. /**
  239. * os_if_son_get_band_info() - get band info
  240. * @vdev: vdev
  241. *
  242. * Return: band info
  243. */
  244. uint32_t os_if_son_get_band_info(struct wlan_objmgr_vdev *vdev);
  245. /**
  246. * os_if_son_get_chan_list() - get a list of chan information
  247. * @vdev: vdev
  248. * @ic_chans: chan information array to get
  249. * @chan_info: pointer to ieee80211_channel_info to get
  250. * @ic_nchans: number of chan information it gets
  251. * @flag_160: flag indicating the API to fill the center frequencies of 160MHz.
  252. *
  253. * Return: 0 on success, negative errno on failure
  254. */
  255. int os_if_son_get_chan_list(struct wlan_objmgr_vdev *vdev,
  256. struct ieee80211_ath_channel *ic_chans,
  257. struct ieee80211_channel_info *chan_info,
  258. uint8_t *ic_nchans, bool flag_160);
  259. /**
  260. * os_if_son_get_sta_count() - get connected STA count
  261. * @vdev: vdev
  262. *
  263. * Return: connected STA count
  264. */
  265. uint32_t os_if_son_get_sta_count(struct wlan_objmgr_vdev *vdev);
  266. /**
  267. * os_if_son_get_bssid() - get bssid of given vdev
  268. * @vdev: vdev
  269. * @bssid: pointer to BSSID
  270. *
  271. * Return: 0 if BSSID is gotten successfully
  272. */
  273. int os_if_son_get_bssid(struct wlan_objmgr_vdev *vdev,
  274. uint8_t bssid[QDF_MAC_ADDR_SIZE]);
  275. /**
  276. * os_if_son_get_ssid() - get ssid of given vdev
  277. * @vdev: vdev
  278. * @ssid: pointer to SSID
  279. * @ssid_len: ssid length
  280. *
  281. * Return: 0 if SSID is gotten successfully
  282. */
  283. int os_if_son_get_ssid(struct wlan_objmgr_vdev *vdev,
  284. char ssid[WLAN_SSID_MAX_LEN + 1],
  285. uint8_t *ssid_len);
  286. /**
  287. * os_if_son_set_chan() - set chan
  288. * @vdev: vdev
  289. * @chan: given chan
  290. * @son_band: given band
  291. *
  292. * Return: 0 on success, negative errno on failure
  293. */
  294. int os_if_son_set_chan(struct wlan_objmgr_vdev *vdev,
  295. int chan, enum wlan_band_id son_band);
  296. /**
  297. * os_if_son_set_cac_timeout() - set cac timeout
  298. * @vdev: vdev
  299. * @cac_timeout: cac timeount to set
  300. *
  301. * Return: 0 if cac time out is set successfully
  302. */
  303. int os_if_son_set_cac_timeout(struct wlan_objmgr_vdev *vdev,
  304. int cac_timeout);
  305. /**
  306. * os_if_son_get_cac_timeout() - get cac timeout
  307. * @vdev: vdev
  308. * @cac_timeout: cac timeout to get
  309. *
  310. * Return 0 if cac time out is get successfully
  311. */
  312. int os_if_son_get_cac_timeout(struct wlan_objmgr_vdev *vdev,
  313. int *cac_timeout);
  314. /**
  315. * os_if_son_set_country_code() - set country code
  316. * @vdev: vdev
  317. * @country_code: country code to set
  318. *
  319. * Return: 0 if country code is set successfully
  320. */
  321. int os_if_son_set_country_code(struct wlan_objmgr_vdev *vdev,
  322. char *country_code);
  323. /**
  324. * os_if_son_get_country_code() - get country code
  325. * @vdev: vdev
  326. * @country_code: country code to get
  327. *
  328. * Return: 0 if country code is get successfully
  329. */
  330. int os_if_son_get_country_code(struct wlan_objmgr_vdev *vdev,
  331. char *country_code);
  332. /**
  333. * os_if_son_set_candidate_freq() - set freq to switch after radar detection
  334. * @vdev: vdev
  335. * @freq: freq to switch
  336. *
  337. * Return: 0 if candidate freq is set successfully
  338. */
  339. int os_if_son_set_candidate_freq(struct wlan_objmgr_vdev *vdev,
  340. qdf_freq_t freq);
  341. /**
  342. * os_if_son_get_candidate_freq() - get freq to switch after radar detection
  343. * @vdev: vdev
  344. *
  345. * Return: candidate freq to switch after radar detection
  346. */
  347. qdf_freq_t os_if_son_get_candidate_freq(struct wlan_objmgr_vdev *vdev);
  348. /**
  349. * os_if_son_get_phymode() - get phy mode
  350. * @vdev: vdev
  351. *
  352. * Return: enum ieee80211_phymode
  353. */
  354. enum ieee80211_phymode os_if_son_get_phymode(struct wlan_objmgr_vdev *vdev);
  355. /**
  356. * os_if_son_set_phymode() - set phy mode
  357. * @vdev: vdev
  358. * @mode: son phy mode to set
  359. *
  360. * Return: 0 on success, negative errno on failure
  361. */
  362. int os_if_son_set_phymode(struct wlan_objmgr_vdev *vdev,
  363. enum ieee80211_phymode mode);
  364. /**
  365. * os_if_son_get_phy_stats() - get phy stats
  366. * @vdev: vdev
  367. * @phy_stats: phy stats
  368. *
  369. * Return: void
  370. */
  371. void os_if_son_get_phy_stats(struct wlan_objmgr_vdev *vdev,
  372. struct ol_ath_radiostats *phy_stats);
  373. /**
  374. * os_if_son_cbs_init() - cbs init
  375. * @vdev: vdev
  376. *
  377. * Return: 0 on success, negative errno on failure
  378. */
  379. int os_if_son_cbs_init(void);
  380. /**
  381. * os_if_son_cbs_deinit() - cbs deinit
  382. * @vdev: vdev
  383. *
  384. * Return: 0 on success, negative errno on failure
  385. */
  386. int os_if_son_cbs_deinit(void);
  387. /**
  388. * os_if_son_set_cbs() - enable cbs or disable
  389. * @vdev: vdev
  390. * @enable: true or false
  391. *
  392. * Return: 0 on success, negative errno on failure
  393. */
  394. int os_if_son_set_cbs(struct wlan_objmgr_vdev *vdev,
  395. bool enable);
  396. /**
  397. * os_if_son_set_cbs_wait_time() - set cbs wait time
  398. * @vdev: vdev
  399. * @val: value
  400. *
  401. * Return: 0 on success, negative errno on failure
  402. */
  403. int os_if_son_set_cbs_wait_time(struct wlan_objmgr_vdev *vdev,
  404. uint32_t val);
  405. /**
  406. * os_if_son_set_cbs_dwell_split_time() - set cbs dwell split time
  407. * @vdev: vdev
  408. * @val: value
  409. *
  410. * Return: 0 on success, negative errno on failure
  411. */
  412. int os_if_son_set_cbs_dwell_split_time(struct wlan_objmgr_vdev *vdev,
  413. uint32_t val);
  414. /**
  415. * os_if_son_get_chan_util() - get chan utilization
  416. * @vdev: vdev
  417. *
  418. * Return: chan utilization (0 - 100)
  419. */
  420. uint8_t os_if_son_get_chan_util(struct wlan_objmgr_vdev *vdev);
  421. /**
  422. * os_if_son_pdev_ops() - Handles PDEV specific SON commands
  423. * @pdev: pdev
  424. * @type: SON command to handle
  425. * @data: Input Data
  426. * @ret: Output Data
  427. *
  428. * Return: QDF_SUCCCESS_SUCCESS in case of success
  429. */
  430. QDF_STATUS os_if_son_pdev_ops(struct wlan_objmgr_pdev *pdev,
  431. enum wlan_mlme_pdev_param type,
  432. void *data, void *ret);
  433. /**
  434. * os_if_son_vdev_ops() - Handles VDEV specific SON commands
  435. * @vdev: vdev
  436. * @type: SON command to handle
  437. * @data: Input Data
  438. * @ret: Output Data
  439. *
  440. * Return: QDF_SUCCCESS_SUCCESS in case of success
  441. */
  442. QDF_STATUS os_if_son_vdev_ops(struct wlan_objmgr_vdev *pdev,
  443. enum wlan_mlme_vdev_param type,
  444. void *data, void *ret);
  445. /**
  446. * os_if_son_peer_ops() - Handles PEER specific SON commands
  447. * @peer: peer
  448. * @type: SON command to handle
  449. * @data: Input Data. Pointer to wlan_mlme_peer_data
  450. * @ret: Output Data. Pointer to wlan_mlme_peer_data
  451. *
  452. * Return: QDF_SUCCCESS_SUCCESS in case of success
  453. */
  454. QDF_STATUS os_if_son_peer_ops(struct wlan_objmgr_peer *peer,
  455. enum wlan_mlme_peer_param type,
  456. union wlan_mlme_peer_data *data,
  457. union wlan_mlme_peer_data *ret);
  458. /**
  459. * os_if_son_scan_db_iterate() - get country code
  460. * @pdev: pdev
  461. * @handler: scan_iterator
  462. * @arg: argument to be passed to handler
  463. *
  464. * Return: QDF_SUCCCESS_SUCCESS in case of success
  465. */
  466. QDF_STATUS os_if_son_scan_db_iterate(struct wlan_objmgr_pdev *pdev,
  467. scan_iterator_func handler, void *arg);
  468. /**
  469. * os_if_son_acl_is_probe_wh_set() - Withheld probes for given mac_addr,
  470. * not supported
  471. * @vdev: vdev
  472. * @mac_addr: 6-Byte MAC address
  473. * @probe_rssi: Probe Request RSSI
  474. *
  475. * Return: true / false
  476. */
  477. bool os_if_son_acl_is_probe_wh_set(struct wlan_objmgr_vdev *vdev,
  478. const uint8_t *mac_addr,
  479. uint8_t probe_rssi);
  480. /**
  481. * os_if_son_get_rx_streams() - Gets number of RX spatial streams
  482. * @vdev: target vdev
  483. *
  484. * Return: number of spatial stream
  485. */
  486. uint8_t os_if_son_get_rx_streams(struct wlan_objmgr_vdev *vdev);
  487. /**
  488. * os_if_son_cfg80211_reply() - replies to cfg80211
  489. * @sk_buf: sk_buff to uper layer
  490. *
  491. * Return: QDF_STATUS_SUCCESS on success
  492. */
  493. QDF_STATUS os_if_son_cfg80211_reply(qdf_nbuf_t sk_buf);
  494. /**
  495. * os_if_son_vdev_is_wds() - checks if wds capability is supported or not
  496. * @vdev: Pointer to vdev
  497. *
  498. * Return: true if wds is supported
  499. */
  500. bool os_if_son_vdev_is_wds(struct wlan_objmgr_vdev *vdev);
  501. /*
  502. * os_if_son_set_acl_policy() - set acl policy
  503. * @vdev: vdev
  504. * @son_acl_policy: son acl policy. enum ieee80211_acl_cmd
  505. *
  506. * Return: QDF_STATUS
  507. */
  508. QDF_STATUS os_if_son_set_acl_policy(struct wlan_objmgr_vdev *vdev,
  509. ieee80211_acl_cmd son_acl_policy);
  510. /**
  511. * os_if_son_get_acl_policy() - get acl policy
  512. * @vdev: vdev
  513. *
  514. * Return: acl policy. enum ieee80211_acl_cmd
  515. */
  516. ieee80211_acl_cmd os_if_son_get_acl_policy(struct wlan_objmgr_vdev *vdev);
  517. /**
  518. * os_if_son_add_acl_mac() - add mac to acl
  519. * @vdev: vdev
  520. * @acl_mac: mac to add
  521. *
  522. * Return: 0 on success, negative errno on failure
  523. */
  524. int os_if_son_add_acl_mac(struct wlan_objmgr_vdev *vdev,
  525. struct qdf_mac_addr *acl_mac);
  526. /**
  527. * os_if_son_get_sta_space() - get sta space
  528. * @vdev: target vdev
  529. *
  530. * Return: bytes which is needed to fill sta information
  531. */
  532. uint32_t os_if_son_get_sta_space(struct wlan_objmgr_vdev *vdev);
  533. /**
  534. * os_if_son_get_sta_list() - get sta list
  535. * @vdev: target vdev
  536. * @si: pointer to ieee80211req_sta_info
  537. * @space: space left
  538. *
  539. * Return: void
  540. */
  541. void os_if_son_get_sta_list(struct wlan_objmgr_vdev *vdev,
  542. struct ieee80211req_sta_info *si, uint32_t *space);
  543. /**
  544. * os_if_son_del_acl_mac() - del mac from acl
  545. * @vdev: vdev
  546. * @acl_mac: mac to del
  547. *
  548. * Return: 0 on success, negative errno on failure
  549. */
  550. int os_if_son_del_acl_mac(struct wlan_objmgr_vdev *vdev,
  551. struct qdf_mac_addr *acl_mac);
  552. /**
  553. * os_if_son_kickout_mac() - kickout sta with given mac
  554. * @vdev: vdev
  555. * @acl_mac: sta mac to kickout
  556. *
  557. * Return: 0 on success, negative errno on failure
  558. */
  559. int os_if_son_kickout_mac(struct wlan_objmgr_vdev *vdev,
  560. struct qdf_mac_addr *mac);
  561. /**
  562. * os_if_son_set_chwidth() - set chan width
  563. * @vdev: vdev
  564. * @son_chwidth: son chan width
  565. *
  566. * Return: 0 on success, negative errno on failure
  567. */
  568. int os_if_son_set_chwidth(struct wlan_objmgr_vdev *vdev,
  569. enum ieee80211_cwm_width son_chwidth);
  570. /**
  571. * os_if_son_get_chwidth() - get chan width
  572. * @vdev: vdev
  573. *
  574. * Return: son chan width
  575. */
  576. enum ieee80211_cwm_width os_if_son_get_chwidth(struct wlan_objmgr_vdev *vdev);
  577. /**
  578. * os_if_son_deauth_peer_sta - Deauths specified STA
  579. * @vdev: vdev
  580. * @peer_mac: Target peer MAC address
  581. * @ignore_frame: True to silently deauth the peer
  582. *
  583. * Return: void
  584. */
  585. void os_if_son_deauth_peer_sta(struct wlan_objmgr_vdev *vdev,
  586. uint8_t *peer_mac,
  587. bool ignore_frame);
  588. /**
  589. * os_if_son_modify_acl - Updates ACL with given peer
  590. * @vdev: vdev
  591. * @peer_mac: Target peer MAC address
  592. * @allow_auth: True to allow specified peer to connect
  593. *
  594. * Return: void
  595. */
  596. void os_if_son_modify_acl(struct wlan_objmgr_vdev *vdev,
  597. uint8_t *peer_mac,
  598. bool allow_auth);
  599. /**
  600. * os_if_son_deliver_ald_event() - deliver ald events to son
  601. * @vdev: vdev object
  602. * @peer: peer object
  603. * @event: Name of the event
  604. * @event_data: event data
  605. *
  606. * Return: 0 on success
  607. */
  608. int os_if_son_deliver_ald_event(struct wlan_objmgr_vdev *vdev,
  609. struct wlan_objmgr_peer *peer,
  610. enum ieee80211_event_type event,
  611. void *event_data);
  612. /**
  613. * os_if_son_get_vdev_by_netdev() - Get vdev from net device
  614. * @dev: net device struct
  615. *
  616. * Return: objmgr vdev on success else NULL
  617. */
  618. struct wlan_objmgr_vdev *os_if_son_get_vdev_by_netdev(struct net_device *dev);
  619. /**
  620. * os_if_son_trigger_objmgr_object_deletion() - Trigger objmgr object deletion
  621. * @id: umac component id
  622. *
  623. * Return: QDF_STATUS_SUCCESS on success
  624. */
  625. QDF_STATUS os_if_son_trigger_objmgr_object_deletion(enum wlan_umac_comp_id id);
  626. /**
  627. * os_if_son_trigger_objmgr_object_creation() - Trigger objmgr object creation
  628. * @id: umac component id
  629. *
  630. * Return: QDF_STATUS_SUCCESS on success
  631. */
  632. QDF_STATUS os_if_son_trigger_objmgr_object_creation(enum wlan_umac_comp_id id);
  633. /**
  634. * os_if_son_start_acs() - Triggers ACS on the target vdev
  635. * @vdev: target vdev
  636. * @enable: True - to start ACS
  637. *
  638. * Return: 0 on success
  639. */
  640. int os_if_son_start_acs(struct wlan_objmgr_vdev *vdev, uint8_t enable);
  641. /**
  642. * os_if_son_set_acs_chan() - Set channel list for ACS
  643. * @vdev: target vdev
  644. * @req: channel list
  645. *
  646. * Return: 0 on success
  647. */
  648. int os_if_son_set_acs_chan(struct wlan_objmgr_vdev *vdev,
  649. struct ieee80211req_athdbg *req);
  650. /**
  651. * os_if_son_get_acs_report() - Get ACS report
  652. * @vdev: target vdev
  653. * @acs_r: ACS report structure
  654. *
  655. * Return: 0 on success
  656. */
  657. int os_if_son_get_acs_report(struct wlan_objmgr_vdev *vdev,
  658. struct ieee80211_acs_dbg *acs_r);
  659. /**
  660. * os_if_son_parse_generic_nl_cmd() - Sends the Generic vendor commands
  661. * to SON.
  662. * @wiphy: Standard wiphy object
  663. * @wdev: wireless device
  664. * @tb: Command type structure pointer
  665. * @type: Get/Set command
  666. *
  667. * This function parses the GENERIC vendor commands received from
  668. * userspace then sends the extracted data to SON module for further
  669. * processing along with wiphy, wdev, extected structure - param
  670. * and command type i.e. GET / SET. Each of the GENERIC commands are
  671. * interdependent and hence in SON module, they will be further
  672. * parsed based on type i.e. GET / SET.
  673. *
  674. * Return: 0 on success
  675. */
  676. int os_if_son_parse_generic_nl_cmd(struct wiphy *wiphy,
  677. struct wireless_dev *wdev,
  678. struct nlattr **tb,
  679. enum os_if_son_vendor_cmd_type type);
  680. #endif