driver_i.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543
  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_set_frag(struct hostapd_data *hapd, int frag)
  226. {
  227. if (hapd->driver == NULL || hapd->driver->set_frag == NULL)
  228. return 0;
  229. return hapd->driver->set_frag(hapd->drv_priv, frag);
  230. }
  231. static inline int
  232. hostapd_set_retry(struct hostapd_data *hapd, int short_retry, int long_retry)
  233. {
  234. if (hapd->driver == NULL || hapd->driver->set_retry == NULL)
  235. return 0;
  236. return hapd->driver->set_retry(hapd->drv_priv, short_retry,
  237. long_retry);
  238. }
  239. static inline int
  240. hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr,
  241. int total_flags, int flags_or, int flags_and)
  242. {
  243. if (hapd->driver == NULL || hapd->driver->sta_set_flags == NULL)
  244. return 0;
  245. return hapd->driver->sta_set_flags(hapd->drv_priv, addr, total_flags,
  246. flags_or, flags_and);
  247. }
  248. static inline int
  249. hostapd_set_rate_sets(struct hostapd_data *hapd, int *supp_rates,
  250. int *basic_rates, int mode)
  251. {
  252. if (hapd->driver == NULL || hapd->driver->set_rate_sets == NULL)
  253. return 0;
  254. return hapd->driver->set_rate_sets(hapd->drv_priv, supp_rates,
  255. basic_rates, mode);
  256. }
  257. static inline int
  258. hostapd_set_country(struct hostapd_data *hapd, const char *country)
  259. {
  260. if (hapd->driver == NULL ||
  261. hapd->driver->set_country == NULL)
  262. return 0;
  263. return hapd->driver->set_country(hapd->drv_priv, country);
  264. }
  265. static inline int
  266. hostapd_set_ieee80211d(struct hostapd_data *hapd, int enabled)
  267. {
  268. if (hapd->driver == NULL ||
  269. hapd->driver->set_ieee80211d == NULL)
  270. return 0;
  271. return hapd->driver->set_ieee80211d(hapd->drv_priv, enabled);
  272. }
  273. static inline int
  274. hostapd_sta_clear_stats(struct hostapd_data *hapd, const u8 *addr)
  275. {
  276. if (hapd->driver == NULL || hapd->driver->sta_clear_stats == NULL)
  277. return 0;
  278. return hapd->driver->sta_clear_stats(hapd->drv_priv, addr);
  279. }
  280. static inline int
  281. hostapd_set_beacon(const char *ifname, struct hostapd_data *hapd,
  282. const u8 *head, size_t head_len,
  283. const u8 *tail, size_t tail_len, int dtim_period)
  284. {
  285. if (hapd->driver == NULL || hapd->driver->set_beacon == NULL)
  286. return 0;
  287. return hapd->driver->set_beacon(ifname, hapd->drv_priv, head, head_len,
  288. tail, tail_len, dtim_period);
  289. }
  290. static inline int
  291. hostapd_set_internal_bridge(struct hostapd_data *hapd, int value)
  292. {
  293. if (hapd->driver == NULL || hapd->driver->set_internal_bridge == NULL)
  294. return 0;
  295. return hapd->driver->set_internal_bridge(hapd->drv_priv, value);
  296. }
  297. static inline int
  298. hostapd_set_beacon_int(struct hostapd_data *hapd, int value)
  299. {
  300. if (hapd->driver == NULL || hapd->driver->set_beacon_int == NULL)
  301. return 0;
  302. return hapd->driver->set_beacon_int(hapd->drv_priv, value);
  303. }
  304. static inline int
  305. hostapd_set_broadcast_ssid(struct hostapd_data *hapd, int value)
  306. {
  307. if (hapd->driver == NULL || hapd->driver->set_broadcast_ssid == NULL)
  308. return 0;
  309. return hapd->driver->set_broadcast_ssid(hapd->drv_priv, value);
  310. }
  311. static inline int
  312. hostapd_set_cts_protect(struct hostapd_data *hapd, int value)
  313. {
  314. if (hapd->driver == NULL || hapd->driver->set_cts_protect == NULL)
  315. return 0;
  316. return hapd->driver->set_cts_protect(hapd->drv_priv, value);
  317. }
  318. static inline int
  319. hostapd_set_preamble(struct hostapd_data *hapd, int value)
  320. {
  321. if (hapd->driver == NULL || hapd->driver->set_preamble == NULL)
  322. return 0;
  323. return hapd->driver->set_preamble(hapd->drv_priv, value);
  324. }
  325. static inline int
  326. hostapd_set_short_slot_time(struct hostapd_data *hapd, int value)
  327. {
  328. if (hapd->driver == NULL || hapd->driver->set_short_slot_time == NULL)
  329. return 0;
  330. return hapd->driver->set_short_slot_time(hapd->drv_priv, value);
  331. }
  332. static inline int
  333. hostapd_set_tx_queue_params(struct hostapd_data *hapd, int queue, int aifs,
  334. int cw_min, int cw_max, int burst_time)
  335. {
  336. if (hapd->driver == NULL || hapd->driver->set_tx_queue_params == NULL)
  337. return 0;
  338. return hapd->driver->set_tx_queue_params(hapd->drv_priv, queue, aifs,
  339. cw_min, cw_max, burst_time);
  340. }
  341. static inline int
  342. hostapd_bss_add(struct hostapd_data *hapd, const char *ifname, const u8 *bssid)
  343. {
  344. if (hapd->driver == NULL || hapd->driver->bss_add == NULL)
  345. return 0;
  346. return hapd->driver->bss_add(hapd->drv_priv, ifname, bssid);
  347. }
  348. static inline int
  349. hostapd_bss_remove(struct hostapd_data *hapd, const char *ifname)
  350. {
  351. if (hapd->driver == NULL || hapd->driver->bss_remove == NULL)
  352. return 0;
  353. return hapd->driver->bss_remove(hapd->drv_priv, ifname);
  354. }
  355. static inline int
  356. hostapd_valid_bss_mask(struct hostapd_data *hapd, const u8 *addr,
  357. const u8 *mask)
  358. {
  359. if (hapd->driver == NULL || hapd->driver->valid_bss_mask == NULL)
  360. return 1;
  361. return hapd->driver->valid_bss_mask(hapd->drv_priv, addr, mask);
  362. }
  363. static inline int
  364. hostapd_if_add(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  365. char *ifname, const u8 *addr)
  366. {
  367. if (hapd->driver == NULL || hapd->driver->if_add == NULL)
  368. return -1;
  369. return hapd->driver->if_add(hapd->conf->iface, hapd->drv_priv, type,
  370. ifname, addr);
  371. }
  372. static inline int
  373. hostapd_if_update(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  374. char *ifname, const u8 *addr)
  375. {
  376. if (hapd->driver == NULL || hapd->driver->if_update == NULL)
  377. return -1;
  378. return hapd->driver->if_update(hapd->drv_priv, type, ifname, addr);
  379. }
  380. static inline int
  381. hostapd_if_remove(struct hostapd_data *hapd, enum hostapd_driver_if_type type,
  382. char *ifname, const u8 *addr)
  383. {
  384. if (hapd->driver == NULL || hapd->driver->if_remove == NULL)
  385. return -1;
  386. return hapd->driver->if_remove(hapd->drv_priv, type, ifname, addr);
  387. }
  388. static inline int
  389. hostapd_passive_scan(struct hostapd_data *hapd, int now, int our_mode_only,
  390. int interval, int _listen, int *channel,
  391. int *last_rx)
  392. {
  393. if (hapd->driver == NULL || hapd->driver->passive_scan == NULL)
  394. return -1;
  395. return hapd->driver->passive_scan(hapd->drv_priv, now, our_mode_only,
  396. interval, _listen, channel, last_rx);
  397. }
  398. static inline struct hostapd_hw_modes *
  399. hostapd_get_hw_feature_data(struct hostapd_data *hapd, u16 *num_modes,
  400. u16 *flags)
  401. {
  402. if (hapd->driver == NULL || hapd->driver->get_hw_feature_data == NULL)
  403. return NULL;
  404. return hapd->driver->get_hw_feature_data(hapd->drv_priv, num_modes,
  405. flags);
  406. }
  407. static inline int
  408. hostapd_set_sta_vlan(const char *ifname, struct hostapd_data *hapd,
  409. const u8 *addr, int vlan_id)
  410. {
  411. if (hapd->driver == NULL || hapd->driver->set_sta_vlan == NULL)
  412. return 0;
  413. return hapd->driver->set_sta_vlan(hapd->drv_priv, addr, ifname, vlan_id);
  414. }
  415. static inline int
  416. hostapd_driver_commit(struct hostapd_data *hapd)
  417. {
  418. if (hapd->driver == NULL || hapd->driver->commit == NULL)
  419. return 0;
  420. return hapd->driver->commit(hapd->drv_priv);
  421. }
  422. static inline int
  423. hostapd_set_radius_acl_auth(struct hostapd_data *hapd, const u8 *mac,
  424. int accepted, u32 session_timeout)
  425. {
  426. if (hapd->driver == NULL || hapd->driver->set_radius_acl_auth == NULL)
  427. return 0;
  428. return hapd->driver->set_radius_acl_auth(hapd->drv_priv, mac, accepted,
  429. session_timeout);
  430. }
  431. static inline int
  432. hostapd_set_radius_acl_expire(struct hostapd_data *hapd, const u8 *mac)
  433. {
  434. if (hapd->driver == NULL ||
  435. hapd->driver->set_radius_acl_expire == NULL)
  436. return 0;
  437. return hapd->driver->set_radius_acl_expire(hapd->drv_priv, mac);
  438. }
  439. #ifdef CONFIG_IEEE80211N
  440. static inline int
  441. hostapd_set_ht_params(const char *ifname, struct hostapd_data *hapd,
  442. const u8 *ht_capab, size_t ht_capab_len,
  443. const u8 *ht_oper, size_t ht_oper_len)
  444. {
  445. if (hapd->driver == NULL || hapd->driver->set_ht_params == NULL ||
  446. ht_capab == NULL || ht_oper == NULL)
  447. return 0;
  448. return hapd->driver->set_ht_params(
  449. ifname, hapd->drv_priv, ht_capab, ht_capab_len,
  450. ht_oper, ht_oper_len);
  451. }
  452. #endif /* CONFIG_IEEE80211N */
  453. static inline int
  454. hostapd_drv_none(struct hostapd_data *hapd)
  455. {
  456. return hapd->driver && os_strcmp(hapd->driver->name, "none") == 0;
  457. }
  458. static inline int
  459. hostapd_set_wps_beacon_ie(struct hostapd_data *hapd, const u8 *ie, size_t len)
  460. {
  461. if (hapd->driver == NULL || hapd->driver->set_wps_beacon_ie == NULL)
  462. return 0;
  463. return hapd->driver->set_wps_beacon_ie(hapd->conf->iface,
  464. hapd->drv_priv, ie, len);
  465. }
  466. static inline int
  467. hostapd_set_wps_probe_resp_ie(struct hostapd_data *hapd, const u8 *ie,
  468. size_t len)
  469. {
  470. if (hapd->driver == NULL ||
  471. hapd->driver->set_wps_probe_resp_ie == NULL)
  472. return 0;
  473. return hapd->driver->set_wps_probe_resp_ie(hapd->conf->iface,
  474. hapd->drv_priv, ie, len);
  475. }
  476. static inline const struct hostapd_neighbor_bss *
  477. hostapd_driver_get_neighbor_bss(struct hostapd_data *hapd, size_t *num)
  478. {
  479. if (hapd->driver == NULL || hapd->driver->get_neighbor_bss == NULL)
  480. return NULL;
  481. return hapd->driver->get_neighbor_bss(hapd->drv_priv, num);
  482. }
  483. #endif /* DRIVER_I_H */