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, 44bd14a57187b024f49f5b9ace55ef457d8d04650aDmitry Shmidt u32 flags, u8 qosinfo, u8 vht_opmode); 458d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_privacy(struct hostapd_data *hapd, int enabled); 468d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_generic_elem(struct hostapd_data *hapd, const u8 *elem, 478d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt size_t elem_len); 488d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_get_ssid(struct hostapd_data *hapd, u8 *buf, size_t len); 498d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_ssid(struct hostapd_data *hapd, const u8 *buf, size_t len); 508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_if_add(struct hostapd_data *hapd, enum wpa_driver_if_type type, 518d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const char *ifname, const u8 *addr, void *bss_ctx, 528d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt void **drv_priv, char *force_ifname, u8 *if_addr, 53cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt const char *bridge, int use_existing); 548d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_if_remove(struct hostapd_data *hapd, enum wpa_driver_if_type type, 558d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const char *ifname); 568d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_ieee8021x(struct hostapd_data *hapd, 578d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct wpa_bss_params *params); 588d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_get_seqnum(const char *ifname, struct hostapd_data *hapd, 598d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int idx, u8 *seq); 608d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_flush(struct hostapd_data *hapd); 616c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtint hostapd_set_freq(struct hostapd_data *hapd, enum hostapd_hw_mode mode, 626c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt int freq, int channel, int ht_enabled, int vht_enabled, 63a54fa5fb807eaeff45464139b5a7759f060cec68Dmitry Shmidt int sec_channel_offset, int vht_oper_chwidth, 64a54fa5fb807eaeff45464139b5a7759f060cec68Dmitry Shmidt int center_segment0, int center_segment1); 658d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_rts(struct hostapd_data *hapd, int rts); 668d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_frag(struct hostapd_data *hapd, int frag); 678d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr, 688d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int total_flags, int flags_or, int flags_and); 698d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_country(struct hostapd_data *hapd, const char *country); 708d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_set_tx_queue_params(struct hostapd_data *hapd, int queue, int aifs, 718d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int cw_min, int cw_max, int burst_time); 728d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct hostapd_hw_modes * 738d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidthostapd_get_hw_feature_data(struct hostapd_data *hapd, u16 *num_modes, 748d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u16 *flags); 758d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_driver_commit(struct hostapd_data *hapd); 768d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_none(struct hostapd_data *hapd); 778d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_driver_scan(struct hostapd_data *hapd, 788d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct wpa_driver_scan_params *params); 798d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstruct wpa_scan_results * hostapd_driver_get_scan_results( 808d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd); 818d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_driver_set_noa(struct hostapd_data *hapd, u8 count, int start, 828d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int duration); 838d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_set_key(const char *ifname, 848d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd, 858d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt enum wpa_alg alg, const u8 *addr, 868d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int key_idx, int set_tx, 878d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *seq, size_t seq_len, 888d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *key, size_t key_len); 898d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_send_mlme(struct hostapd_data *hapd, 901f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt const void *msg, size_t len, int noack); 918d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_sta_deauth(struct hostapd_data *hapd, 928d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int reason); 938d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtint hostapd_drv_sta_disassoc(struct hostapd_data *hapd, 948d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int reason); 9504949598a23f501be6eec21697465fd46a28840aDmitry Shmidtint hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq, 9604949598a23f501be6eec21697465fd46a28840aDmitry Shmidt unsigned int wait, const u8 *dst, const u8 *data, 9704949598a23f501be6eec21697465fd46a28840aDmitry Shmidt size_t len); 981f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_add_sta_node(struct hostapd_data *hapd, const u8 *addr, 991f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt u16 auth_alg); 1001f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_sta_auth(struct hostapd_data *hapd, const u8 *addr, 1011f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt u16 seq, u16 status, const u8 *ie, size_t len); 1021f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_sta_assoc(struct hostapd_data *hapd, const u8 *addr, 1031f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt int reassoc, u16 status, const u8 *ie, size_t len); 1041f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtint hostapd_add_tspec(struct hostapd_data *hapd, const u8 *addr, 1051f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt u8 *tspec_ie, size_t tspec_ielen); 1066c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtint hostapd_start_dfs_cac(struct hostapd_iface *iface, 1076c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt enum hostapd_hw_mode mode, int freq, 108051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt int channel, int ht_enabled, int vht_enabled, 109051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt int sec_channel_offset, int vht_oper_chwidth, 110051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt int center_segment0, int center_segment1); 1116c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtint hostapd_drv_do_acs(struct hostapd_data *hapd); 1128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#include "drivers/driver.h" 1158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 11661d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidtint hostapd_drv_wnm_oper(struct hostapd_data *hapd, 11761d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidt enum wnm_oper oper, const u8 *peer, 11861d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidt u8 *buf, u16 *buf_len); 11961d9df3e62aaa0e87ad05452fcb95142159a17b6Dmitry Shmidt 120051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidtint hostapd_drv_set_qos_map(struct hostapd_data *hapd, const u8 *qos_map_set, 121051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt u8 qos_map_set_len); 122051af73b8f8014eff33330aead0f36944b3403e6Dmitry Shmidt 1238d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_countermeasures(struct hostapd_data *hapd, 1248d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt int enabled) 1258d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1268d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || 1278d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt hapd->driver->hapd_set_countermeasures == NULL) 1288d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1298d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->hapd_set_countermeasures(hapd->drv_priv, enabled); 1308d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1318d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1328d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_sta_vlan(const char *ifname, 1338d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd, 1348d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, int vlan_id) 1358d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1368d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_sta_vlan == NULL) 1378d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1388d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->set_sta_vlan(hapd->drv_priv, addr, ifname, 1398d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt vlan_id); 1408d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1418d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1428d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_get_inact_sec(struct hostapd_data *hapd, 1438d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1448d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1458d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->get_inact_sec == NULL) 1468d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1478d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->get_inact_sec(hapd->drv_priv, addr); 1488d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1498d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1508d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_sta_remove(struct hostapd_data *hapd, 1518d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1528d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1538d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->sta_remove == NULL) 1548d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1558d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->sta_remove(hapd->drv_priv, addr); 1568d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1578d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1588d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_hapd_send_eapol(struct hostapd_data *hapd, 1598d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr, const u8 *data, 1608d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt size_t data_len, int encrypt, 1618d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u32 flags) 1628d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1638d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->hapd_send_eapol == NULL) 1648d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1658d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->hapd_send_eapol(hapd->drv_priv, addr, data, 1668d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt data_len, encrypt, 1678d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt hapd->own_addr, flags); 1688d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1698d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1708d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_read_sta_data( 1718d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt struct hostapd_data *hapd, struct hostap_sta_driver_data *data, 1728d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1738d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1748d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->read_sta_data == NULL) 1758d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return -1; 1768d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->read_sta_data(hapd->drv_priv, data, addr); 1778d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1788d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1798d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_sta_clear_stats(struct hostapd_data *hapd, 1808d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *addr) 1818d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1828d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->sta_clear_stats == NULL) 1838d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 1848d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->sta_clear_stats(hapd->drv_priv, addr); 1858d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 1868d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 1878bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidtstatic inline int hostapd_drv_set_acl(struct hostapd_data *hapd, 1888bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt struct hostapd_acl_params *params) 1898bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt{ 1908bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_acl == NULL) 1918bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt return 0; 1928bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt return hapd->driver->set_acl(hapd->drv_priv, params); 1938bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt} 1948bae4138a0356709720a96f3e50b4d734e532c12Dmitry Shmidt 1951f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtstatic inline int hostapd_drv_set_ap(struct hostapd_data *hapd, 1961f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt struct wpa_driver_ap_params *params) 1978d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 1981f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_ap == NULL) 1998d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 2001f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt return hapd->driver->set_ap(hapd->drv_priv, params); 2018d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 2028d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 2038d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_radius_acl_auth(struct hostapd_data *hapd, 2048d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *mac, int accepted, 2058d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt u32 session_timeout) 2068d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 2078d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->set_radius_acl_auth == NULL) 2088d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 2098d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->set_radius_acl_auth(hapd->drv_priv, mac, accepted, 2108d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt session_timeout); 2118d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 2128d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 2138d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidtstatic inline int hostapd_drv_set_radius_acl_expire(struct hostapd_data *hapd, 2148d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt const u8 *mac) 2158d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt{ 2168d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt if (hapd->driver == NULL || 2178d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt hapd->driver->set_radius_acl_expire == NULL) 2188d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return 0; 2198d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt return hapd->driver->set_radius_acl_expire(hapd->drv_priv, mac); 2208d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt} 2218d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt 22275ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinenstatic inline int hostapd_drv_set_authmode(struct hostapd_data *hapd, 22375ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen int auth_algs) 22475ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen{ 22575ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen if (hapd->driver == NULL || hapd->driver->set_authmode == NULL) 22675ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen return 0; 22775ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen return hapd->driver->set_authmode(hapd->drv_priv, auth_algs); 22875ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen} 22975ecf5267604f166b85a7ee2cf0d9cb682966680Jouni Malinen 2301f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidtstatic inline void hostapd_drv_poll_client(struct hostapd_data *hapd, 2311f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt const u8 *own_addr, const u8 *addr, 2321f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt int qos) 2331f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt{ 2341f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt if (hapd->driver == NULL || hapd->driver->poll_client == NULL) 2351f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt return; 2361f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt hapd->driver->poll_client(hapd->drv_priv, own_addr, addr, qos); 2371f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt} 2381f69aa52ea2e0a73ac502565df8c666ee49cab6aDmitry Shmidt 239b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidtstatic inline int hostapd_drv_get_survey(struct hostapd_data *hapd, 240b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt unsigned int freq) 241b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt{ 242b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt if (hapd->driver == NULL) 243b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt return -1; 244b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt if (!hapd->driver->get_survey) 245b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt return -1; 246b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt return hapd->driver->get_survey(hapd->drv_priv, freq); 247b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt} 248b7b4d0ec07161a6d76c40ba7ef1306e82fbb7e15Dmitry Shmidt 249cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidtstatic inline int hostapd_get_country(struct hostapd_data *hapd, char *alpha2) 250cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt{ 251cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->get_country == NULL) 252cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return -1; 253cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return hapd->driver->get_country(hapd->drv_priv, alpha2); 254cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt} 255cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt 256cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidtstatic inline const char * hostapd_drv_get_radio_name(struct hostapd_data *hapd) 257cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt{ 258cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 259cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt hapd->driver->get_radio_name == NULL) 260cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return NULL; 261cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt return hapd->driver->get_radio_name(hapd->drv_priv); 262cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt} 263cce06667447b5aec83452adb0c15100ada531095Dmitry Shmidt 264e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidtstatic inline int hostapd_drv_switch_channel(struct hostapd_data *hapd, 265e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt struct csa_settings *settings) 266e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt{ 267e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt if (hapd->driver == NULL || hapd->driver->switch_channel == NULL) 268e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt return -ENOTSUP; 269e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt 270e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt return hapd->driver->switch_channel(hapd->drv_priv, settings); 271e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt} 272e0e48dc666fb14a7bb60264ca87463ba7bc1fe0bDmitry Shmidt 273fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidtstatic inline int hostapd_drv_status(struct hostapd_data *hapd, char *buf, 274fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt size_t buflen) 275fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt{ 276fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->status == NULL) 277fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return -1; 278fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt return hapd->driver->status(hapd->drv_priv, buf, buflen); 279fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt} 280fb79edc9df1f20461e90e478363d207348213d35Dmitry Shmidt 2816c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_add_ip_neigh(struct hostapd_data *hapd, 2826c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt int version, const u8 *ipaddr, 2836c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt int prefixlen, const u8 *addr) 2846c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 2856c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 2866c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_add_ip_neigh == NULL) 2876c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 2886c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_add_ip_neigh(hapd->drv_priv, version, ipaddr, 2896c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt prefixlen, addr); 2906c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 2916c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 2926c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_delete_ip_neigh(struct hostapd_data *hapd, 2936c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt u8 version, const u8 *ipaddr) 2946c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 2956c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 2966c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_delete_ip_neigh == NULL) 2976c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 2986c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_delete_ip_neigh(hapd->drv_priv, version, 2996c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt ipaddr); 3006c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3016c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 3026c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_port_set_attr(struct hostapd_data *hapd, 3036c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt enum drv_br_port_attr attr, 3046c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt unsigned int val) 3056c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 3066c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 3076c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_port_set_attr == NULL) 3086c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 3096c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_port_set_attr(hapd->drv_priv, attr, val); 3106c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3116c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 3126c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidtstatic inline int hostapd_drv_br_set_net_param(struct hostapd_data *hapd, 3136c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt enum drv_br_net_param param, 3146c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt unsigned int val) 3156c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt{ 3166c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt if (hapd->driver == NULL || hapd->drv_priv == NULL || 3176c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt hapd->driver->br_set_net_param == NULL) 3186c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return -1; 3196c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt return hapd->driver->br_set_net_param(hapd->drv_priv, param, val); 3206c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt} 3216c0da2bb83f6915d8260912362692d1a742e057bDmitry Shmidt 322df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidtstatic inline int hostapd_drv_vendor_cmd(struct hostapd_data *hapd, 323df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt int vendor_id, int subcmd, 324df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt const u8 *data, size_t data_len, 325df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt struct wpabuf *buf) 326df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt{ 327df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->vendor_cmd == NULL) 328df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt return -1; 329df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt return hapd->driver->vendor_cmd(hapd->drv_priv, vendor_id, subcmd, data, 330df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt data_len, buf); 331df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt} 332df5a7e4c5c64890c2425bb47d665bbce4992b676Dmitry Shmidt 3337f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidtstatic inline int hostapd_drv_stop_ap(struct hostapd_data *hapd) 3347f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt{ 3357f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt if (hapd->driver == NULL || hapd->driver->stop_ap == NULL) 3367f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt return 0; 3377f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt return hapd->driver->stop_ap(hapd->drv_priv); 3387f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt} 3397f65602d49069f96a7bb44da8bd79ffe8d4c6a98Dmitry Shmidt 3408d520ff1dc2da35cdca849e982051b86468016d8Dmitry Shmidt#endif /* AP_DRV_OPS */ 341