18d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt/* 28d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt * hostapd - Driver operations 3fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt * Copyright (c) 2009-2014, Jouni Malinen <j@w1.fi> 48d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt * 5c5ec7f57ead87efa365800228aa0b09a12d9e6c4Dmitry Shmidt * This software may be distributed under the terms of the BSD license. 6c5ec7f57ead87efa365800228aa0b09a12d9e6c4Dmitry Shmidt * See README for more details. 78d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt */ 88d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 98d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#ifndef AP_DRV_OPS 108d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#define AP_DRV_OPS 118d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtenum wpa_driver_if_type; 138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct wpa_bss_params; 148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct wpa_driver_scan_params; 158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct ieee80211_ht_capabilities; 16a54fa5fb807eaeff45464139b5a7759f060cec68Dmitry Shmidtstruct ieee80211_vht_capabilities; 1704f534e89ed127da4077485376f24debc50d80d5Dmitry Shmidtstruct hostapd_freq_params; 188d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 198d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtu32 hostapd_sta_flags_to_drv(u32 flags); 201f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_build_ap_extra_ies(struct hostapd_data *hapd, 211f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpabuf **beacon, 221f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpabuf **proberesp, 231f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpabuf **assocresp); 241f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtvoid hostapd_free_ap_extra_ies(struct hostapd_data *hapd, struct wpabuf *beacon, 251f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpabuf *proberesp, 261f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpabuf *assocresp); 27dda10c2afb8378747491ea5d329a1de635d6d58eDmitry Shmidtint hostapd_reset_ap_wps_ie(struct hostapd_data *hapd); 288d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_ap_wps_ie(struct hostapd_data *hapd); 298d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_authorized(struct hostapd_data *hapd, 308d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct sta_info *sta, int authorized); 318d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_sta_flags(struct hostapd_data *hapd, struct sta_info *sta); 328d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_drv_ieee8021x(struct hostapd_data *hapd, const char *ifname, 338d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int enabled); 348d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_vlan_if_add(struct hostapd_data *hapd, const char *ifname); 358d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_vlan_if_remove(struct hostapd_data *hapd, const char *ifname); 36c2ebb4b85d69b65f552fee71ac68f44e8d87b39eDmitry Shmidtint hostapd_set_wds_sta(struct hostapd_data *hapd, char *ifname_wds, 37c2ebb4b85d69b65f552fee71ac68f44e8d87b39eDmitry Shmidt const u8 *addr, int aid, int val); 388d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_sta_add(struct hostapd_data *hapd, 398d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, u16 aid, u16 capability, 408d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *supp_rates, size_t supp_rates_len, 418d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u16 listen_interval, 421f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt const struct ieee80211_ht_capabilities *ht_capab, 43a54fa5fb807eaeff45464139b5a7759f060cec68Dmitry Shmidt const struct ieee80211_vht_capabilities *vht_capab, 44849734c8d1847920ed7042463f7480b1e0c1dfeaDmitry Shmidt u32 flags, u8 qosinfo, u8 vht_opmode, int supp_p2p_ps, 45849734c8d1847920ed7042463f7480b1e0c1dfeaDmitry Shmidt int set); 468d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_privacy(struct hostapd_data *hapd, int enabled); 478d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_generic_elem(struct hostapd_data *hapd, const u8 *elem, 488d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt size_t elem_len); 498d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_get_ssid(struct hostapd_data *hapd, u8 *buf, size_t len); 508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_ssid(struct hostapd_data *hapd, const u8 *buf, size_t len); 518d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_if_add(struct hostapd_data *hapd, enum wpa_driver_if_type type, 528d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const char *ifname, const u8 *addr, void *bss_ctx, 538d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt void **drv_priv, char *force_ifname, u8 *if_addr, 54cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt const char *bridge, int use_existing); 558d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_if_remove(struct hostapd_data *hapd, enum wpa_driver_if_type type, 568d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const char *ifname); 578d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_ieee8021x(struct hostapd_data *hapd, 588d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct wpa_bss_params *params); 598d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_get_seqnum(const char *ifname, struct hostapd_data *hapd, 608d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int idx, u8 *seq); 618d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_flush(struct hostapd_data *hapd); 626c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtint hostapd_set_freq(struct hostapd_data *hapd, enum hostapd_hw_mode mode, 636c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt int freq, int channel, int ht_enabled, int vht_enabled, 64a54fa5fb807eaeff45464139b5a7759f060cec68Dmitry Shmidt int sec_channel_offset, int vht_oper_chwidth, 65a54fa5fb807eaeff45464139b5a7759f060cec68Dmitry Shmidt int center_segment0, int center_segment1); 668d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_rts(struct hostapd_data *hapd, int rts); 678d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_frag(struct hostapd_data *hapd, int frag); 688d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr, 698d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int total_flags, int flags_or, int flags_and); 708d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_country(struct hostapd_data *hapd, const char *country); 718d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_tx_queue_params(struct hostapd_data *hapd, int queue, int aifs, 728d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int cw_min, int cw_max, int burst_time); 738d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct hostapd_hw_modes * 748d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidthostapd_get_hw_feature_data(struct hostapd_data *hapd, u16 *num_modes, 758d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u16 *flags); 768d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_driver_commit(struct hostapd_data *hapd); 778d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_none(struct hostapd_data *hapd); 788d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_driver_scan(struct hostapd_data *hapd, 798d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct wpa_driver_scan_params *params); 808d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct wpa_scan_results * hostapd_driver_get_scan_results( 818d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd); 828d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_driver_set_noa(struct hostapd_data *hapd, u8 count, int start, 838d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int duration); 848d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_set_key(const char *ifname, 858d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd, 868d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt enum wpa_alg alg, const u8 *addr, 878d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int key_idx, int set_tx, 888d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *seq, size_t seq_len, 898d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *key, size_t key_len); 908d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_send_mlme(struct hostapd_data *hapd, 911f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt const void *msg, size_t len, int noack); 92d80a401aed31d06f261efd19223cf55d1a2a8228Dmitry Shmidtint hostapd_drv_send_mlme_csa(struct hostapd_data *hapd, 93d80a401aed31d06f261efd19223cf55d1a2a8228Dmitry Shmidt const void *msg, size_t len, int noack, 94d80a401aed31d06f261efd19223cf55d1a2a8228Dmitry Shmidt const u16 *csa_offs, size_t csa_offs_len); 958d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_sta_deauth(struct hostapd_data *hapd, 968d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int reason); 978d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_sta_disassoc(struct hostapd_data *hapd, 988d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int reason); 9904949598a23f501be6eec21697465fd46a28840aDmitry Shmidtint hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq, 10004949598a23f501be6eec21697465fd46a28840aDmitry Shmidt unsigned int wait, const u8 *dst, const u8 *data, 10104949598a23f501be6eec21697465fd46a28840aDmitry Shmidt size_t len); 102d5ab1b53af720d05586ccc0addabe93459f1f388Dmitry Shmidtint hostapd_drv_send_action_addr3_ap(struct hostapd_data *hapd, 103d5ab1b53af720d05586ccc0addabe93459f1f388Dmitry Shmidt unsigned int freq, 104d5ab1b53af720d05586ccc0addabe93459f1f388Dmitry Shmidt unsigned int wait, const u8 *dst, 105d5ab1b53af720d05586ccc0addabe93459f1f388Dmitry Shmidt const u8 *data, size_t len); 1061f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_add_sta_node(struct hostapd_data *hapd, const u8 *addr, 1071f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt u16 auth_alg); 1081f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_sta_auth(struct hostapd_data *hapd, const u8 *addr, 1091f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt u16 seq, u16 status, const u8 *ie, size_t len); 1101f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_sta_assoc(struct hostapd_data *hapd, const u8 *addr, 1111f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt int reassoc, u16 status, const u8 *ie, size_t len); 1121f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_add_tspec(struct hostapd_data *hapd, const u8 *addr, 1131f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt u8 *tspec_ie, size_t tspec_ielen); 1146c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtint hostapd_start_dfs_cac(struct hostapd_iface *iface, 1156c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt enum hostapd_hw_mode mode, int freq, 116051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt int channel, int ht_enabled, int vht_enabled, 117051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt int sec_channel_offset, int vht_oper_chwidth, 118051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt int center_segment0, int center_segment1); 1196c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtint hostapd_drv_do_acs(struct hostapd_data *hapd); 1208d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1218d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1228d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "drivers/driver.h" 1238d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 12461d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidtint hostapd_drv_wnm_oper(struct hostapd_data *hapd, 12561d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidt enum wnm_oper oper, const u8 *peer, 12661d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidt u8 *buf, u16 *buf_len); 12761d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidt 128051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidtint hostapd_drv_set_qos_map(struct hostapd_data *hapd, const u8 *qos_map_set, 129051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt u8 qos_map_set_len); 130051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt 131d5ab1b53af720d05586ccc0addabe93459f1f388Dmitry Shmidtvoid hostapd_get_ext_capa(struct hostapd_iface *iface); 132d5ab1b53af720d05586ccc0addabe93459f1f388Dmitry Shmidt 1338d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_countermeasures(struct hostapd_data *hapd, 1348d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int enabled) 1358d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1368d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || 1378d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt hapd->driver->hapd_set_countermeasures == NULL) 1388d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1398d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->hapd_set_countermeasures(hapd->drv_priv, enabled); 1408d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1418d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1428d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_sta_vlan(const char *ifname, 1438d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd, 1448d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int vlan_id) 1458d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1468d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_sta_vlan == NULL) 1478d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1488d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->set_sta_vlan(hapd->drv_priv, addr, ifname, 1498d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt vlan_id); 1508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1518d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1528d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_get_inact_sec(struct hostapd_data *hapd, 1538d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1548d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1558d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->get_inact_sec == NULL) 1568d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1578d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->get_inact_sec(hapd->drv_priv, addr); 1588d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1598d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1608d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_sta_remove(struct hostapd_data *hapd, 1618d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1628d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1637d17530e229db79208e99741071df97ea4faeec6Dmitry Shmidt if (!hapd->driver || !hapd->driver->sta_remove || !hapd->drv_priv) 1648d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1658d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->sta_remove(hapd->drv_priv, addr); 1668d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1678d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1688d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_hapd_send_eapol(struct hostapd_data *hapd, 1698d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, const u8 *data, 1708d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt size_t data_len, int encrypt, 1718d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u32 flags) 1728d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1738d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->hapd_send_eapol == NULL) 1748d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1758d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->hapd_send_eapol(hapd->drv_priv, addr, data, 1768d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt data_len, encrypt, 1778d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt hapd->own_addr, flags); 1788d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1798d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1808d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_read_sta_data( 1818d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd, struct hostap_sta_driver_data *data, 1828d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1838d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1848d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->read_sta_data == NULL) 1858d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return -1; 1868d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->read_sta_data(hapd->drv_priv, data, addr); 1878d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1888d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1898d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_sta_clear_stats(struct hostapd_data *hapd, 1908d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1918d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1928d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->sta_clear_stats == NULL) 1938d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1948d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->sta_clear_stats(hapd->drv_priv, addr); 1958d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1968d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1978bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidtstatic inline int hostapd_drv_set_acl(struct hostapd_data *hapd, 1988bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt struct hostapd_acl_params *params) 1998bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt{ 2008bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_acl == NULL) 2018bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt return 0; 2028bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt return hapd->driver->set_acl(hapd->drv_priv, params); 2038bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt} 2048bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt 2051f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtstatic inline int hostapd_drv_set_ap(struct hostapd_data *hapd, 2061f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpa_driver_ap_params *params) 2078d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 2081f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_ap == NULL) 2098d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 2101f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt return hapd->driver->set_ap(hapd->drv_priv, params); 2118d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 2128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 2138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_radius_acl_auth(struct hostapd_data *hapd, 2148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *mac, int accepted, 2158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u32 session_timeout) 2168d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 2178d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_radius_acl_auth == NULL) 2188d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 2198d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->set_radius_acl_auth(hapd->drv_priv, mac, accepted, 2208d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt session_timeout); 2218d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 2228d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 2238d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_radius_acl_expire(struct hostapd_data *hapd, 2248d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *mac) 2258d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 2268d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || 2278d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt hapd->driver->set_radius_acl_expire == NULL) 2288d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 2298d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->set_radius_acl_expire(hapd->drv_priv, mac); 2308d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 2318d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 23275ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinenstatic inline int hostapd_drv_set_authmode(struct hostapd_data *hapd, 23375ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen int auth_algs) 23475ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen{ 23575ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen if (hapd->driver == NULL || hapd->driver->set_authmode == NULL) 23675ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen return 0; 23775ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen return hapd->driver->set_authmode(hapd->drv_priv, auth_algs); 23875ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen} 23975ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen 2401f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtstatic inline void hostapd_drv_poll_client(struct hostapd_data *hapd, 2411f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt const u8 *own_addr, const u8 *addr, 2421f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt int qos) 2431f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt{ 2441f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt if (hapd->driver == NULL || hapd->driver->poll_client == NULL) 2451f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt return; 2461f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt hapd->driver->poll_client(hapd->drv_priv, own_addr, addr, qos); 2471f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt} 2481f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt 249b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidtstatic inline int hostapd_drv_get_survey(struct hostapd_data *hapd, 250b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt unsigned int freq) 251b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt{ 252b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt if (hapd->driver == NULL) 253b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt return -1; 254b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt if (!hapd->driver->get_survey) 255b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt return -1; 256b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt return hapd->driver->get_survey(hapd->drv_priv, freq); 257b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt} 258b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt 259cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidtstatic inline int hostapd_get_country(struct hostapd_data *hapd, char *alpha2) 260cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt{ 261cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->get_country == NULL) 262cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return -1; 263cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return hapd->driver->get_country(hapd->drv_priv, alpha2); 264cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt} 265cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt 266cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidtstatic inline const char * hostapd_drv_get_radio_name(struct hostapd_data *hapd) 267cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt{ 268cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 269cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt hapd->driver->get_radio_name == NULL) 270cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return NULL; 271cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return hapd->driver->get_radio_name(hapd->drv_priv); 272cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt} 273cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt 274e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidtstatic inline int hostapd_drv_switch_channel(struct hostapd_data *hapd, 275e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt struct csa_settings *settings) 276e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt{ 277e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt if (hapd->driver == NULL || hapd->driver->switch_channel == NULL) 278e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt return -ENOTSUP; 279e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt 280e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt return hapd->driver->switch_channel(hapd->drv_priv, settings); 281e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt} 282e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt 283fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidtstatic inline int hostapd_drv_status(struct hostapd_data *hapd, char *buf, 284fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt size_t buflen) 285fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt{ 2867d17530e229db79208e99741071df97ea4faeec6Dmitry Shmidt if (!hapd->driver || !hapd->driver->status || !hapd->drv_priv) 287fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return -1; 288fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return hapd->driver->status(hapd->drv_priv, buf, buflen); 289fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt} 290fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 2916c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_add_ip_neigh(struct hostapd_data *hapd, 2926c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt int version, const u8 *ipaddr, 2936c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt int prefixlen, const u8 *addr) 2946c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 2956c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 2966c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_add_ip_neigh == NULL) 2976c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 2986c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_add_ip_neigh(hapd->drv_priv, version, ipaddr, 2996c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt prefixlen, addr); 3006c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3016c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 3026c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_delete_ip_neigh(struct hostapd_data *hapd, 3036c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt u8 version, const u8 *ipaddr) 3046c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 3056c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 3066c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_delete_ip_neigh == NULL) 3076c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 3086c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_delete_ip_neigh(hapd->drv_priv, version, 3096c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt ipaddr); 3106c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3116c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 3126c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_port_set_attr(struct hostapd_data *hapd, 3136c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt enum drv_br_port_attr attr, 3146c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt unsigned int val) 3156c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 3166c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 3176c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_port_set_attr == NULL) 3186c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 3196c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_port_set_attr(hapd->drv_priv, attr, val); 3206c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3216c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 3226c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_set_net_param(struct hostapd_data *hapd, 3236c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt enum drv_br_net_param param, 3246c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt unsigned int val) 3256c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 3266c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 3276c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_set_net_param == NULL) 3286c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 3296c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_set_net_param(hapd->drv_priv, param, val); 3306c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3316c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 332df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidtstatic inline int hostapd_drv_vendor_cmd(struct hostapd_data *hapd, 333df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt int vendor_id, int subcmd, 334df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt const u8 *data, size_t data_len, 335df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt struct wpabuf *buf) 336df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt{ 337df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->vendor_cmd == NULL) 338df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt return -1; 339df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt return hapd->driver->vendor_cmd(hapd->drv_priv, vendor_id, subcmd, data, 340df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt data_len, buf); 341df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt} 342df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt 3437f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidtstatic inline int hostapd_drv_stop_ap(struct hostapd_data *hapd) 3447f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt{ 3457d17530e229db79208e99741071df97ea4faeec6Dmitry Shmidt if (!hapd->driver || !hapd->driver->stop_ap || !hapd->drv_priv) 3467f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt return 0; 3477f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt return hapd->driver->stop_ap(hapd->drv_priv); 3487f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt} 3497f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt 3508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#endif /* AP_DRV_OPS */ 351