wmi_unified_roam_api.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. /*
  2. * Copyright (c) 2013-2020, The Linux Foundation. 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. #include <osdep.h>
  17. #include <wmi.h>
  18. #include <wmi_unified_priv.h>
  19. #include <wmi_unified_roam_param.h>
  20. #include <wmi_unified_roam_api.h>
  21. #ifdef FEATURE_LFR_SUBNET_DETECTION
  22. QDF_STATUS
  23. wmi_unified_set_gateway_params_cmd(wmi_unified_t wmi_handle,
  24. struct gateway_update_req_param *req)
  25. {
  26. if (wmi_handle->ops->send_set_gateway_params_cmd)
  27. return wmi_handle->ops->send_set_gateway_params_cmd(wmi_handle,
  28. req);
  29. return QDF_STATUS_E_FAILURE;
  30. }
  31. #endif /* FEATURE_LFR_SUBNET_DETECTION */
  32. #ifdef FEATURE_RSSI_MONITOR
  33. QDF_STATUS
  34. wmi_unified_set_rssi_monitoring_cmd(wmi_unified_t wmi_handle,
  35. struct rssi_monitor_param *req)
  36. {
  37. if (wmi_handle->ops->send_set_rssi_monitoring_cmd)
  38. return wmi_handle->ops->send_set_rssi_monitoring_cmd(wmi_handle,
  39. req);
  40. return QDF_STATUS_E_FAILURE;
  41. }
  42. #endif /* FEATURE_RSSI_MONITOR */
  43. #ifdef ROAM_OFFLOAD_V1
  44. QDF_STATUS wmi_unified_roam_scan_offload_rssi_thresh_cmd(
  45. wmi_unified_t wmi_handle,
  46. struct wlan_roam_offload_scan_rssi_params *roam_req)
  47. {
  48. if (wmi_handle->ops->send_roam_scan_offload_rssi_thresh_cmd)
  49. return wmi_handle->ops->send_roam_scan_offload_rssi_thresh_cmd(
  50. wmi_handle, roam_req);
  51. return QDF_STATUS_E_FAILURE;
  52. }
  53. QDF_STATUS
  54. wmi_unified_roam_scan_offload_scan_period(
  55. wmi_unified_t wmi_handle,
  56. struct wlan_roam_scan_period_params *param)
  57. {
  58. if (wmi_handle->ops->send_roam_scan_offload_scan_period_cmd)
  59. return wmi_handle->ops->send_roam_scan_offload_scan_period_cmd(
  60. wmi_handle, param);
  61. return QDF_STATUS_E_FAILURE;
  62. }
  63. #else
  64. QDF_STATUS wmi_unified_roam_scan_offload_rssi_thresh_cmd(
  65. wmi_unified_t wmi_handle,
  66. struct roam_offload_scan_rssi_params *roam_req)
  67. {
  68. if (wmi_handle->ops->send_roam_scan_offload_rssi_thresh_cmd)
  69. return wmi_handle->ops->send_roam_scan_offload_rssi_thresh_cmd(
  70. wmi_handle, roam_req);
  71. return QDF_STATUS_E_FAILURE;
  72. }
  73. QDF_STATUS
  74. wmi_unified_roam_scan_offload_scan_period(wmi_unified_t wmi_handle,
  75. struct roam_scan_period_params *param)
  76. {
  77. if (wmi_handle->ops->send_roam_scan_offload_scan_period_cmd)
  78. return wmi_handle->ops->send_roam_scan_offload_scan_period_cmd(
  79. wmi_handle, param);
  80. return QDF_STATUS_E_FAILURE;
  81. }
  82. #endif
  83. QDF_STATUS wmi_unified_roam_mawc_params_cmd(
  84. wmi_unified_t wmi_handle,
  85. struct wmi_mawc_roam_params *params)
  86. {
  87. if (wmi_handle->ops->send_roam_mawc_params_cmd)
  88. return wmi_handle->ops->send_roam_mawc_params_cmd(wmi_handle,
  89. params);
  90. return QDF_STATUS_E_FAILURE;
  91. }
  92. QDF_STATUS
  93. wmi_unified_roam_scan_filter_cmd(wmi_unified_t wmi_handle,
  94. struct roam_scan_filter_params *roam_req)
  95. {
  96. if (wmi_handle->ops->send_roam_scan_filter_cmd)
  97. return wmi_handle->ops->send_roam_scan_filter_cmd(wmi_handle,
  98. roam_req);
  99. return QDF_STATUS_E_FAILURE;
  100. }
  101. #ifdef FEATURE_WLAN_ESE
  102. QDF_STATUS wmi_unified_plm_stop_cmd(wmi_unified_t wmi_handle,
  103. const struct plm_req_params *plm)
  104. {
  105. if (wmi_handle->ops->send_plm_stop_cmd)
  106. return wmi_handle->ops->send_plm_stop_cmd(wmi_handle, plm);
  107. return QDF_STATUS_E_FAILURE;
  108. }
  109. QDF_STATUS wmi_unified_plm_start_cmd(wmi_unified_t wmi_handle,
  110. const struct plm_req_params *plm)
  111. {
  112. if (wmi_handle->ops->send_plm_start_cmd)
  113. return wmi_handle->ops->send_plm_start_cmd(wmi_handle, plm);
  114. return QDF_STATUS_E_FAILURE;
  115. }
  116. #endif /* FEATURE_WLAN_ESE */
  117. #ifdef WLAN_FEATURE_ROAM_OFFLOAD
  118. QDF_STATUS wmi_unified_set_ric_req_cmd(wmi_unified_t wmi_handle, void *msg,
  119. uint8_t is_add_ts)
  120. {
  121. if (wmi_handle->ops->send_set_ric_req_cmd)
  122. return wmi_handle->ops->send_set_ric_req_cmd(wmi_handle, msg,
  123. is_add_ts);
  124. return QDF_STATUS_E_FAILURE;
  125. }
  126. QDF_STATUS wmi_unified_roam_synch_complete_cmd(wmi_unified_t wmi_handle,
  127. uint8_t vdev_id)
  128. {
  129. if (wmi_handle->ops->send_process_roam_synch_complete_cmd)
  130. return wmi_handle->ops->send_process_roam_synch_complete_cmd(
  131. wmi_handle, vdev_id);
  132. return QDF_STATUS_E_FAILURE;
  133. }
  134. QDF_STATUS wmi_unified_roam_invoke_cmd(wmi_unified_t wmi_handle,
  135. struct wmi_roam_invoke_cmd *roaminvoke,
  136. uint32_t ch_hz)
  137. {
  138. if (wmi_handle->ops->send_roam_invoke_cmd)
  139. return wmi_handle->ops->send_roam_invoke_cmd(wmi_handle,
  140. roaminvoke,
  141. ch_hz);
  142. return QDF_STATUS_E_FAILURE;
  143. }
  144. QDF_STATUS
  145. wmi_unified_send_disconnect_roam_params(wmi_unified_t wmi_handle,
  146. struct wlan_roam_disconnect_params *req)
  147. {
  148. if (wmi_handle->ops->send_disconnect_roam_params)
  149. return wmi_handle->ops->send_disconnect_roam_params(wmi_handle,
  150. req);
  151. return QDF_STATUS_E_FAILURE;
  152. }
  153. QDF_STATUS
  154. wmi_unified_send_idle_roam_params(wmi_unified_t wmi_handle,
  155. struct wlan_roam_idle_params *req)
  156. {
  157. if (wmi_handle->ops->send_idle_roam_params)
  158. return wmi_handle->ops->send_idle_roam_params(wmi_handle,
  159. req);
  160. return QDF_STATUS_E_FAILURE;
  161. }
  162. QDF_STATUS
  163. wmi_unified_send_roam_preauth_status(wmi_unified_t wmi_handle,
  164. struct wmi_roam_auth_status_params *params)
  165. {
  166. if (wmi_handle->ops->send_roam_preauth_status)
  167. return wmi_handle->ops->send_roam_preauth_status(wmi_handle,
  168. params);
  169. return QDF_STATUS_E_FAILURE;
  170. }
  171. QDF_STATUS wmi_unified_vdev_set_pcl_cmd(wmi_unified_t wmi_handle,
  172. struct set_pcl_cmd_params *params)
  173. {
  174. if (wmi_handle->ops->send_vdev_set_pcl_cmd)
  175. return wmi_handle->ops->send_vdev_set_pcl_cmd(wmi_handle,
  176. params);
  177. return QDF_STATUS_E_FAILURE;
  178. }
  179. #endif /* WLAN_FEATURE_ROAM_OFFLOAD */
  180. QDF_STATUS wmi_unified_roam_scan_offload_mode_cmd(
  181. wmi_unified_t wmi_handle,
  182. wmi_start_scan_cmd_fixed_param *scan_cmd_fp,
  183. struct roam_offload_scan_params *roam_req)
  184. {
  185. if (wmi_handle->ops->send_roam_scan_offload_mode_cmd)
  186. return wmi_handle->ops->send_roam_scan_offload_mode_cmd(
  187. wmi_handle, scan_cmd_fp, roam_req);
  188. return QDF_STATUS_E_FAILURE;
  189. }
  190. QDF_STATUS wmi_unified_send_roam_scan_offload_ap_cmd(
  191. wmi_unified_t wmi_handle,
  192. struct ap_profile_params *ap_profile)
  193. {
  194. if (wmi_handle->ops->send_roam_scan_offload_ap_profile_cmd)
  195. return wmi_handle->ops->send_roam_scan_offload_ap_profile_cmd(
  196. wmi_handle, ap_profile);
  197. return QDF_STATUS_E_FAILURE;
  198. }
  199. QDF_STATUS wmi_unified_roam_scan_offload_cmd(wmi_unified_t wmi_handle,
  200. uint32_t command,
  201. uint32_t vdev_id)
  202. {
  203. if (wmi_handle->ops->send_roam_scan_offload_cmd)
  204. return wmi_handle->ops->send_roam_scan_offload_cmd(wmi_handle,
  205. command,
  206. vdev_id);
  207. return QDF_STATUS_E_FAILURE;
  208. }
  209. QDF_STATUS
  210. wmi_unified_roam_scan_offload_chan_list_cmd(wmi_unified_t wmi_handle,
  211. uint8_t chan_count,
  212. uint32_t *chan_list,
  213. uint8_t list_type,
  214. uint32_t vdev_id)
  215. {
  216. if (wmi_handle->ops->send_roam_scan_offload_chan_list_cmd)
  217. return wmi_handle->ops->send_roam_scan_offload_chan_list_cmd(
  218. wmi_handle, chan_count, chan_list,
  219. list_type, vdev_id);
  220. return QDF_STATUS_E_FAILURE;
  221. }
  222. QDF_STATUS
  223. wmi_unified_roam_scan_offload_rssi_change_cmd(wmi_unified_t wmi_handle,
  224. uint32_t vdev_id,
  225. int32_t rssi_change_thresh,
  226. uint32_t bcn_rssi_weight,
  227. uint32_t hirssi_delay_btw_scans)
  228. {
  229. if (wmi_handle->ops->send_roam_scan_offload_rssi_change_cmd)
  230. return wmi_handle->ops->send_roam_scan_offload_rssi_change_cmd(
  231. wmi_handle, vdev_id, rssi_change_thresh,
  232. bcn_rssi_weight, hirssi_delay_btw_scans);
  233. return QDF_STATUS_E_FAILURE;
  234. }
  235. QDF_STATUS
  236. wmi_unified_set_per_roam_config(wmi_unified_t wmi_handle,
  237. struct wlan_per_roam_config_req *req_buf)
  238. {
  239. if (wmi_handle->ops->send_per_roam_config_cmd)
  240. return wmi_handle->ops->send_per_roam_config_cmd(wmi_handle,
  241. req_buf);
  242. return QDF_STATUS_E_FAILURE;
  243. }
  244. QDF_STATUS wmi_unified_send_limit_off_chan_cmd(
  245. wmi_unified_t wmi_handle,
  246. struct wmi_limit_off_chan_param *limit_off_chan_param)
  247. {
  248. if (wmi_handle->ops->send_limit_off_chan_cmd)
  249. return wmi_handle->ops->send_limit_off_chan_cmd(wmi_handle,
  250. limit_off_chan_param);
  251. return QDF_STATUS_E_FAILURE;
  252. }
  253. #ifdef WLAN_FEATURE_FILS_SK
  254. QDF_STATUS wmi_unified_roam_send_hlp_cmd(wmi_unified_t wmi_handle,
  255. struct hlp_params *req_buf)
  256. {
  257. if (wmi_handle->ops->send_roam_scan_hlp_cmd)
  258. return wmi_handle->ops->send_roam_scan_hlp_cmd(wmi_handle,
  259. req_buf);
  260. return QDF_STATUS_E_FAILURE;
  261. }
  262. #endif /* WLAN_FEATURE_FILS_SK */
  263. QDF_STATUS wmi_unified_send_btm_config(wmi_unified_t wmi_handle,
  264. struct wlan_roam_btm_config *params)
  265. {
  266. if (wmi_handle->ops->send_btm_config)
  267. return wmi_handle->ops->send_btm_config(wmi_handle,
  268. params);
  269. return QDF_STATUS_E_FAILURE;
  270. }
  271. QDF_STATUS wmi_unified_send_bss_load_config(wmi_unified_t wmi_handle,
  272. struct wmi_bss_load_config *params)
  273. {
  274. if (wmi_handle->ops->send_roam_bss_load_config)
  275. return wmi_handle->ops->send_roam_bss_load_config(wmi_handle,
  276. params);
  277. return QDF_STATUS_E_FAILURE;
  278. }
  279. QDF_STATUS
  280. wmi_unified_offload_11k_cmd(wmi_unified_t wmi_handle,
  281. struct wlan_roam_11k_offload_params *params)
  282. {
  283. if (wmi_handle->ops->send_offload_11k_cmd)
  284. return wmi_handle->ops->send_offload_11k_cmd(wmi_handle,
  285. params);
  286. return QDF_STATUS_E_FAILURE;
  287. }
  288. QDF_STATUS wmi_unified_invoke_neighbor_report_cmd(
  289. wmi_unified_t wmi_handle,
  290. struct wmi_invoke_neighbor_report_params *params)
  291. {
  292. if (wmi_handle->ops->send_invoke_neighbor_report_cmd)
  293. return wmi_handle->ops->send_invoke_neighbor_report_cmd(
  294. wmi_handle, params);
  295. return QDF_STATUS_E_FAILURE;
  296. }
  297. QDF_STATUS wmi_unified_get_roam_scan_ch_list(wmi_unified_t wmi_handle,
  298. uint8_t vdev_id)
  299. {
  300. if (wmi_handle->ops->send_roam_scan_ch_list_req_cmd)
  301. return wmi_handle->ops->send_roam_scan_ch_list_req_cmd(
  302. wmi_handle, vdev_id);
  303. return QDF_STATUS_E_FAILURE;
  304. }
  305. #ifdef WLAN_FEATURE_ROAM_OFFLOAD
  306. QDF_STATUS wmi_unified_set_roam_triggers(wmi_unified_t wmi_handle,
  307. struct wlan_roam_triggers *triggers)
  308. {
  309. if (wmi_handle->ops->send_set_roam_trigger_cmd)
  310. return wmi_handle->ops->send_set_roam_trigger_cmd(wmi_handle,
  311. triggers);
  312. return QDF_STATUS_E_FAILURE;
  313. }
  314. #endif