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