2009-12-25 07:20:35 -05:00
|
|
|
/*
|
|
|
|
* hostapd - Driver operations
|
2014-01-05 14:50:34 -05:00
|
|
|
* Copyright (c) 2009-2014, Jouni Malinen <j@w1.fi>
|
2009-12-25 07:20:35 -05:00
|
|
|
*
|
2012-02-11 09:46:35 -05:00
|
|
|
* This software may be distributed under the terms of the BSD license.
|
|
|
|
* See README for more details.
|
2009-12-25 07:20:35 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef AP_DRV_OPS
|
|
|
|
#define AP_DRV_OPS
|
|
|
|
|
2009-12-25 17:21:22 -05:00
|
|
|
enum wpa_driver_if_type;
|
|
|
|
struct wpa_bss_params;
|
|
|
|
struct wpa_driver_scan_params;
|
2010-11-24 09:50:06 -05:00
|
|
|
struct ieee80211_ht_capabilities;
|
2012-12-28 10:30:30 -05:00
|
|
|
struct ieee80211_vht_capabilities;
|
2013-11-25 14:16:14 -05:00
|
|
|
struct hostapd_freq_params;
|
2009-12-25 17:21:22 -05:00
|
|
|
|
2011-04-02 15:03:05 -04:00
|
|
|
u32 hostapd_sta_flags_to_drv(u32 flags);
|
2011-08-26 14:14:25 -04:00
|
|
|
int hostapd_build_ap_extra_ies(struct hostapd_data *hapd,
|
|
|
|
struct wpabuf **beacon,
|
|
|
|
struct wpabuf **proberesp,
|
|
|
|
struct wpabuf **assocresp);
|
|
|
|
void hostapd_free_ap_extra_ies(struct hostapd_data *hapd, struct wpabuf *beacon,
|
|
|
|
struct wpabuf *proberesp,
|
|
|
|
struct wpabuf *assocresp);
|
2015-03-24 09:05:43 -04:00
|
|
|
int hostapd_reset_ap_wps_ie(struct hostapd_data *hapd);
|
2010-11-24 09:50:06 -05:00
|
|
|
int hostapd_set_ap_wps_ie(struct hostapd_data *hapd);
|
|
|
|
int hostapd_set_authorized(struct hostapd_data *hapd,
|
|
|
|
struct sta_info *sta, int authorized);
|
|
|
|
int hostapd_set_sta_flags(struct hostapd_data *hapd, struct sta_info *sta);
|
|
|
|
int hostapd_set_drv_ieee8021x(struct hostapd_data *hapd, const char *ifname,
|
|
|
|
int enabled);
|
|
|
|
int hostapd_vlan_if_add(struct hostapd_data *hapd, const char *ifname);
|
|
|
|
int hostapd_vlan_if_remove(struct hostapd_data *hapd, const char *ifname);
|
2013-07-20 10:41:22 -04:00
|
|
|
int hostapd_set_wds_sta(struct hostapd_data *hapd, char *ifname_wds,
|
|
|
|
const u8 *addr, int aid, int val);
|
2010-11-24 09:50:06 -05:00
|
|
|
int hostapd_sta_add(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr, u16 aid, u16 capability,
|
|
|
|
const u8 *supp_rates, size_t supp_rates_len,
|
|
|
|
u16 listen_interval,
|
2011-07-12 13:26:52 -04:00
|
|
|
const struct ieee80211_ht_capabilities *ht_capab,
|
2012-12-28 10:30:30 -05:00
|
|
|
const struct ieee80211_vht_capabilities *vht_capab,
|
2016-04-07 06:31:01 -04:00
|
|
|
u32 flags, u8 qosinfo, u8 vht_opmode, int supp_p2p_ps,
|
|
|
|
int set);
|
2009-12-25 17:12:25 -05:00
|
|
|
int hostapd_set_privacy(struct hostapd_data *hapd, int enabled);
|
|
|
|
int hostapd_set_generic_elem(struct hostapd_data *hapd, const u8 *elem,
|
|
|
|
size_t elem_len);
|
|
|
|
int hostapd_get_ssid(struct hostapd_data *hapd, u8 *buf, size_t len);
|
|
|
|
int hostapd_set_ssid(struct hostapd_data *hapd, const u8 *buf, size_t len);
|
|
|
|
int hostapd_if_add(struct hostapd_data *hapd, enum wpa_driver_if_type type,
|
2010-03-06 15:22:56 -05:00
|
|
|
const char *ifname, const u8 *addr, void *bss_ctx,
|
2011-03-15 07:02:49 -04:00
|
|
|
void **drv_priv, char *force_ifname, u8 *if_addr,
|
2013-10-31 13:41:42 -04:00
|
|
|
const char *bridge, int use_existing);
|
2009-12-25 17:12:25 -05:00
|
|
|
int hostapd_if_remove(struct hostapd_data *hapd, enum wpa_driver_if_type type,
|
|
|
|
const char *ifname);
|
2009-12-25 17:21:22 -05:00
|
|
|
int hostapd_set_ieee8021x(struct hostapd_data *hapd,
|
|
|
|
struct wpa_bss_params *params);
|
|
|
|
int hostapd_get_seqnum(const char *ifname, struct hostapd_data *hapd,
|
|
|
|
const u8 *addr, int idx, u8 *seq);
|
|
|
|
int hostapd_flush(struct hostapd_data *hapd);
|
2015-01-03 09:59:14 -05:00
|
|
|
int hostapd_set_freq(struct hostapd_data *hapd, enum hostapd_hw_mode mode,
|
|
|
|
int freq, int channel, int ht_enabled, int vht_enabled,
|
2012-12-28 10:24:21 -05:00
|
|
|
int sec_channel_offset, int vht_oper_chwidth,
|
|
|
|
int center_segment0, int center_segment1);
|
2009-12-25 17:21:22 -05:00
|
|
|
int hostapd_set_rts(struct hostapd_data *hapd, int rts);
|
|
|
|
int hostapd_set_frag(struct hostapd_data *hapd, int frag);
|
|
|
|
int hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr,
|
|
|
|
int total_flags, int flags_or, int flags_and);
|
|
|
|
int hostapd_set_country(struct hostapd_data *hapd, const char *country);
|
|
|
|
int hostapd_set_tx_queue_params(struct hostapd_data *hapd, int queue, int aifs,
|
|
|
|
int cw_min, int cw_max, int burst_time);
|
|
|
|
struct hostapd_hw_modes *
|
|
|
|
hostapd_get_hw_feature_data(struct hostapd_data *hapd, u16 *num_modes,
|
|
|
|
u16 *flags);
|
|
|
|
int hostapd_driver_commit(struct hostapd_data *hapd);
|
|
|
|
int hostapd_drv_none(struct hostapd_data *hapd);
|
|
|
|
int hostapd_driver_scan(struct hostapd_data *hapd,
|
|
|
|
struct wpa_driver_scan_params *params);
|
|
|
|
struct wpa_scan_results * hostapd_driver_get_scan_results(
|
|
|
|
struct hostapd_data *hapd);
|
2010-07-08 20:14:24 -04:00
|
|
|
int hostapd_driver_set_noa(struct hostapd_data *hapd, u8 count, int start,
|
|
|
|
int duration);
|
2010-11-24 10:01:21 -05:00
|
|
|
int hostapd_drv_set_key(const char *ifname,
|
|
|
|
struct hostapd_data *hapd,
|
|
|
|
enum wpa_alg alg, const u8 *addr,
|
|
|
|
int key_idx, int set_tx,
|
|
|
|
const u8 *seq, size_t seq_len,
|
|
|
|
const u8 *key, size_t key_len);
|
|
|
|
int hostapd_drv_send_mlme(struct hostapd_data *hapd,
|
2011-11-19 12:02:05 -05:00
|
|
|
const void *msg, size_t len, int noack);
|
2015-09-08 05:46:26 -04:00
|
|
|
int hostapd_drv_send_mlme_csa(struct hostapd_data *hapd,
|
|
|
|
const void *msg, size_t len, int noack,
|
|
|
|
const u16 *csa_offs, size_t csa_offs_len);
|
2010-11-24 10:01:21 -05:00
|
|
|
int hostapd_drv_sta_deauth(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr, int reason);
|
|
|
|
int hostapd_drv_sta_disassoc(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr, int reason);
|
2012-02-26 13:52:31 -05:00
|
|
|
int hostapd_drv_send_action(struct hostapd_data *hapd, unsigned int freq,
|
|
|
|
unsigned int wait, const u8 *dst, const u8 *data,
|
|
|
|
size_t len);
|
2016-06-10 14:30:03 -04:00
|
|
|
int hostapd_drv_send_action_addr3_ap(struct hostapd_data *hapd,
|
|
|
|
unsigned int freq,
|
|
|
|
unsigned int wait, const u8 *dst,
|
|
|
|
const u8 *data, size_t len);
|
2011-09-29 17:05:29 -04:00
|
|
|
int hostapd_add_sta_node(struct hostapd_data *hapd, const u8 *addr,
|
|
|
|
u16 auth_alg);
|
|
|
|
int hostapd_sta_auth(struct hostapd_data *hapd, const u8 *addr,
|
|
|
|
u16 seq, u16 status, const u8 *ie, size_t len);
|
|
|
|
int hostapd_sta_assoc(struct hostapd_data *hapd, const u8 *addr,
|
|
|
|
int reassoc, u16 status, const u8 *ie, size_t len);
|
|
|
|
int hostapd_add_tspec(struct hostapd_data *hapd, const u8 *addr,
|
|
|
|
u8 *tspec_ie, size_t tspec_ielen);
|
2015-01-03 09:59:14 -05:00
|
|
|
int hostapd_start_dfs_cac(struct hostapd_iface *iface,
|
|
|
|
enum hostapd_hw_mode mode, int freq,
|
2013-10-16 05:18:52 -04:00
|
|
|
int channel, int ht_enabled, int vht_enabled,
|
|
|
|
int sec_channel_offset, int vht_oper_chwidth,
|
|
|
|
int center_segment0, int center_segment1);
|
2014-11-18 13:11:09 -05:00
|
|
|
int hostapd_drv_do_acs(struct hostapd_data *hapd);
|
2009-12-25 07:20:35 -05:00
|
|
|
|
2010-11-24 08:19:50 -05:00
|
|
|
|
|
|
|
#include "drivers/driver.h"
|
|
|
|
|
2012-02-26 10:22:02 -05:00
|
|
|
int hostapd_drv_wnm_oper(struct hostapd_data *hapd,
|
|
|
|
enum wnm_oper oper, const u8 *peer,
|
|
|
|
u8 *buf, u16 *buf_len);
|
|
|
|
|
2013-07-24 05:28:20 -04:00
|
|
|
int hostapd_drv_set_qos_map(struct hostapd_data *hapd, const u8 *qos_map_set,
|
|
|
|
u8 qos_map_set_len);
|
|
|
|
|
2016-04-12 04:01:42 -04:00
|
|
|
void hostapd_get_ext_capa(struct hostapd_iface *iface);
|
|
|
|
|
2010-11-24 08:26:44 -05:00
|
|
|
static inline int hostapd_drv_set_countermeasures(struct hostapd_data *hapd,
|
|
|
|
int enabled)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL ||
|
|
|
|
hapd->driver->hapd_set_countermeasures == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->hapd_set_countermeasures(hapd->drv_priv, enabled);
|
|
|
|
}
|
|
|
|
|
2010-11-24 08:36:02 -05:00
|
|
|
static inline int hostapd_drv_set_sta_vlan(const char *ifname,
|
|
|
|
struct hostapd_data *hapd,
|
|
|
|
const u8 *addr, int vlan_id)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->set_sta_vlan == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->set_sta_vlan(hapd->drv_priv, addr, ifname,
|
|
|
|
vlan_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_get_inact_sec(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->get_inact_sec == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->get_inact_sec(hapd->drv_priv, addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_sta_remove(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr)
|
|
|
|
{
|
2016-08-19 05:24:15 -04:00
|
|
|
if (!hapd->driver || !hapd->driver->sta_remove || !hapd->drv_priv)
|
2010-11-24 08:36:02 -05:00
|
|
|
return 0;
|
|
|
|
return hapd->driver->sta_remove(hapd->drv_priv, addr);
|
|
|
|
}
|
|
|
|
|
2010-11-24 09:34:49 -05:00
|
|
|
static inline int hostapd_drv_hapd_send_eapol(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr, const u8 *data,
|
2011-04-02 15:03:05 -04:00
|
|
|
size_t data_len, int encrypt,
|
|
|
|
u32 flags)
|
2010-11-24 09:34:49 -05:00
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->hapd_send_eapol == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->hapd_send_eapol(hapd->drv_priv, addr, data,
|
|
|
|
data_len, encrypt,
|
2011-04-02 15:03:05 -04:00
|
|
|
hapd->own_addr, flags);
|
2010-11-24 09:34:49 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_read_sta_data(
|
|
|
|
struct hostapd_data *hapd, struct hostap_sta_driver_data *data,
|
|
|
|
const u8 *addr)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->read_sta_data == NULL)
|
|
|
|
return -1;
|
|
|
|
return hapd->driver->read_sta_data(hapd->drv_priv, data, addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_sta_clear_stats(struct hostapd_data *hapd,
|
|
|
|
const u8 *addr)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->sta_clear_stats == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->sta_clear_stats(hapd->drv_priv, addr);
|
|
|
|
}
|
|
|
|
|
2013-05-23 07:38:20 -04:00
|
|
|
static inline int hostapd_drv_set_acl(struct hostapd_data *hapd,
|
|
|
|
struct hostapd_acl_params *params)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->set_acl == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->set_acl(hapd->drv_priv, params);
|
|
|
|
}
|
|
|
|
|
2011-08-10 06:22:37 -04:00
|
|
|
static inline int hostapd_drv_set_ap(struct hostapd_data *hapd,
|
|
|
|
struct wpa_driver_ap_params *params)
|
2010-11-24 09:34:49 -05:00
|
|
|
{
|
2011-08-10 06:22:37 -04:00
|
|
|
if (hapd->driver == NULL || hapd->driver->set_ap == NULL)
|
2010-11-24 09:34:49 -05:00
|
|
|
return 0;
|
2011-08-10 06:22:37 -04:00
|
|
|
return hapd->driver->set_ap(hapd->drv_priv, params);
|
2010-11-24 09:34:49 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_set_radius_acl_auth(struct hostapd_data *hapd,
|
|
|
|
const u8 *mac, int accepted,
|
|
|
|
u32 session_timeout)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->set_radius_acl_auth == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->set_radius_acl_auth(hapd->drv_priv, mac, accepted,
|
|
|
|
session_timeout);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_set_radius_acl_expire(struct hostapd_data *hapd,
|
|
|
|
const u8 *mac)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL ||
|
|
|
|
hapd->driver->set_radius_acl_expire == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->set_radius_acl_expire(hapd->drv_priv, mac);
|
|
|
|
}
|
|
|
|
|
2011-05-20 11:27:53 -04:00
|
|
|
static inline int hostapd_drv_set_authmode(struct hostapd_data *hapd,
|
|
|
|
int auth_algs)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->set_authmode == NULL)
|
|
|
|
return 0;
|
|
|
|
return hapd->driver->set_authmode(hapd->drv_priv, auth_algs);
|
|
|
|
}
|
|
|
|
|
2011-10-20 14:03:08 -04:00
|
|
|
static inline void hostapd_drv_poll_client(struct hostapd_data *hapd,
|
|
|
|
const u8 *own_addr, const u8 *addr,
|
|
|
|
int qos)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->poll_client == NULL)
|
|
|
|
return;
|
|
|
|
hapd->driver->poll_client(hapd->drv_priv, own_addr, addr, qos);
|
|
|
|
}
|
|
|
|
|
2013-07-24 02:59:13 -04:00
|
|
|
static inline int hostapd_drv_get_survey(struct hostapd_data *hapd,
|
|
|
|
unsigned int freq)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL)
|
|
|
|
return -1;
|
|
|
|
if (!hapd->driver->get_survey)
|
|
|
|
return -1;
|
|
|
|
return hapd->driver->get_survey(hapd->drv_priv, freq);
|
|
|
|
}
|
|
|
|
|
2013-11-03 09:33:11 -05:00
|
|
|
static inline int hostapd_get_country(struct hostapd_data *hapd, char *alpha2)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->get_country == NULL)
|
|
|
|
return -1;
|
|
|
|
return hapd->driver->get_country(hapd->drv_priv, alpha2);
|
|
|
|
}
|
|
|
|
|
2013-11-03 11:20:28 -05:00
|
|
|
static inline const char * hostapd_drv_get_radio_name(struct hostapd_data *hapd)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->drv_priv == NULL ||
|
|
|
|
hapd->driver->get_radio_name == NULL)
|
|
|
|
return NULL;
|
|
|
|
return hapd->driver->get_radio_name(hapd->drv_priv);
|
|
|
|
}
|
|
|
|
|
2013-11-14 05:28:31 -05:00
|
|
|
static inline int hostapd_drv_switch_channel(struct hostapd_data *hapd,
|
|
|
|
struct csa_settings *settings)
|
|
|
|
{
|
2017-03-22 07:42:38 -04:00
|
|
|
if (hapd->driver == NULL || hapd->driver->switch_channel == NULL ||
|
|
|
|
hapd->drv_priv == NULL)
|
2013-11-14 05:28:31 -05:00
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return hapd->driver->switch_channel(hapd->drv_priv, settings);
|
|
|
|
}
|
|
|
|
|
2014-01-05 14:50:34 -05:00
|
|
|
static inline int hostapd_drv_status(struct hostapd_data *hapd, char *buf,
|
|
|
|
size_t buflen)
|
|
|
|
{
|
2016-08-19 05:24:15 -04:00
|
|
|
if (!hapd->driver || !hapd->driver->status || !hapd->drv_priv)
|
2014-01-05 14:50:34 -05:00
|
|
|
return -1;
|
|
|
|
return hapd->driver->status(hapd->drv_priv, buf, buflen);
|
|
|
|
}
|
|
|
|
|
2014-09-24 02:02:04 -04:00
|
|
|
static inline int hostapd_drv_br_add_ip_neigh(struct hostapd_data *hapd,
|
2014-11-05 19:15:46 -05:00
|
|
|
int version, const u8 *ipaddr,
|
|
|
|
int prefixlen, const u8 *addr)
|
2014-09-24 02:02:04 -04:00
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->drv_priv == NULL ||
|
|
|
|
hapd->driver->br_add_ip_neigh == NULL)
|
|
|
|
return -1;
|
2014-11-05 19:15:46 -05:00
|
|
|
return hapd->driver->br_add_ip_neigh(hapd->drv_priv, version, ipaddr,
|
|
|
|
prefixlen, addr);
|
2014-09-24 02:02:04 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline int hostapd_drv_br_delete_ip_neigh(struct hostapd_data *hapd,
|
2014-11-05 19:15:46 -05:00
|
|
|
u8 version, const u8 *ipaddr)
|
2014-09-24 02:02:04 -04:00
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->drv_priv == NULL ||
|
|
|
|
hapd->driver->br_delete_ip_neigh == NULL)
|
|
|
|
return -1;
|
2014-11-05 19:15:46 -05:00
|
|
|
return hapd->driver->br_delete_ip_neigh(hapd->drv_priv, version,
|
|
|
|
ipaddr);
|
2014-09-24 02:02:04 -04:00
|
|
|
}
|
|
|
|
|
2014-09-26 00:04:43 -04:00
|
|
|
static inline int hostapd_drv_br_port_set_attr(struct hostapd_data *hapd,
|
|
|
|
enum drv_br_port_attr attr,
|
|
|
|
unsigned int val)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->drv_priv == NULL ||
|
|
|
|
hapd->driver->br_port_set_attr == NULL)
|
|
|
|
return -1;
|
|
|
|
return hapd->driver->br_port_set_attr(hapd->drv_priv, attr, val);
|
|
|
|
}
|
|
|
|
|
2014-09-27 00:09:54 -04:00
|
|
|
static inline int hostapd_drv_br_set_net_param(struct hostapd_data *hapd,
|
|
|
|
enum drv_br_net_param param,
|
|
|
|
unsigned int val)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->drv_priv == NULL ||
|
|
|
|
hapd->driver->br_set_net_param == NULL)
|
|
|
|
return -1;
|
|
|
|
return hapd->driver->br_set_net_param(hapd->drv_priv, param, val);
|
|
|
|
}
|
|
|
|
|
2014-03-27 02:58:31 -04:00
|
|
|
static inline int hostapd_drv_vendor_cmd(struct hostapd_data *hapd,
|
|
|
|
int vendor_id, int subcmd,
|
|
|
|
const u8 *data, size_t data_len,
|
|
|
|
struct wpabuf *buf)
|
|
|
|
{
|
|
|
|
if (hapd->driver == NULL || hapd->driver->vendor_cmd == NULL)
|
|
|
|
return -1;
|
|
|
|
return hapd->driver->vendor_cmd(hapd->drv_priv, vendor_id, subcmd, data,
|
|
|
|
data_len, buf);
|
|
|
|
}
|
|
|
|
|
2015-02-08 05:16:13 -05:00
|
|
|
static inline int hostapd_drv_stop_ap(struct hostapd_data *hapd)
|
|
|
|
{
|
2016-08-19 05:24:15 -04:00
|
|
|
if (!hapd->driver || !hapd->driver->stop_ap || !hapd->drv_priv)
|
2015-02-08 05:16:13 -05:00
|
|
|
return 0;
|
|
|
|
return hapd->driver->stop_ap(hapd->drv_priv);
|
|
|
|
}
|
|
|
|
|
2009-12-25 07:20:35 -05:00
|
|
|
#endif /* AP_DRV_OPS */
|