net: wifi: rockchip: update broadcom drivers for kernel4.4
[firefly-linux-kernel-4.4.55.git] / drivers / net / wireless / rockchip_wlan / rkwifi / bcmdhd / dhd_config.h
index 203714af9ffbc78ade11a45ea3a81b9bb2597e57..d2bd3062a471681f090c213294928e4ea6407965 100755 (executable)
@@ -9,11 +9,31 @@
 #include <proto/802.11.h>\r
 \r
 #define FW_PATH_AUTO_SELECT 1\r
+//#define CONFIG_PATH_AUTO_SELECT\r
 extern char firmware_path[MOD_PARAM_PATHLEN];\r
 extern int disable_proptx;\r
+extern uint dhd_rxbound;
+extern uint dhd_txbound;
+#define TXGLOM_RECV_OFFSET 8
 #ifdef BCMSDIO\r
 extern uint dhd_doflow;\r
+extern uint dhd_slpauto;\r
+\r
+#define BCM43362A0_CHIP_REV     0\r
+#define BCM43362A2_CHIP_REV     1\r
+#define BCM43430A0_CHIP_REV     0\r
+#define BCM43430A1_CHIP_REV     1\r
+#define BCM4330B2_CHIP_REV      4\r
+#define BCM4334B1_CHIP_REV      3\r
+#define BCM43341B0_CHIP_REV     2\r
+#define BCM43241B4_CHIP_REV     5\r
+#define BCM4335A0_CHIP_REV      2\r
+#define BCM4339A0_CHIP_REV      1\r
+#define BCM43455C0_CHIP_REV     6\r
+#define BCM4354A1_CHIP_REV      1\r
+#define BCM4359B1_CHIP_REV      5\r
 #endif\r
