driver_i.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602
  1. /*
  2. * wpa_supplicant - Internal driver interface wrappers
  3. * Copyright (c) 2003-2009, Jouni Malinen <j@w1.fi>
  4. *
  5. * This software may be distributed under the terms of the BSD license.
  6. * See README for more details.
  7. */
  8. #ifndef DRIVER_I_H
  9. #define DRIVER_I_H
  10. #include "drivers/driver.h"
  11. /* driver_ops */
  12. static inline void * wpa_drv_init(struct wpa_supplicant *wpa_s,
  13. const char *ifname)
  14. {
  15. if (wpa_s->driver->init2)
  16. return wpa_s->driver->init2(wpa_s, ifname,
  17. wpa_s->global_drv_priv);
  18. if (wpa_s->driver->init) {
  19. return wpa_s->driver->init(wpa_s, ifname);
  20. }
  21. return NULL;
  22. }
  23. static inline void wpa_drv_deinit(struct wpa_supplicant *wpa_s)
  24. {
  25. if (wpa_s->driver->deinit)
  26. wpa_s->driver->deinit(wpa_s->drv_priv);
  27. }
  28. static inline int wpa_drv_set_param(struct wpa_supplicant *wpa_s,
  29. const char *param)
  30. {
  31. if (wpa_s->driver->set_param)
  32. return wpa_s->driver->set_param(wpa_s->drv_priv, param);
  33. return 0;
  34. }
  35. static inline int wpa_drv_set_countermeasures(struct wpa_supplicant *wpa_s,
  36. int enabled)
  37. {
  38. if (wpa_s->driver->set_countermeasures) {
  39. return wpa_s->driver->set_countermeasures(wpa_s->drv_priv,
  40. enabled);
  41. }
  42. return -1;
  43. }
  44. static inline int wpa_drv_authenticate(struct wpa_supplicant *wpa_s,
  45. struct wpa_driver_auth_params *params)
  46. {
  47. if (wpa_s->driver->authenticate)
  48. return wpa_s->driver->authenticate(wpa_s->drv_priv, params);
  49. return -1;
  50. }
  51. static inline int wpa_drv_associate(struct wpa_supplicant *wpa_s,
  52. struct wpa_driver_associate_params *params)
  53. {
  54. if (wpa_s->driver->associate) {
  55. return wpa_s->driver->associate(wpa_s->drv_priv, params);
  56. }
  57. return -1;
  58. }
  59. static inline int wpa_drv_scan(struct wpa_supplicant *wpa_s,
  60. struct wpa_driver_scan_params *params)
  61. {
  62. if (wpa_s->driver->scan2)
  63. return wpa_s->driver->scan2(wpa_s->drv_priv, params);
  64. return -1;
  65. }
  66. static inline int wpa_drv_sched_scan(struct wpa_supplicant *wpa_s,
  67. struct wpa_driver_scan_params *params,
  68. u32 interval)
  69. {
  70. if (wpa_s->driver->sched_scan)
  71. return wpa_s->driver->sched_scan(wpa_s->drv_priv,
  72. params, interval);
  73. return -1;
  74. }
  75. static inline int wpa_drv_stop_sched_scan(struct wpa_supplicant *wpa_s)
  76. {
  77. if (wpa_s->driver->stop_sched_scan)
  78. return wpa_s->driver->stop_sched_scan(wpa_s->drv_priv);
  79. return -1;
  80. }
  81. static inline struct wpa_scan_results * wpa_drv_get_scan_results2(
  82. struct wpa_supplicant *wpa_s)
  83. {
  84. if (wpa_s->driver->get_scan_results2)
  85. return wpa_s->driver->get_scan_results2(wpa_s->drv_priv);
  86. return NULL;
  87. }
  88. static inline int wpa_drv_get_bssid(struct wpa_supplicant *wpa_s, u8 *bssid)
  89. {
  90. if (wpa_s->driver->get_bssid) {
  91. return wpa_s->driver->get_bssid(wpa_s->drv_priv, bssid);
  92. }
  93. return -1;
  94. }
  95. static inline int wpa_drv_get_ssid(struct wpa_supplicant *wpa_s, u8 *ssid)
  96. {
  97. if (wpa_s->driver->get_ssid) {
  98. return wpa_s->driver->get_ssid(wpa_s->drv_priv, ssid);
  99. }
  100. return -1;
  101. }
  102. static inline int wpa_drv_set_key(struct wpa_supplicant *wpa_s,
  103. enum wpa_alg alg, const u8 *addr,
  104. int key_idx, int set_tx,
  105. const u8 *seq, size_t seq_len,
  106. const u8 *key, size_t key_len)
  107. {
  108. if (wpa_s->driver->set_key) {
  109. wpa_s->keys_cleared = 0;
  110. return wpa_s->driver->set_key(wpa_s->ifname, wpa_s->drv_priv,
  111. alg, addr, key_idx, set_tx,
  112. seq, seq_len, key, key_len);
  113. }
  114. return -1;
  115. }
  116. static inline int wpa_drv_sta_deauth(struct wpa_supplicant *wpa_s,
  117. const u8 *addr, int reason_code)
  118. {
  119. if (wpa_s->driver->sta_deauth) {
  120. return wpa_s->driver->sta_deauth(wpa_s->drv_priv,
  121. wpa_s->own_addr, addr,
  122. reason_code);
  123. }
  124. return -1;
  125. }
  126. static inline int wpa_drv_deauthenticate(struct wpa_supplicant *wpa_s,
  127. const u8 *addr, int reason_code)
  128. {
  129. if (wpa_s->driver->deauthenticate) {
  130. return wpa_s->driver->deauthenticate(wpa_s->drv_priv, addr,
  131. reason_code);
  132. }
  133. return -1;
  134. }
  135. static inline int wpa_drv_add_pmkid(struct wpa_supplicant *wpa_s,
  136. const u8 *bssid, const u8 *pmkid)
  137. {
  138. if (wpa_s->driver->add_pmkid) {
  139. return wpa_s->driver->add_pmkid(wpa_s->drv_priv, bssid, pmkid);
  140. }
  141. return -1;
  142. }
  143. static inline int wpa_drv_remove_pmkid(struct wpa_supplicant *wpa_s,
  144. const u8 *bssid, const u8 *pmkid)
  145. {
  146. if (wpa_s->driver->remove_pmkid) {
  147. return wpa_s->driver->remove_pmkid(wpa_s->drv_priv, bssid,
  148. pmkid);
  149. }
  150. return -1;
  151. }
  152. static inline int wpa_drv_flush_pmkid(struct wpa_supplicant *wpa_s)
  153. {
  154. if (wpa_s->driver->flush_pmkid) {
  155. return wpa_s->driver->flush_pmkid(wpa_s->drv_priv);
  156. }
  157. return -1;
  158. }
  159. static inline int wpa_drv_get_capa(struct wpa_supplicant *wpa_s,
  160. struct wpa_driver_capa *capa)
  161. {
  162. if (wpa_s->driver->get_capa) {
  163. return wpa_s->driver->get_capa(wpa_s->drv_priv, capa);
  164. }
  165. return -1;
  166. }
  167. static inline void wpa_drv_poll(struct wpa_supplicant *wpa_s)
  168. {
  169. if (wpa_s->driver->poll) {
  170. wpa_s->driver->poll(wpa_s->drv_priv);
  171. }
  172. }
  173. static inline const char * wpa_drv_get_ifname(struct wpa_supplicant *wpa_s)
  174. {
  175. if (wpa_s->driver->get_ifname) {
  176. return wpa_s->driver->get_ifname(wpa_s->drv_priv);
  177. }
  178. return NULL;
  179. }
  180. static inline const u8 * wpa_drv_get_mac_addr(struct wpa_supplicant *wpa_s)
  181. {
  182. if (wpa_s->driver->get_mac_addr) {
  183. return wpa_s->driver->get_mac_addr(wpa_s->drv_priv);
  184. }
  185. return NULL;
  186. }
  187. static inline int wpa_drv_send_eapol(struct wpa_supplicant *wpa_s,
  188. const u8 *dst, u16 proto,
  189. const u8 *data, size_t data_len)
  190. {
  191. if (wpa_s->driver->send_eapol)
  192. return wpa_s->driver->send_eapol(wpa_s->drv_priv, dst, proto,
  193. data, data_len);
  194. return -1;
  195. }
  196. static inline int wpa_drv_set_operstate(struct wpa_supplicant *wpa_s,
  197. int state)
  198. {
  199. if (wpa_s->driver->set_operstate)
  200. return wpa_s->driver->set_operstate(wpa_s->drv_priv, state);
  201. return 0;
  202. }
  203. static inline int wpa_drv_mlme_setprotection(struct wpa_supplicant *wpa_s,
  204. const u8 *addr, int protect_type,
  205. int key_type)
  206. {
  207. if (wpa_s->driver->mlme_setprotection)
  208. return wpa_s->driver->mlme_setprotection(wpa_s->drv_priv, addr,
  209. protect_type,
  210. key_type);
  211. return 0;
  212. }
  213. static inline struct hostapd_hw_modes *
  214. wpa_drv_get_hw_feature_data(struct wpa_supplicant *wpa_s, u16 *num_modes,
  215. u16 *flags)
  216. {
  217. if (wpa_s->driver->get_hw_feature_data)
  218. return wpa_s->driver->get_hw_feature_data(wpa_s->drv_priv,
  219. num_modes, flags);
  220. return NULL;
  221. }
  222. static inline int wpa_drv_set_country(struct wpa_supplicant *wpa_s,
  223. const char *alpha2)
  224. {
  225. if (wpa_s->driver->set_country)
  226. return wpa_s->driver->set_country(wpa_s->drv_priv, alpha2);
  227. return 0;
  228. }
  229. static inline int wpa_drv_send_mlme(struct wpa_supplicant *wpa_s,
  230. const u8 *data, size_t data_len, int noack)
  231. {
  232. if (wpa_s->driver->send_mlme)
  233. return wpa_s->driver->send_mlme(wpa_s->drv_priv,
  234. data, data_len, noack);
  235. return -1;
  236. }
  237. static inline int wpa_drv_update_ft_ies(struct wpa_supplicant *wpa_s,
  238. const u8 *md,
  239. const u8 *ies, size_t ies_len)
  240. {
  241. if (wpa_s->driver->update_ft_ies)
  242. return wpa_s->driver->update_ft_ies(wpa_s->drv_priv, md,
  243. ies, ies_len);
  244. return -1;
  245. }
  246. static inline int wpa_drv_send_ft_action(struct wpa_supplicant *wpa_s,
  247. u8 action, const u8 *target_ap,
  248. const u8 *ies, size_t ies_len)
  249. {
  250. if (wpa_s->driver->send_ft_action)
  251. return wpa_s->driver->send_ft_action(wpa_s->drv_priv, action,
  252. target_ap, ies, ies_len);
  253. return -1;
  254. }
  255. static inline int wpa_drv_set_ap(struct wpa_supplicant *wpa_s,
  256. struct wpa_driver_ap_params *params)
  257. {
  258. if (wpa_s->driver->set_ap)
  259. return wpa_s->driver->set_ap(wpa_s->drv_priv, params);
  260. return -1;
  261. }
  262. static inline int wpa_drv_sta_add(struct wpa_supplicant *wpa_s,
  263. struct hostapd_sta_add_params *params)
  264. {
  265. if (wpa_s->driver->sta_add)
  266. return wpa_s->driver->sta_add(wpa_s->drv_priv, params);
  267. return -1;
  268. }
  269. static inline int wpa_drv_sta_remove(struct wpa_supplicant *wpa_s,
  270. const u8 *addr)
  271. {
  272. if (wpa_s->driver->sta_remove)
  273. return wpa_s->driver->sta_remove(wpa_s->drv_priv, addr);
  274. return -1;
  275. }
  276. static inline int wpa_drv_hapd_send_eapol(struct wpa_supplicant *wpa_s,
  277. const u8 *addr, const u8 *data,
  278. size_t data_len, int encrypt,
  279. const u8 *own_addr, u32 flags)
  280. {
  281. if (wpa_s->driver->hapd_send_eapol)
  282. return wpa_s->driver->hapd_send_eapol(wpa_s->drv_priv, addr,
  283. data, data_len, encrypt,
  284. own_addr, flags);
  285. return -1;
  286. }
  287. static inline int wpa_drv_sta_set_flags(struct wpa_supplicant *wpa_s,
  288. const u8 *addr, int total_flags,
  289. int flags_or, int flags_and)
  290. {
  291. if (wpa_s->driver->sta_set_flags)
  292. return wpa_s->driver->sta_set_flags(wpa_s->drv_priv, addr,
  293. total_flags, flags_or,
  294. flags_and);
  295. return -1;
  296. }
  297. static inline int wpa_drv_set_supp_port(struct wpa_supplicant *wpa_s,
  298. int authorized)
  299. {
  300. if (wpa_s->driver->set_supp_port) {
  301. return wpa_s->driver->set_supp_port(wpa_s->drv_priv,
  302. authorized);
  303. }
  304. return 0;
  305. }
  306. static inline int wpa_drv_send_action(struct wpa_supplicant *wpa_s,
  307. unsigned int freq,
  308. unsigned int wait,
  309. const u8 *dst, const u8 *src,
  310. const u8 *bssid,
  311. const u8 *data, size_t data_len,
  312. int no_cck)
  313. {
  314. if (wpa_s->driver->send_action)
  315. return wpa_s->driver->send_action(wpa_s->drv_priv, freq,
  316. wait, dst, src, bssid,
  317. data, data_len, no_cck);
  318. return -1;
  319. }
  320. static inline void wpa_drv_send_action_cancel_wait(struct wpa_supplicant *wpa_s)
  321. {
  322. if (wpa_s->driver->send_action_cancel_wait)
  323. wpa_s->driver->send_action_cancel_wait(wpa_s->drv_priv);
  324. }
  325. static inline int wpa_drv_set_freq(struct wpa_supplicant *wpa_s,
  326. struct hostapd_freq_params *freq)
  327. {
  328. if (wpa_s->driver->set_freq)
  329. return wpa_s->driver->set_freq(wpa_s->drv_priv, freq);
  330. return -1;
  331. }
  332. static inline int wpa_drv_if_add(struct wpa_supplicant *wpa_s,
  333. enum wpa_driver_if_type type,
  334. const char *ifname, const u8 *addr,
  335. void *bss_ctx, char *force_ifname,
  336. u8 *if_addr, const char *bridge)
  337. {
  338. if (wpa_s->driver->if_add)
  339. return wpa_s->driver->if_add(wpa_s->drv_priv, type, ifname,
  340. addr, bss_ctx, NULL, force_ifname,
  341. if_addr, bridge, 0);
  342. return -1;
  343. }
  344. static inline int wpa_drv_if_remove(struct wpa_supplicant *wpa_s,
  345. enum wpa_driver_if_type type,
  346. const char *ifname)
  347. {
  348. if (wpa_s->driver->if_remove)
  349. return wpa_s->driver->if_remove(wpa_s->drv_priv, type, ifname);
  350. return -1;
  351. }
  352. static inline int wpa_drv_remain_on_channel(struct wpa_supplicant *wpa_s,
  353. unsigned int freq,
  354. unsigned int duration)
  355. {
  356. if (wpa_s->driver->remain_on_channel)
  357. return wpa_s->driver->remain_on_channel(wpa_s->drv_priv, freq,
  358. duration);
  359. return -1;
  360. }
  361. static inline int wpa_drv_cancel_remain_on_channel(
  362. struct wpa_supplicant *wpa_s)
  363. {
  364. if (wpa_s->driver->cancel_remain_on_channel)
  365. return wpa_s->driver->cancel_remain_on_channel(
  366. wpa_s->drv_priv);
  367. return -1;
  368. }
  369. static inline int wpa_drv_probe_req_report(struct wpa_supplicant *wpa_s,
  370. int report)
  371. {
  372. if (wpa_s->driver->probe_req_report)
  373. return wpa_s->driver->probe_req_report(wpa_s->drv_priv,
  374. report);
  375. return -1;
  376. }
  377. static inline int wpa_drv_deinit_ap(struct wpa_supplicant *wpa_s)
  378. {
  379. if (wpa_s->driver->deinit_ap)
  380. return wpa_s->driver->deinit_ap(wpa_s->drv_priv);
  381. return 0;
  382. }
  383. static inline int wpa_drv_deinit_p2p_cli(struct wpa_supplicant *wpa_s)
  384. {
  385. if (wpa_s->driver->deinit_p2p_cli)
  386. return wpa_s->driver->deinit_p2p_cli(wpa_s->drv_priv);
  387. return 0;
  388. }
  389. static inline void wpa_drv_suspend(struct wpa_supplicant *wpa_s)
  390. {
  391. if (wpa_s->driver->suspend)
  392. wpa_s->driver->suspend(wpa_s->drv_priv);
  393. }
  394. static inline void wpa_drv_resume(struct wpa_supplicant *wpa_s)
  395. {
  396. if (wpa_s->driver->resume)
  397. wpa_s->driver->resume(wpa_s->drv_priv);
  398. }
  399. static inline int wpa_drv_signal_monitor(struct wpa_supplicant *wpa_s,
  400. int threshold, int hysteresis)
  401. {
  402. if (wpa_s->driver->signal_monitor)
  403. return wpa_s->driver->signal_monitor(wpa_s->drv_priv,
  404. threshold, hysteresis);
  405. return -1;
  406. }
  407. static inline int wpa_drv_signal_poll(struct wpa_supplicant *wpa_s,
  408. struct wpa_signal_info *si)
  409. {
  410. if (wpa_s->driver->signal_poll)
  411. return wpa_s->driver->signal_poll(wpa_s->drv_priv, si);
  412. return -1;
  413. }
  414. static inline int wpa_drv_pktcnt_poll(struct wpa_supplicant *wpa_s,
  415. struct hostap_sta_driver_data *sta)
  416. {
  417. if (wpa_s->driver->read_sta_data)
  418. return wpa_s->driver->read_sta_data(wpa_s->drv_priv, sta,
  419. wpa_s->bssid);
  420. return -1;
  421. }
  422. static inline int wpa_drv_set_ap_wps_ie(struct wpa_supplicant *wpa_s,
  423. const struct wpabuf *beacon,
  424. const struct wpabuf *proberesp,
  425. const struct wpabuf *assocresp)
  426. {
  427. if (!wpa_s->driver->set_ap_wps_ie)
  428. return -1;
  429. return wpa_s->driver->set_ap_wps_ie(wpa_s->drv_priv, beacon,
  430. proberesp, assocresp);
  431. }
  432. static inline int wpa_drv_shared_freq(struct wpa_supplicant *wpa_s)
  433. {
  434. if (!wpa_s->driver->shared_freq)
  435. return -1;
  436. return wpa_s->driver->shared_freq(wpa_s->drv_priv);
  437. }
  438. static inline int wpa_drv_get_noa(struct wpa_supplicant *wpa_s,
  439. u8 *buf, size_t buf_len)
  440. {
  441. if (!wpa_s->driver->get_noa)
  442. return -1;
  443. return wpa_s->driver->get_noa(wpa_s->drv_priv, buf, buf_len);
  444. }
  445. static inline int wpa_drv_set_p2p_powersave(struct wpa_supplicant *wpa_s,
  446. int legacy_ps, int opp_ps,
  447. int ctwindow)
  448. {
  449. if (!wpa_s->driver->set_p2p_powersave)
  450. return -1;
  451. return wpa_s->driver->set_p2p_powersave(wpa_s->drv_priv, legacy_ps,
  452. opp_ps, ctwindow);
  453. }
  454. static inline int wpa_drv_ampdu(struct wpa_supplicant *wpa_s, int ampdu)
  455. {
  456. if (!wpa_s->driver->ampdu)
  457. return -1;
  458. return wpa_s->driver->ampdu(wpa_s->drv_priv, ampdu);
  459. }
  460. static inline int wpa_drv_send_tdls_mgmt(struct wpa_supplicant *wpa_s,
  461. const u8 *dst, u8 action_code,
  462. u8 dialog_token, u16 status_code,
  463. const u8 *buf, size_t len)
  464. {
  465. if (wpa_s->driver->send_tdls_mgmt) {
  466. return wpa_s->driver->send_tdls_mgmt(wpa_s->drv_priv, dst,
  467. action_code, dialog_token,
  468. status_code, buf, len);
  469. }
  470. return -1;
  471. }
  472. static inline int wpa_drv_tdls_oper(struct wpa_supplicant *wpa_s,
  473. enum tdls_oper oper, const u8 *peer)
  474. {
  475. if (!wpa_s->driver->tdls_oper)
  476. return -1;
  477. return wpa_s->driver->tdls_oper(wpa_s->drv_priv, oper, peer);
  478. }
  479. #ifdef ANDROID
  480. static inline int wpa_drv_driver_cmd(struct wpa_supplicant *wpa_s,
  481. char *cmd, char *buf, size_t buf_len)
  482. {
  483. if (!wpa_s->driver->driver_cmd)
  484. return -1;
  485. return wpa_s->driver->driver_cmd(wpa_s->drv_priv, cmd, buf, buf_len);
  486. }
  487. #endif /* ANDROID */
  488. static inline void wpa_drv_set_rekey_info(struct wpa_supplicant *wpa_s,
  489. const u8 *kek, const u8 *kck,
  490. const u8 *replay_ctr)
  491. {
  492. if (!wpa_s->driver->set_rekey_info)
  493. return;
  494. wpa_s->driver->set_rekey_info(wpa_s->drv_priv, kek, kck, replay_ctr);
  495. }
  496. static inline int wpa_drv_radio_disable(struct wpa_supplicant *wpa_s,
  497. int disabled)
  498. {
  499. if (!wpa_s->driver->radio_disable)
  500. return -1;
  501. return wpa_s->driver->radio_disable(wpa_s->drv_priv, disabled);
  502. }
  503. static inline int wpa_drv_switch_channel(struct wpa_supplicant *wpa_s,
  504. struct csa_settings *settings)
  505. {
  506. if (!wpa_s->driver->switch_channel)
  507. return -1;
  508. return wpa_s->driver->switch_channel(wpa_s->drv_priv, settings);
  509. }
  510. static inline int wpa_drv_wnm_oper(struct wpa_supplicant *wpa_s,
  511. enum wnm_oper oper, const u8 *peer,
  512. u8 *buf, u16 *buf_len)
  513. {
  514. if (!wpa_s->driver->wnm_oper)
  515. return -1;
  516. return wpa_s->driver->wnm_oper(wpa_s->drv_priv, oper, peer, buf,
  517. buf_len);
  518. }
  519. static inline int wpa_drv_status(struct wpa_supplicant *wpa_s,
  520. char *buf, size_t buflen)
  521. {
  522. if (!wpa_s->driver->status)
  523. return -1;
  524. return wpa_s->driver->status(wpa_s->drv_priv, buf, buflen);
  525. }
  526. static inline int wpa_drv_set_qos_map(struct wpa_supplicant *wpa_s,
  527. const u8 *qos_map_set, u8 qos_map_set_len)
  528. {
  529. if (!wpa_s->driver->set_qos_map)
  530. return -1;
  531. return wpa_s->driver->set_qos_map(wpa_s->drv_priv, qos_map_set,
  532. qos_map_set_len);
  533. }
  534. #endif /* DRIVER_I_H */