summaryrefslogtreecommitdiff
path: root/drivers/net/wireless/bcmdhd.1.88.45.x.cn/dhd_config.h
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/bcmdhd.1.88.45.x.cn/dhd_config.h')
-rwxr-xr-xdrivers/net/wireless/bcmdhd.1.88.45.x.cn/dhd_config.h174
1 files changed, 174 insertions, 0 deletions
diff --git a/drivers/net/wireless/bcmdhd.1.88.45.x.cn/dhd_config.h b/drivers/net/wireless/bcmdhd.1.88.45.x.cn/dhd_config.h
new file mode 100755
index 00000000..104048b5
--- /dev/null
+++ b/drivers/net/wireless/bcmdhd.1.88.45.x.cn/dhd_config.h
@@ -0,0 +1,174 @@
+
+#ifndef _dhd_config_
+#define _dhd_config_
+
+#include <bcmdevs.h>
+#include <dngl_stats.h>
+#include <dhd.h>
+#include <wlioctl.h>
+#include <proto/802.11.h>
+#ifdef POWER_OFF_IN_SUSPEND
+#include <wl_android.h>
+#include <bcmsdbus.h>
+#include <linux/mmc/sdio_func.h>
+#endif
+
+#define FW_PATH_AUTO_SELECT 1
+extern char firmware_path[MOD_PARAM_PATHLEN];
+extern int disable_proptx;
+extern uint dhd_doflow;
+
+/* mac range */
+typedef struct wl_mac_range {
+ uint32 oui;
+ uint32 nic_start;
+ uint32 nic_end;
+} wl_mac_range_t;
+
+/* mac list */
+typedef struct wl_mac_list {
+ int count;
+ wl_mac_range_t *mac;
+ char name[MOD_PARAM_PATHLEN]; /* path */
+} wl_mac_list_t;
+
+/* mac list head */
+typedef struct wl_mac_list_ctrl {
+ int count;
+ struct wl_mac_list *m_mac_list_head;
+} wl_mac_list_ctrl_t;
+
+/* channel list */
+typedef struct wl_channel_list {
+ /* in - # of channels, out - # of entries */
+ uint32 count;
+ /* variable length channel list */
+ uint32 channel[WL_NUMCHANNELS];
+} wl_channel_list_t;
+
+typedef struct wmes_param {
+ int aifsn[AC_COUNT];
+ int cwmin[AC_COUNT];
+ int cwmax[AC_COUNT];
+} wme_param_t;
+
+#ifdef PKT_FILTER_SUPPORT
+#define DHD_CONF_FILTER_MAX 8
+/* filter list */
+#define PKT_FILTER_LEN 150
+typedef struct conf_pkt_filter_add {
+ /* in - # of channels, out - # of entries */
+ uint32 count;
+ /* variable length filter list */
+ char filter[DHD_CONF_FILTER_MAX][PKT_FILTER_LEN];
+} conf_pkt_filter_add_t;
+
+/* pkt_filter_del list */
+typedef struct conf_pkt_filter_del {
+ /* in - # of channels, out - # of entries */
+ uint32 count;
+ /* variable length filter list */
+ uint32 id[DHD_CONF_FILTER_MAX];
+} conf_pkt_filter_del_t;
+#endif
+
+typedef struct dhd_conf {
+ wl_mac_list_ctrl_t fw_by_mac; /* Firmware auto selection by MAC */
+ wl_mac_list_ctrl_t nv_by_mac; /* NVRAM auto selection by MAC */
+ char fw_path[MOD_PARAM_PATHLEN]; /* Firmware path */
+ char nv_path[MOD_PARAM_PATHLEN]; /* NVRAM path */
+ uint band; /* Band, b:2.4G only, otherwise for auto */
+ int mimo_bw_cap; /* Bandwidth, 0:HT20ALL, 1: HT40ALL, 2:HT20IN2G_HT40PIN5G */
+ wl_country_t cspec; /* Country */
+ wl_channel_list_t channels; /* Support channels */
+ uint roam_off; /* Roaming, 0:enable, 1:disable */
+ uint roam_off_suspend; /* Roaming in suspend, 0:enable, 1:disable */
+ int roam_trigger[2]; /* The RSSI threshold to trigger roaming */
+ int roam_scan_period[2]; /* Roaming scan period */
+ int roam_delta[2]; /* Roaming candidate qualification delta */
+ int fullroamperiod; /* Full Roaming period */
+ uint keep_alive_period; /* The perioid in ms to send keep alive packet */
+ uint force_wme_ac;
+ wme_param_t wme; /* WME parameters */
+ int stbc; /* STBC for Tx/Rx */
+ int phy_oclscdenable; /* phy_oclscdenable */
+#ifdef PKT_FILTER_SUPPORT
+ conf_pkt_filter_add_t pkt_filter_add; /* Packet filter add */
+ conf_pkt_filter_del_t pkt_filter_del; /* Packet filter add */
+#endif
+ int srl; /* short retry limit */
+ int lrl; /* long retry limit */
+ uint bcn_timeout; /* beacon timeout */
+ uint32 bus_txglom; /* bus:txglom */
+ uint32 ampdu_ba_wsize;
+ bool kso_enable;
+ int spect;
+} dhd_conf_t;
+
+extern void *bcmsdh_get_drvdata(void);
+void dhd_conf_set_fw_name_by_mac(dhd_pub_t *dhd, bcmsdh_info_t *sdh, char *fw_path);
+void dhd_conf_set_nv_name_by_mac(dhd_pub_t *dhd, bcmsdh_info_t *sdh, char *nv_path);
+void dhd_conf_set_fw_name_by_chip(dhd_pub_t *dhd, char *dst, char *src);
+#if defined(HW_OOB)
+void dhd_conf_set_hw_oob_intr(bcmsdh_info_t *sdh, uint chip);
+#endif
+#if defined(CUSTOMER_HW) && defined(CONFIG_DHD_USE_STATIC_BUF)
+void* dhd_conf_prealloc(int section, unsigned long size);
+#endif
+void dhd_conf_set_fw_path(dhd_pub_t *dhd, char *fw_path);
+void dhd_conf_set_nv_path(dhd_pub_t *dhd, char *nv_path);
+int dhd_conf_set_band(dhd_pub_t *dhd);
+uint dhd_conf_get_band(dhd_pub_t *dhd);
+int dhd_conf_set_country(dhd_pub_t *dhd);
+int dhd_conf_get_country(dhd_pub_t *dhd, wl_country_t *cspec);
+int dhd_conf_fix_country(dhd_pub_t *dhd);
+bool dhd_conf_match_channel(dhd_pub_t *dhd, uint32 channel);
+int dhd_conf_set_roam(dhd_pub_t *dhd);
+void dhd_conf_set_mimo_bw_cap(dhd_pub_t *dhd);
+void dhd_conf_force_wme(dhd_pub_t *dhd);
+void dhd_conf_get_wme(dhd_pub_t *dhd, edcf_acparam_t *acp);
+void dhd_conf_set_wme(dhd_pub_t *dhd);
+void dhd_conf_set_stbc(dhd_pub_t *dhd);
+void dhd_conf_set_phyoclscdenable(dhd_pub_t *dhd);
+void dhd_conf_add_pkt_filter(dhd_pub_t *dhd);
+bool dhd_conf_del_pkt_filter(dhd_pub_t *dhd, uint32 id);
+void dhd_conf_discard_pkt_filter(dhd_pub_t *dhd);
+void dhd_conf_set_srl(dhd_pub_t *dhd);
+void dhd_conf_set_lrl(dhd_pub_t *dhd);
+void dhd_conf_set_glom(dhd_pub_t *dhd);
+void dhd_conf_set_ampdu_ba_wsize(dhd_pub_t *dhd);
+void dhd_conf_set_spect(dhd_pub_t *dhd);
+int dhd_conf_read_config(dhd_pub_t *dhd);
+int dhd_conf_preinit(dhd_pub_t *dhd);
+int dhd_conf_attach(dhd_pub_t *dhd);
+void dhd_conf_detach(dhd_pub_t *dhd);
+
+#ifdef POWER_OFF_IN_SUSPEND
+extern struct net_device *g_netdev;
+#if defined(CONFIG_HAS_EARLYSUSPEND)
+extern int g_wifi_on;
+#if defined(WL_ENABLE_P2P_IF)
+extern struct net_device *g_p2pnetdev;
+extern bool g_p2pnet_enabled;
+#endif
+#ifdef WL_CFG80211
+void wl_cfg80211_stop(void);
+void wl_cfg80211_send_disconnect(void);
+void wl_cfg80211_user_sync(bool lock);
+extern s32 wl_cfg80211_up2(void *para);
+extern s32 wl_cfg80211_down2(void *para);
+void wl_cfgp2p_start(void);
+void wl_cfgp2p_stop(void);
+void dhd_cleanup_virt_ifaces2(struct net_device *net);
+#endif
+void dhd_wlfc_cleanup2(struct net_device *net);
+extern int dhd_dev_init_ioctl(struct net_device *dev);
+void dhd_cleanup_wlfc(struct net_device *net);
+
+#endif
+void dhd_conf_wifi_suspend(struct sdio_func *func);
+void dhd_conf_register_wifi_suspend(struct sdio_func *func);
+void dhd_conf_unregister_wifi_suspend(struct sdio_func *func);
+#endif
+
+#endif /* _dhd_config_ */