+#define BCM4356A2_CHIP_REV      2\r
 \r
 /* mac range */\r
 typedef struct wl_mac_range {\r
@@ -82,13 +102,21 @@ typedef struct conf_pkt_filter_del {
 } conf_pkt_filter_del_t;\r
 #endif\r
 \r
+#define CONFIG_COUNTRY_LIST_SIZE 100\r
+/* country list */\r
+typedef struct conf_country_list {\r
+       uint32 count;\r
+       wl_country_t cspec[CONFIG_COUNTRY_LIST_SIZE];\r
+} conf_country_list_t;\r
+\r
 typedef struct dhd_conf {\r
        uint    chip;                   /* chip number */
        uint    chiprev;                /* chip revision */\r
        wl_mac_list_ctrl_t fw_by_mac;   /* Firmware auto selection by MAC */\r
        wl_mac_list_ctrl_t nv_by_mac;   /* NVRAM auto selection by MAC */\r
        wl_chip_nv_path_list_ctrl_t nv_by_chip; /* NVRAM auto selection by chip */\r
-       uint band;                      /* Band, b:2.4G only, otherwise for auto */\r
+       conf_country_list_t country_list; /* Country list */\r
+       int band;                       /* Band, b:2.4G only, otherwise for auto */\r
        int mimo_bw_cap;                        /* Bandwidth, 0:HT20ALL, 1: HT40ALL, 2:HT20IN2G_HT40PIN5G */\r
        wl_country_t cspec;             /* Country */\r
        wl_channel_list_t channels;     /* Support channels */\r
@@ -99,13 +127,14 @@ typedef struct dhd_conf {
        int roam_delta[2];                      /* Roaming candidate qualification delta */\r
        int fullroamperiod;                     /* Full Roaming period */\r
        uint keep_alive_period;         /* The perioid in ms to send keep alive packet */\r
-       uint force_wme_ac;\r
+       int force_wme_ac;\r
        wme_param_t wme;        /* WME parameters */\r
        int stbc;                       /* STBC for Tx/Rx */\r
        int phy_oclscdenable;           /* phy_oclscdenable */\r
 #ifdef PKT_FILTER_SUPPORT\r
        conf_pkt_filter_add_t pkt_filter_add;           /* Packet filter add */\r
        conf_pkt_filter_del_t pkt_filter_del;           /* Packet filter add */\r
+       bool pkt_filter_magic;\r
 #endif\r
        int srl;        /* short retry limit */\r
        int lrl;        /* long retry limit */\r
@@ -115,58 +144,67 @@ typedef struct dhd_conf {
        int txbf;\r
        int lpc;\r
        int disable_proptx;\r
-       uint32 bus_txglom;      /* bus:txglom */\r
+       int bus_txglom; /* bus:txglom */\r
        int use_rxchain;\r
        bool bus_rxglom;        /* bus:rxglom */\r
-       int txglomsize;\r
-       uint32 ampdu_ba_wsize;\r
+       uint txglomsize;\r
+       int ampdu_ba_wsize;\r
        int dpc_cpucore;\r
        int frameburst;\r
        bool deepsleep;\r
        int pm;\r
        uint8 tcpack_sup_mode;\r
+       int dhd_poll;\r
+       uint deferred_tx_len;\r
+       int pktprio8021x;\r
+       bool txctl_tmo_fix;\r
+       bool swtxglom; /* SW TXGLOM */\r
+       bool txglom_ext; /* Only for 43362/4330/43340/43341/43241 */
+       /*txglom_bucket_size:
+        * 43362/4330: 1680
+        * 43340/43341/43241: 1684
+        */
+       int txglom_bucket_size;
+       int tx_max_offset;\r
+       bool tx_in_rx; // Skip tx before rx, in order to get more glomed in tx\r
+       int rsdb_mode;\r
+       bool txglom_mode;\r
 } dhd_conf_t;\r
 \r
 #ifdef BCMSDIO\r
 int dhd_conf_get_mac(dhd_pub_t *dhd, bcmsdh_info_t *sdh, uint8 *mac);\r
 void dhd_conf_set_fw_name_by_mac(dhd_pub_t *dhd, bcmsdh_info_t *sdh, char *fw_path);\r
 void dhd_conf_set_nv_name_by_mac(dhd_pub_t *dhd, bcmsdh_info_t *sdh, char *nv_path);\r
-#if defined(HW_OOB)\r
+#if defined(HW_OOB) || defined(FORCE_WOWLAN)\r
 void dhd_conf_set_hw_oob_intr(bcmsdh_info_t *sdh, uint chip);\r
 #endif\r
 #endif\r
-void dhd_conf_set_fw_name_by_chip(dhd_pub_t *dhd, char *fw_path, char *nv_path);\r
+void dhd_conf_set_fw_name_by_chip(dhd_pub_t *dhd, char *fw_path);\r
 void dhd_conf_set_nv_name_by_chip(dhd_pub_t *dhd, char *nv_path);\r
 void dhd_conf_set_conf_path_by_nv_path(dhd_pub_t *dhd, char *conf_path, char *nv_path);\r
-int dhd_conf_set_band(dhd_pub_t *dhd);\r
+#ifdef CONFIG_PATH_AUTO_SELECT\r
+void dhd_conf_set_conf_name_by_chip(dhd_pub_t *dhd, char *conf_path);\r
+#endif\r
+int dhd_conf_set_fw_int_cmd(dhd_pub_t *dhd, char *name, uint cmd, int val, int def, bool down);\r
+int dhd_conf_set_fw_string_cmd(dhd_pub_t *dhd, char *cmd, int val, int def, bool down);\r
 uint dhd_conf_get_band(dhd_pub_t *dhd);\r
 int dhd_conf_set_country(dhd_pub_t *dhd);\r
 int dhd_conf_get_country(dhd_pub_t *dhd, wl_country_t *cspec);\r
+int dhd_conf_get_country_from_config(dhd_pub_t *dhd, wl_country_t *cspec);\r
 int dhd_conf_fix_country(dhd_pub_t *dhd);\r
 bool dhd_conf_match_channel(dhd_pub_t *dhd, uint32 channel);\r
 int dhd_conf_set_roam(dhd_pub_t *dhd);\r
-void dhd_conf_set_mimo_bw_cap(dhd_pub_t *dhd);\r
-void dhd_conf_force_wme(dhd_pub_t *dhd);\r
 void dhd_conf_get_wme(dhd_pub_t *dhd, edcf_acparam_t *acp);\r
 void dhd_conf_set_wme(dhd_pub_t *dhd);\r
-void dhd_conf_set_stbc(dhd_pub_t *dhd);\r
-void dhd_conf_set_phyoclscdenable(dhd_pub_t *dhd);\r
 void dhd_conf_add_pkt_filter(dhd_pub_t *dhd);\r
 bool dhd_conf_del_pkt_filter(dhd_pub_t *dhd, uint32 id);\r
 void dhd_conf_discard_pkt_filter(dhd_pub_t *dhd);\r
-void dhd_conf_set_srl(dhd_pub_t *dhd);\r
-void dhd_conf_set_lrl(dhd_pub_t *dhd);\r
-void dhd_conf_set_bus_txglom(dhd_pub_t *dhd);\r
-void dhd_conf_set_ampdu_ba_wsize(dhd_pub_t *dhd);\r
-void dhd_conf_set_spect(dhd_pub_t *dhd);\r
-void dhd_conf_set_txbf(dhd_pub_t *dhd);\r
-void dhd_conf_set_frameburst(dhd_pub_t *dhd);\r
-void dhd_conf_set_lpc(dhd_pub_t *dhd);\r
 void dhd_conf_set_disable_proptx(dhd_pub_t *dhd);\r
 int dhd_conf_read_config(dhd_pub_t *dhd, char *conf_path);\r
 int dhd_conf_set_chiprev(dhd_pub_t *dhd, uint chip, uint chiprev);\r
 uint dhd_conf_get_chip(void *context);\r
 uint dhd_conf_get_chiprev(void *context);\r
+void dhd_conf_set_txglom_params(dhd_pub_t *dhd, bool enable);\r
 int dhd_conf_get_pm(dhd_pub_t *dhd);\r
 int dhd_conf_get_tcpack_sup_mode(dhd_pub_t *dhd);\r
 int dhd_conf_preinit(dhd_pub_t *dhd);\r