driver_i.h 15 KB

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