driver_i.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546
  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 "drivers/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->hapd_init == NULL)
  23. return NULL;
  24. return hapd->driver->hapd_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->hapd_deinit == NULL)
  37. return;
  38. hapd->driver->hapd_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->hapd_set_key == NULL)
  63. return 0;
  64. return hapd->driver->hapd_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->hapd_send_eapol == NULL)
  115. return 0;
  116. return hapd->driver->hapd_send_eapol(hapd->drv_priv, addr, data,
  117. data_len, encrypt,
  118. hapd->own_addr);
  119. }
  120. static inline int
  121. hostapd_sta_deauth(struct hostapd_data *hapd, const u8 *addr, int reason)
  122. {
  123. if (hapd->driver == NULL || hapd->driver->sta_deauth == NULL)
  124. return 0;
  125. return hapd->driver->sta_deauth(hapd->drv_priv, addr, reason);
  126. }
  127. static inline int
  128. hostapd_sta_disassoc(struct hostapd_data *hapd, const u8 *addr, int reason)
  129. {
  130. if (hapd->driver == NULL || hapd->driver->sta_disassoc == NULL)
  131. return 0;
  132. return hapd->driver->sta_disassoc(hapd->drv_priv, addr, reason);
  133. }
  134. static inline int
  135. hostapd_sta_remove(struct hostapd_data *hapd, const u8 *addr)
  136. {
  137. if (hapd->driver == NULL || hapd->driver->sta_remove == NULL)
  138. return 0;
  139. return hapd->driver->sta_remove(hapd->drv_priv, addr);
  140. }
  141. static inline int
  142. hostapd_get_ssid(struct hostapd_data *hapd, u8 *buf, size_t len)
  143. {
  144. if (hapd->driver == NULL || hapd->driver->hapd_get_ssid == NULL)
  145. return 0;
  146. return hapd->driver->hapd_get_ssid(hapd->conf->iface, hapd->drv_priv,
  147. buf, len);
  148. }
  149. static inline int
  150. hostapd_set_ssid(struct hostapd_data *hapd, const u8 *buf, size_t len)
  151. {
  152. if (hapd->driver == NULL || hapd->driver->hapd_set_ssid == NULL)
  153. return 0;
  154. return hapd->driver->hapd_set_ssid(hapd->conf->iface, hapd->drv_priv,
  155. buf, len);
  156. }
  157. static inline int
  158. hostapd_send_mgmt_frame(struct hostapd_data *hapd, const void *msg, size_t len)
  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);
  163. }
  164. static inline int
  165. hostapd_set_countermeasures(struct hostapd_data *hapd, int enabled)
  166. {
  167. if (hapd->driver == NULL ||
  168. hapd->driver->hapd_set_countermeasures == NULL)
  169. return 0;
  170. return hapd->driver->hapd_set_countermeasures(hapd->drv_priv, enabled);
  171. }
  172. static inline int
  173. hostapd_sta_add(const char *ifname, struct hostapd_data *hapd, const u8 *addr,
  174. u16 aid, u16 capability, const u8 *supp_rates,
  175. size_t supp_rates_len, int flags, u16 listen_interval,
  176. const struct ht_cap_ie *ht_capabilities)
  177. {
  178. struct hostapd_sta_add_params params;
  179. if (hapd->driver == NULL)
  180. return 0;
  181. if (hapd->driver->sta_add == NULL)
  182. return 0;
  183. os_memset(&params, 0, sizeof(params));
  184. params.addr = addr;
  185. params.aid = aid;
  186. params.capability = capability;
  187. params.supp_rates = supp_rates;
  188. params.supp_rates_len = supp_rates_len;
  189. params.flags = flags;
  190. params.listen_interval = listen_interval;
  191. params.ht_capabilities = ht_capabilities;
  192. return hapd->driver->sta_add(ifname, hapd->drv_priv, &params);
  193. }
  194. static inline int
  195. hostapd_get_inact_sec(struct hostapd_data *hapd, const u8 *addr)
  196. {
  197. if (hapd->driver == NULL || hapd->driver->get_inact_sec == NULL)
  198. return 0;
  199. return hapd->driver->get_inact_sec(hapd->drv_priv, addr);
  200. }
  201. static inline int
  202. hostapd_set_freq(struct hostapd_data *hapd, int mode, int freq, int channel,
  203. int ht_enabled, int sec_channel_offset)
  204. {
  205. struct hostapd_freq_params data;
  206. if (hapd->driver == NULL)
  207. return 0;
  208. if (hapd->driver->set_freq == NULL)
  209. return 0;
  210. os_memset(&data, 0, sizeof(data));
  211. data.mode = mode;
  212. data.freq = freq;
  213. data.channel = channel;
  214. data.ht_enabled = ht_enabled;
  215. data.sec_channel_offset = sec_channel_offset;
  216. return hapd->driver->set_freq(hapd->drv_priv, &data);
  217. }
  218. static inline int
  219. hostapd_set_rts(struct hostapd_data *hapd, int rts)
  220. {
  221. if (hapd->driver == NULL || hapd->driver->set_rts == NULL)
  222. return 0;
  223. return hapd->driver->set_rts(hapd->drv_priv, rts);
  224. }
  225. static inline int
  226. hostapd_set_frag(struct hostapd_data *hapd, int frag)
  227. {
  228. if (hapd->driver == NULL || hapd->driver->set_frag == NULL)
  229. return 0;
  230. return hapd->driver->set_frag(hapd->drv_priv, frag);
  231. }
  232. static inline int
  233. hostapd_set_retry(struct hostapd_data *hapd, int short_retry, int long_retry)
  234. {
  235. if (hapd->driver == NULL || hapd->driver->set_retry == NULL)
  236. return 0;
  237. return hapd->driver->set_retry(hapd->drv_priv, short_retry,
  238. long_retry);
  239. }
  240. static inline int
  241. hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr,
  242. int total_flags, int flags_or, int flags_and)
  243. {
  244. if (hapd->driver == NULL || hapd->driver->sta_set_flags == NULL)
  245. return 0;
  246. return hapd->driver->sta_set_flags(hapd->drv_priv, addr, total_flags,
  247. flags_or, flags_and);
  248. }
  249. static inline int
  250. hostapd_set_rate_sets(struct hostapd_data *hapd, int *supp_rates,
  251. int *basic_rates, int mode)
  252. {
  253. if (hapd->driver == NULL || hapd->driver->set_rate_sets == NULL)
  254. return 0;
  255. return hapd->driver->set_rate_sets(hapd->drv_priv, supp_rates,
  256. basic_rates, mode);
  257. }
  258. static inline int
  259. hostapd_set_country(struct hostapd_data *hapd, const char *country)
  260. {
  261. if (hapd->driver == NULL ||
  262. hapd->driver->hapd_set_country == NULL)
  263. return 0;
  264. return hapd->driver->hapd_set_country(hapd->drv_priv, country);
  265. }
  266. static inline int
  267. hostapd_set_ieee80211d(struct hostapd_data *hapd, int enabled)
  268. {
  269. if (hapd->driver == NULL ||
  270. hapd->driver->set_ieee80211d == NULL)
  271. return 0;
  272. return hapd->driver->set_ieee80211d(hapd->drv_priv, enabled);
  273. }
  274. static inline int
  275. hostapd_sta_clear_stats(struct hostapd_data *hapd, const u8 *addr)
  276. {
  277. if (hapd->driver == NULL || hapd->driver->sta_clear_stats == NULL)
  278. return 0;
  279. return hapd->driver->sta_clear_stats(hapd->drv_priv, addr);
  280. }
  281. static inline int
  282. hostapd_set_beacon(const char *ifname, struct hostapd_data *hapd,
  283. const u8 *head, size_t head_len,
  284. const u8 *tail, size_t tail_len, int dtim_period)
  285. {
  286. if (hapd->driver == NULL || hapd->driver->hapd_set_beacon == NULL)
  287. return 0;
  288. return hapd->driver->hapd_set_beacon(ifname, hapd->drv_priv,
  289. head, head_len,
  290. tail, tail_len, dtim_period);
  291. }
  292. static inline int
  293. hostapd_set_internal_bridge(struct hostapd_data *hapd, int value)
  294. {
  295. if (hapd->driver == NULL || hapd->driver->set_internal_bridge == NULL)
  296. return 0;
  297. return hapd->driver->set_internal_bridge(hapd->drv_priv, value);
  298. }
  299. static inline int
  300. hostapd_set_beacon_int(struct hostapd_data *hapd, int value)
  301. {
  302. if (hapd->driver == NULL || hapd->driver->hapd_set_beacon_int == NULL)
  303. return 0;
  304. return hapd->driver->hapd_set_beacon_int(hapd->drv_priv, value);
  305. }
  306. static inline int
  307. hostapd_set_broadcast_ssid(struct hostapd_data *hapd, int value)
  308. {
  309. if (hapd->driver == NULL || hapd->driver->set_broadcast_ssid == NULL)
  310. return 0;
  311. return hapd->driver->set_broadcast_ssid(hapd->drv_priv, value);
  312. }
  313. static inline int
  314. hostapd_set_cts_protect(struct hostapd_data *hapd, int value)
  315. {
  316. if (hapd->driver == NULL || hapd->driver->set_cts_protect == NULL)
  317. return 0;
  318. return hapd->driver->set_cts_protect(hapd->drv_priv, value);
  319. }
  320. static inline int
  321. hostapd_set_preamble(struct hostapd_data *hapd, int value)
  322. {
  323. if (hapd->driver == NULL || hapd->driver->set_preamble == NULL)
  324. return 0;
  325. return hapd->driver->set_preamble(hapd->drv_priv, value);
  326. }
  327. static inline int
  328. hostapd_set_short_slot_time(struct hostapd_data *hapd, int value)
  329. {
  330. if (hapd->driver == NULL || hapd->driver->set_short_slot_time == NULL)
  331. return 0;
  332. return hapd->driver->set_short_slot_time(hapd->drv_priv, value);
  333. }
  334. static inline int
  335. hostapd_set_tx_queue_params(struct hostapd_data *hapd, int queue, int aifs,
  336. int cw_min, int cw_max, int burst_time)
  337. {
  338. if (hapd->driver == NULL || hapd->driver->set_tx_queue_params == NULL)
  339. return 0;
  340. return hapd->driver->set_tx_queue_params(hapd->drv_priv, queue, aifs,
  341. cw_min, cw_max, burst_time);
  342. }
  343. static inline int
  344. hostapd_bss_add(struct hostapd_data *hapd, const char *ifname, const u8 *bssid)
  345. {
  346. if (hapd->driver == NULL || hapd->driver->bss_add == NULL)
  347. return 0;
  348. return hapd->driver->bss_add(hapd->drv_priv, ifname, bssid);
  349. }
  350. static inline int
  351. hostapd_bss_remove(struct hostapd_data *hapd, const char *ifname)
  352. {
  353. if (hapd->driver == NULL || hapd->driver->bss_remove == NULL)
  354. return 0;
  355. return hapd->driver->bss_remove(hapd->drv_priv, ifname);
  356. }
  357. static inline int
  358. hostapd_valid_bss_mask(struct hostapd_data *hapd, const u8 *addr,
  359. const u8 *mask)
  360. {
  361. if (hapd->driver == NULL || hapd->driver->valid_bss_mask == NULL)
  362. return 1;
  363. return hapd->driver->valid_bss_mask(hapd->drv_priv, addr, mask);
  364. }
  365. static inline int
  366. hostapd_if_add(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  367. char *ifname, const u8 *addr)
  368. {
  369. if (hapd->driver == NULL || hapd->driver->if_add == NULL)
  370. return -1;
  371. return hapd->driver->if_add(hapd->conf->iface, hapd->drv_priv, type,
  372. ifname, addr);
  373. }
  374. static inline int
  375. hostapd_if_update(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  376. char *ifname, const u8 *addr)
  377. {
  378. if (hapd->driver == NULL || hapd->driver->if_update == NULL)
  379. return -1;
  380. return hapd->driver->if_update(hapd->drv_priv, type, ifname, addr);
  381. }
  382. static inline int
  383. hostapd_if_remove(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  384. char *ifname, const u8 *addr)
  385. {
  386. if (hapd->driver == NULL || hapd->driver->if_remove == NULL)
  387. return -1;
  388. return hapd->driver->if_remove(hapd->drv_priv, type, ifname, addr);
  389. }
  390. static inline int
  391. hostapd_passive_scan(struct hostapd_data *hapd, int now, int our_mode_only,
  392. int interval, int _listen, int *channel,
  393. int *last_rx)
  394. {
  395. if (hapd->driver == NULL || hapd->driver->passive_scan == NULL)
  396. return -1;
  397. return hapd->driver->passive_scan(hapd->drv_priv, now, our_mode_only,
  398. interval, _listen, channel, last_rx);
  399. }
  400. static inline struct hostapd_hw_modes *
  401. hostapd_get_hw_feature_data(struct hostapd_data *hapd, u16 *num_modes,
  402. u16 *flags)
  403. {
  404. if (hapd->driver == NULL ||
  405. hapd->driver->get_hw_feature_data == NULL)
  406. return NULL;
  407. return hapd->driver->get_hw_feature_data(hapd->drv_priv, num_modes,
  408. flags);
  409. }
  410. static inline int
  411. hostapd_set_sta_vlan(const char *ifname, struct hostapd_data *hapd,
  412. const u8 *addr, int vlan_id)
  413. {
  414. if (hapd->driver == NULL || hapd->driver->set_sta_vlan == NULL)
  415. return 0;
  416. return hapd->driver->set_sta_vlan(hapd->drv_priv, addr, ifname, vlan_id);
  417. }
  418. static inline int
  419. hostapd_driver_commit(struct hostapd_data *hapd)
  420. {
  421. if (hapd->driver == NULL || hapd->driver->commit == NULL)
  422. return 0;
  423. return hapd->driver->commit(hapd->drv_priv);
  424. }
  425. static inline int
  426. hostapd_set_radius_acl_auth(struct hostapd_data *hapd, const u8 *mac,
  427. int accepted, u32 session_timeout)
  428. {
  429. if (hapd->driver == NULL || hapd->driver->set_radius_acl_auth == NULL)
  430. return 0;
  431. return hapd->driver->set_radius_acl_auth(hapd->drv_priv, mac, accepted,
  432. session_timeout);
  433. }
  434. static inline int
  435. hostapd_set_radius_acl_expire(struct hostapd_data *hapd, const u8 *mac)
  436. {
  437. if (hapd->driver == NULL ||
  438. hapd->driver->set_radius_acl_expire == NULL)
  439. return 0;
  440. return hapd->driver->set_radius_acl_expire(hapd->drv_priv, mac);
  441. }
  442. #ifdef CONFIG_IEEE80211N
  443. static inline int
  444. hostapd_set_ht_params(const char *ifname, struct hostapd_data *hapd,
  445. const u8 *ht_capab, size_t ht_capab_len,
  446. const u8 *ht_oper, size_t ht_oper_len)
  447. {
  448. if (hapd->driver == NULL || hapd->driver->set_ht_params == NULL ||
  449. ht_capab == NULL || ht_oper == NULL)
  450. return 0;
  451. return hapd->driver->set_ht_params(
  452. ifname, hapd->drv_priv, ht_capab, ht_capab_len,
  453. ht_oper, ht_oper_len);
  454. }
  455. #endif /* CONFIG_IEEE80211N */
  456. static inline int
  457. hostapd_drv_none(struct hostapd_data *hapd)
  458. {
  459. return hapd->driver && os_strcmp(hapd->driver->name, "none") == 0;
  460. }
  461. static inline int
  462. hostapd_set_wps_beacon_ie(struct hostapd_data *hapd, const u8 *ie, size_t len)
  463. {
  464. if (hapd->driver == NULL || hapd->driver->set_wps_beacon_ie == NULL)
  465. return 0;
  466. return hapd->driver->set_wps_beacon_ie(hapd->conf->iface,
  467. hapd->drv_priv, ie, len);
  468. }
  469. static inline int
  470. hostapd_set_wps_probe_resp_ie(struct hostapd_data *hapd, const u8 *ie,
  471. size_t len)
  472. {
  473. if (hapd->driver == NULL ||
  474. hapd->driver->set_wps_probe_resp_ie == NULL)
  475. return 0;
  476. return hapd->driver->set_wps_probe_resp_ie(hapd->conf->iface,
  477. hapd->drv_priv, ie, len);
  478. }
  479. static inline const struct hostapd_neighbor_bss *
  480. hostapd_driver_get_neighbor_bss(struct hostapd_data *hapd, size_t *num)
  481. {
  482. if (hapd->driver == NULL || hapd->driver->get_neighbor_bss == NULL)
  483. return NULL;
  484. return hapd->driver->get_neighbor_bss(hapd->drv_priv, num);
  485. }
  486. #endif /* DRIVER_I_H */