driver_i.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
  1. /*
  2. * hostapd - internal driver interface wrappers
  3. * Copyright (c) 2002-2009, Jouni Malinen <j@w1.fi>
  4. * Copyright (c) 2007-2008, Intel Corporation
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. *
  10. * Alternatively, this software may be distributed under the terms of BSD
  11. * license.
  12. *
  13. * See README and COPYING for more details.
  14. */
  15. #ifndef DRIVER_I_H
  16. #define DRIVER_I_H
  17. #include "driver.h"
  18. #include "config.h"
  19. static inline void *
  20. hostapd_driver_init(struct hostapd_data *hapd)
  21. {
  22. if (hapd->driver == NULL || hapd->driver->init == NULL)
  23. return NULL;
  24. return hapd->driver->init(hapd);
  25. }
  26. static inline void *
  27. hostapd_driver_init_bssid(struct hostapd_data *hapd, const u8 *bssid)
  28. {
  29. if (hapd->driver == NULL || hapd->driver->init_bssid == NULL)
  30. return NULL;
  31. return hapd->driver->init_bssid(hapd, bssid);
  32. }
  33. static inline void
  34. hostapd_driver_deinit(struct hostapd_data *hapd)
  35. {
  36. if (hapd->driver == NULL || hapd->driver->deinit == NULL)
  37. return;
  38. hapd->driver->deinit(hapd->drv_priv);
  39. }
  40. static inline int
  41. hostapd_set_ieee8021x(const char *ifname, struct hostapd_data *hapd,
  42. int enabled)
  43. {
  44. if (hapd->driver == NULL || hapd->driver->set_ieee8021x == NULL)
  45. return 0;
  46. return hapd->driver->set_ieee8021x(ifname, hapd->drv_priv, enabled);
  47. }
  48. static inline int
  49. hostapd_set_privacy(struct hostapd_data *hapd, int enabled)
  50. {
  51. if (hapd->driver == NULL || hapd->driver->set_privacy == NULL)
  52. return 0;
  53. return hapd->driver->set_privacy(hapd->conf->iface, hapd->drv_priv,
  54. enabled);
  55. }
  56. static inline int
  57. hostapd_set_key(const char *ifname, struct hostapd_data *hapd,
  58. wpa_alg alg, const u8 *addr, int key_idx,
  59. int set_tx, const u8 *seq, size_t seq_len,
  60. const u8 *key, size_t key_len)
  61. {
  62. if (hapd->driver == NULL || hapd->driver->set_key == NULL)
  63. return 0;
  64. return hapd->driver->set_key(ifname, hapd->drv_priv, alg, addr,
  65. key_idx, set_tx, seq, seq_len, key,
  66. key_len);
  67. }
  68. static inline int
  69. hostapd_get_seqnum(const char *ifname, struct hostapd_data *hapd,
  70. const u8 *addr, int idx, u8 *seq)
  71. {
  72. if (hapd->driver == NULL || hapd->driver->get_seqnum == NULL)
  73. return 0;
  74. return hapd->driver->get_seqnum(ifname, hapd->drv_priv, addr, idx,
  75. seq);
  76. }
  77. static inline int
  78. hostapd_get_seqnum_igtk(const char *ifname, struct hostapd_data *hapd,
  79. const u8 *addr, int idx, u8 *seq)
  80. {
  81. if (hapd->driver == NULL || hapd->driver->get_seqnum_igtk == NULL)
  82. return -1;
  83. return hapd->driver->get_seqnum_igtk(ifname, hapd->drv_priv, addr, idx,
  84. seq);
  85. }
  86. static inline int
  87. hostapd_flush(struct hostapd_data *hapd)
  88. {
  89. if (hapd->driver == NULL || hapd->driver->flush == NULL)
  90. return 0;
  91. return hapd->driver->flush(hapd->drv_priv);
  92. }
  93. static inline int
  94. hostapd_set_generic_elem(struct hostapd_data *hapd, const u8 *elem,
  95. size_t elem_len)
  96. {
  97. if (hapd->driver == NULL || hapd->driver->set_generic_elem == NULL)
  98. return 0;
  99. return hapd->driver->set_generic_elem(hapd->conf->iface,
  100. hapd->drv_priv, elem, elem_len);
  101. }
  102. static inline int
  103. hostapd_read_sta_data(struct hostapd_data *hapd,
  104. struct hostap_sta_driver_data *data, const u8 *addr)
  105. {
  106. if (hapd->driver == NULL || hapd->driver->read_sta_data == NULL)
  107. return -1;
  108. return hapd->driver->read_sta_data(hapd->drv_priv, data, addr);
  109. }
  110. static inline int
  111. hostapd_send_eapol(struct hostapd_data *hapd, const u8 *addr, const u8 *data,
  112. size_t data_len, int encrypt)
  113. {
  114. if (hapd->driver == NULL || hapd->driver->send_eapol == NULL)
  115. return 0;
  116. return hapd->driver->send_eapol(hapd->drv_priv, addr, data, data_len,
  117. encrypt, hapd->own_addr);
  118. }
  119. static inline int
  120. hostapd_sta_deauth(struct hostapd_data *hapd, const u8 *addr, int reason)
  121. {
  122. if (hapd->driver == NULL || hapd->driver->sta_deauth == NULL)
  123. return 0;
  124. return hapd->driver->sta_deauth(hapd->drv_priv, addr, reason);
  125. }
  126. static inline int
  127. hostapd_sta_disassoc(struct hostapd_data *hapd, const u8 *addr, int reason)
  128. {
  129. if (hapd->driver == NULL || hapd->driver->sta_disassoc == NULL)
  130. return 0;
  131. return hapd->driver->sta_disassoc(hapd->drv_priv, addr, reason);
  132. }
  133. static inline int
  134. hostapd_sta_remove(struct hostapd_data *hapd, const u8 *addr)
  135. {
  136. if (hapd->driver == NULL || hapd->driver->sta_remove == NULL)
  137. return 0;
  138. return hapd->driver->sta_remove(hapd->drv_priv, addr);
  139. }
  140. static inline int
  141. hostapd_get_ssid(struct hostapd_data *hapd, u8 *buf, size_t len)
  142. {
  143. if (hapd->driver == NULL || hapd->driver->get_ssid == NULL)
  144. return 0;
  145. return hapd->driver->get_ssid(hapd->conf->iface, hapd->drv_priv, buf,
  146. len);
  147. }
  148. static inline int
  149. hostapd_set_ssid(struct hostapd_data *hapd, const u8 *buf, size_t len)
  150. {
  151. if (hapd->driver == NULL || hapd->driver->set_ssid == NULL)
  152. return 0;
  153. return hapd->driver->set_ssid(hapd->conf->iface, hapd->drv_priv, buf,
  154. len);
  155. }
  156. static inline int
  157. hostapd_send_mgmt_frame(struct hostapd_data *hapd, const void *msg, size_t len,
  158. int flags)
  159. {
  160. if (hapd->driver == NULL || hapd->driver->send_mgmt_frame == NULL)
  161. return 0;
  162. return hapd->driver->send_mgmt_frame(hapd->drv_priv, msg, len, flags);
  163. }
  164. static inline int
  165. hostapd_set_countermeasures(struct hostapd_data *hapd, int enabled)
  166. {
  167. if (hapd->driver == NULL || hapd->driver->set_countermeasures == NULL)
  168. return 0;
  169. return hapd->driver->set_countermeasures(hapd->drv_priv, enabled);
  170. }
  171. static inline int
  172. hostapd_sta_add(const char *ifname, struct hostapd_data *hapd, const u8 *addr,
  173. u16 aid, u16 capability, const u8 *supp_rates,
  174. size_t supp_rates_len, int flags, u16 listen_interval,
  175. const struct ht_cap_ie *ht_capabilities)
  176. {
  177. struct hostapd_sta_add_params params;
  178. if (hapd->driver == NULL)
  179. return 0;
  180. if (hapd->driver->sta_add == NULL)
  181. return 0;
  182. os_memset(&params, 0, sizeof(params));
  183. params.addr = addr;
  184. params.aid = aid;
  185. params.capability = capability;
  186. params.supp_rates = supp_rates;
  187. params.supp_rates_len = supp_rates_len;
  188. params.flags = flags;
  189. params.listen_interval = listen_interval;
  190. params.ht_capabilities = ht_capabilities;
  191. return hapd->driver->sta_add(ifname, hapd->drv_priv, &params);
  192. }
  193. static inline int
  194. hostapd_get_inact_sec(struct hostapd_data *hapd, const u8 *addr)
  195. {
  196. if (hapd->driver == NULL || hapd->driver->get_inact_sec == NULL)
  197. return 0;
  198. return hapd->driver->get_inact_sec(hapd->drv_priv, addr);
  199. }
  200. static inline int
  201. hostapd_set_freq(struct hostapd_data *hapd, int mode, int freq, int channel,
  202. int ht_enabled, int sec_channel_offset)
  203. {
  204. struct hostapd_freq_params data;
  205. if (hapd->driver == NULL)
  206. return 0;
  207. if (hapd->driver->set_freq == NULL)
  208. return 0;
  209. os_memset(&data, 0, sizeof(data));
  210. data.mode = mode;
  211. data.freq = freq;
  212. data.channel = channel;
  213. data.ht_enabled = ht_enabled;
  214. data.sec_channel_offset = sec_channel_offset;
  215. return hapd->driver->set_freq(hapd->drv_priv, &data);
  216. }
  217. static inline int
  218. hostapd_set_rts(struct hostapd_data *hapd, int rts)
  219. {
  220. if (hapd->driver == NULL || hapd->driver->set_rts == NULL)
  221. return 0;
  222. return hapd->driver->set_rts(hapd->drv_priv, rts);
  223. }
  224. static inline int
  225. hostapd_get_rts(struct hostapd_data *hapd, int *rts)
  226. {
  227. if (hapd->driver == NULL || hapd->driver->get_rts == NULL)
  228. return 0;
  229. return hapd->driver->get_rts(hapd->drv_priv, rts);
  230. }
  231. static inline int
  232. hostapd_set_frag(struct hostapd_data *hapd, int frag)
  233. {
  234. if (hapd->driver == NULL || hapd->driver->set_frag == NULL)
  235. return 0;
  236. return hapd->driver->set_frag(hapd->drv_priv, frag);
  237. }
  238. static inline int
  239. hostapd_get_frag(struct hostapd_data *hapd, int *frag)
  240. {
  241. if (hapd->driver == NULL || hapd->driver->get_frag == NULL)
  242. return 0;
  243. return hapd->driver->get_frag(hapd->drv_priv, frag);
  244. }
  245. static inline int
  246. hostapd_set_retry(struct hostapd_data *hapd, int short_retry, int long_retry)
  247. {
  248. if (hapd->driver == NULL || hapd->driver->set_retry == NULL)
  249. return 0;
  250. return hapd->driver->set_retry(hapd->drv_priv, short_retry,
  251. long_retry);
  252. }
  253. static inline int
  254. hostapd_get_retry(struct hostapd_data *hapd, int *short_retry, int *long_retry)
  255. {
  256. if (hapd->driver == NULL || hapd->driver->get_retry == NULL)
  257. return 0;
  258. return hapd->driver->get_retry(hapd->drv_priv, short_retry,
  259. long_retry);
  260. }
  261. static inline int
  262. hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr,
  263. int total_flags, int flags_or, int flags_and)
  264. {
  265. if (hapd->driver == NULL || hapd->driver->sta_set_flags == NULL)
  266. return 0;
  267. return hapd->driver->sta_set_flags(hapd->drv_priv, addr, total_flags,
  268. flags_or, flags_and);
  269. }
  270. static inline int
  271. hostapd_set_rate_sets(struct hostapd_data *hapd, int *supp_rates,
  272. int *basic_rates, int mode)
  273. {
  274. if (hapd->driver == NULL || hapd->driver->set_rate_sets == NULL)
  275. return 0;
  276. return hapd->driver->set_rate_sets(hapd->drv_priv, supp_rates,
  277. basic_rates, mode);
  278. }
  279. static inline int
  280. hostapd_set_country(struct hostapd_data *hapd, const char *country)
  281. {
  282. if (hapd->driver == NULL ||
  283. hapd->driver->set_country == NULL)
  284. return 0;
  285. return hapd->driver->set_country(hapd->drv_priv, country);
  286. }
  287. static inline int
  288. hostapd_set_ieee80211d(struct hostapd_data *hapd, int enabled)
  289. {
  290. if (hapd->driver == NULL ||
  291. hapd->driver->set_ieee80211d == NULL)
  292. return 0;
  293. return hapd->driver->set_ieee80211d(hapd->drv_priv, enabled);
  294. }
  295. static inline int
  296. hostapd_sta_clear_stats(struct hostapd_data *hapd, const u8 *addr)
  297. {
  298. if (hapd->driver == NULL || hapd->driver->sta_clear_stats == NULL)
  299. return 0;
  300. return hapd->driver->sta_clear_stats(hapd->drv_priv, addr);
  301. }
  302. static inline int
  303. hostapd_set_beacon(const char *ifname, struct hostapd_data *hapd,
  304. const u8 *head, size_t head_len,
  305. const u8 *tail, size_t tail_len, int dtim_period)
  306. {
  307. if (hapd->driver == NULL || hapd->driver->set_beacon == NULL)
  308. return 0;
  309. return hapd->driver->set_beacon(ifname, hapd->drv_priv, head, head_len,
  310. tail, tail_len, dtim_period);
  311. }
  312. static inline int
  313. hostapd_set_internal_bridge(struct hostapd_data *hapd, int value)
  314. {
  315. if (hapd->driver == NULL || hapd->driver->set_internal_bridge == NULL)
  316. return 0;
  317. return hapd->driver->set_internal_bridge(hapd->drv_priv, value);
  318. }
  319. static inline int
  320. hostapd_set_beacon_int(struct hostapd_data *hapd, int value)
  321. {
  322. if (hapd->driver == NULL || hapd->driver->set_beacon_int == NULL)
  323. return 0;
  324. return hapd->driver->set_beacon_int(hapd->drv_priv, value);
  325. }
  326. static inline int
  327. hostapd_set_broadcast_ssid(struct hostapd_data *hapd, int value)
  328. {
  329. if (hapd->driver == NULL || hapd->driver->set_broadcast_ssid == NULL)
  330. return 0;
  331. return hapd->driver->set_broadcast_ssid(hapd->drv_priv, value);
  332. }
  333. static inline int
  334. hostapd_set_cts_protect(struct hostapd_data *hapd, int value)
  335. {
  336. if (hapd->driver == NULL || hapd->driver->set_cts_protect == NULL)
  337. return 0;
  338. return hapd->driver->set_cts_protect(hapd->drv_priv, value);
  339. }
  340. static inline int
  341. hostapd_set_key_tx_rx_threshold(struct hostapd_data *hapd, int value)
  342. {
  343. if (hapd->driver == NULL ||
  344. hapd->driver->set_key_tx_rx_threshold == NULL)
  345. return 0;
  346. return hapd->driver->set_key_tx_rx_threshold(hapd->drv_priv, value);
  347. }
  348. static inline int
  349. hostapd_set_preamble(struct hostapd_data *hapd, int value)
  350. {
  351. if (hapd->driver == NULL || hapd->driver->set_preamble == NULL)
  352. return 0;
  353. return hapd->driver->set_preamble(hapd->drv_priv, value);
  354. }
  355. static inline int
  356. hostapd_set_short_slot_time(struct hostapd_data *hapd, int value)
  357. {
  358. if (hapd->driver == NULL || hapd->driver->set_short_slot_time == NULL)
  359. return 0;
  360. return hapd->driver->set_short_slot_time(hapd->drv_priv, value);
  361. }
  362. static inline int
  363. hostapd_set_tx_queue_params(struct hostapd_data *hapd, int queue, int aifs,
  364. int cw_min, int cw_max, int burst_time)
  365. {
  366. if (hapd->driver == NULL || hapd->driver->set_tx_queue_params == NULL)
  367. return 0;
  368. return hapd->driver->set_tx_queue_params(hapd->drv_priv, queue, aifs,
  369. cw_min, cw_max, burst_time);
  370. }
  371. static inline int
  372. hostapd_bss_add(struct hostapd_data *hapd, const char *ifname, const u8 *bssid)
  373. {
  374. if (hapd->driver == NULL || hapd->driver->bss_add == NULL)
  375. return 0;
  376. return hapd->driver->bss_add(hapd->drv_priv, ifname, bssid);
  377. }
  378. static inline int
  379. hostapd_bss_remove(struct hostapd_data *hapd, const char *ifname)
  380. {
  381. if (hapd->driver == NULL || hapd->driver->bss_remove == NULL)
  382. return 0;
  383. return hapd->driver->bss_remove(hapd->drv_priv, ifname);
  384. }
  385. static inline int
  386. hostapd_valid_bss_mask(struct hostapd_data *hapd, const u8 *addr,
  387. const u8 *mask)
  388. {
  389. if (hapd->driver == NULL || hapd->driver->valid_bss_mask == NULL)
  390. return 1;
  391. return hapd->driver->valid_bss_mask(hapd->drv_priv, addr, mask);
  392. }
  393. static inline int
  394. hostapd_if_add(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  395. char *ifname, const u8 *addr)
  396. {
  397. if (hapd->driver == NULL || hapd->driver->if_add == NULL)
  398. return -1;
  399. return hapd->driver->if_add(hapd->conf->iface, hapd->drv_priv, type,
  400. ifname, addr);
  401. }
  402. static inline int
  403. hostapd_if_update(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  404. char *ifname, const u8 *addr)
  405. {
  406. if (hapd->driver == NULL || hapd->driver->if_update == NULL)
  407. return -1;
  408. return hapd->driver->if_update(hapd->drv_priv, type, ifname, addr);
  409. }
  410. static inline int
  411. hostapd_if_remove(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  412. char *ifname, const u8 *addr)
  413. {
  414. if (hapd->driver == NULL || hapd->driver->if_remove == NULL)
  415. return -1;
  416. return hapd->driver->if_remove(hapd->drv_priv, type, ifname, addr);
  417. }
  418. static inline int
  419. hostapd_passive_scan(struct hostapd_data *hapd, int now, int our_mode_only,
  420. int interval, int _listen, int *channel,
  421. int *last_rx)
  422. {
  423. if (hapd->driver == NULL || hapd->driver->passive_scan == NULL)
  424. return -1;
  425. return hapd->driver->passive_scan(hapd->drv_priv, now, our_mode_only,
  426. interval, _listen, channel, last_rx);
  427. }
  428. static inline struct hostapd_hw_modes *
  429. hostapd_get_hw_feature_data(struct hostapd_data *hapd, u16 *num_modes,
  430. u16 *flags)
  431. {
  432. if (hapd->driver == NULL || hapd->driver->get_hw_feature_data == NULL)
  433. return NULL;
  434. return hapd->driver->get_hw_feature_data(hapd->drv_priv, num_modes,
  435. flags);
  436. }
  437. static inline int
  438. hostapd_set_sta_vlan(const char *ifname, struct hostapd_data *hapd,
  439. const u8 *addr, int vlan_id)
  440. {
  441. if (hapd->driver == NULL || hapd->driver->set_sta_vlan == NULL)
  442. return 0;
  443. return hapd->driver->set_sta_vlan(hapd->drv_priv, addr, ifname, vlan_id);
  444. }
  445. static inline int
  446. hostapd_driver_commit(struct hostapd_data *hapd)
  447. {
  448. if (hapd->driver == NULL || hapd->driver->commit == NULL)
  449. return 0;
  450. return hapd->driver->commit(hapd->drv_priv);
  451. }
  452. static inline int
  453. hostapd_set_radius_acl_auth(struct hostapd_data *hapd, const u8 *mac,
  454. int accepted, u32 session_timeout)
  455. {
  456. if (hapd->driver == NULL || hapd->driver->set_radius_acl_auth == NULL)
  457. return 0;
  458. return hapd->driver->set_radius_acl_auth(hapd->drv_priv, mac, accepted,
  459. session_timeout);
  460. }
  461. static inline int
  462. hostapd_set_radius_acl_expire(struct hostapd_data *hapd, const u8 *mac)
  463. {
  464. if (hapd->driver == NULL ||
  465. hapd->driver->set_radius_acl_expire == NULL)
  466. return 0;
  467. return hapd->driver->set_radius_acl_expire(hapd->drv_priv, mac);
  468. }
  469. #ifdef CONFIG_IEEE80211N
  470. static inline int
  471. hostapd_set_ht_params(const char *ifname, struct hostapd_data *hapd,
  472. const u8 *ht_capab, size_t ht_capab_len,
  473. const u8 *ht_oper, size_t ht_oper_len)
  474. {
  475. if (hapd->driver == NULL || hapd->driver->set_ht_params == NULL ||
  476. ht_capab == NULL || ht_oper == NULL)
  477. return 0;
  478. return hapd->driver->set_ht_params(
  479. ifname, hapd->drv_priv, ht_capab, ht_capab_len,
  480. ht_oper, ht_oper_len);
  481. }
  482. #endif /* CONFIG_IEEE80211N */
  483. static inline int
  484. hostapd_drv_none(struct hostapd_data *hapd)
  485. {
  486. return hapd->driver && os_strcmp(hapd->driver->name, "none") == 0;
  487. }
  488. static inline int
  489. hostapd_set_wps_beacon_ie(struct hostapd_data *hapd, const u8 *ie, size_t len)
  490. {
  491. if (hapd->driver == NULL || hapd->driver->set_wps_beacon_ie == NULL)
  492. return 0;
  493. return hapd->driver->set_wps_beacon_ie(hapd->conf->iface,
  494. hapd->drv_priv, ie, len);
  495. }
  496. static inline int
  497. hostapd_set_wps_probe_resp_ie(struct hostapd_data *hapd, const u8 *ie,
  498. size_t len)
  499. {
  500. if (hapd->driver == NULL ||
  501. hapd->driver->set_wps_probe_resp_ie == NULL)
  502. return 0;
  503. return hapd->driver->set_wps_probe_resp_ie(hapd->conf->iface,
  504. hapd->drv_priv, ie, len);
  505. }
  506. static inline const struct hostapd_neighbor_bss *
  507. hostapd_driver_get_neighbor_bss(struct hostapd_data *hapd, size_t *num)
  508. {
  509. if (hapd->driver == NULL || hapd->driver->get_neighbor_bss == NULL)
  510. return NULL;
  511. return hapd->driver->get_neighbor_bss(hapd->drv_priv, num);
  512. }
  513. #endif /* DRIVER_I_H */