提交 a9c130d5 编写于 作者: L Luciano Coelho

wl18xx: add board type module argument

Different board types (ie. FPGA, HDK and DVP/EVB) require slightly
different init configuration options.  Since we cannot probe the type
of board from the actual hardware, we need to pass it as an option
during module load.

This patch adds a module parameters that accepts the 3 different board
types, with DVP/EVB as the default, and uses this value where needed.
Signed-off-by: NLuciano Coelho <coelho@ti.com>
Signed-off-by: NArik Nemtsov <arik@wizery.com>
上级 3a8ddb61
...@@ -42,6 +42,7 @@ ...@@ -42,6 +42,7 @@
#define WL18XX_RX_CHECKSUM_MASK 0x40 #define WL18XX_RX_CHECKSUM_MASK 0x40
static char *ht_mode_param; static char *ht_mode_param;
static char *board_type_param;
static const u8 wl18xx_rate_to_idx_2ghz[] = { static const u8 wl18xx_rate_to_idx_2ghz[] = {
/* MCS rates are used only with 11n */ /* MCS rates are used only with 11n */
...@@ -680,8 +681,7 @@ static void wl18xx_set_mac_and_phy(struct wl1271 *wl) ...@@ -680,8 +681,7 @@ static void wl18xx_set_mac_and_phy(struct wl1271 *wl)
params.secondary_clock_setting_time = params.secondary_clock_setting_time =
phy->secondary_clock_setting_time; phy->secondary_clock_setting_time;
/* TODO: hardcoded for now */ params.board_type = priv->board_type;
params.board_type = BOARD_TYPE_DVP_EVB_18XX;
wlcore_set_partition(wl, &wl->ptable[PART_PHY_INIT]); wlcore_set_partition(wl, &wl->ptable[PART_PHY_INIT]);
wl1271_write(wl, WL18XX_PHY_INIT_MEM_ADDR, (u8 *)&params, wl1271_write(wl, WL18XX_PHY_INIT_MEM_ADDR, (u8 *)&params,
...@@ -964,6 +964,7 @@ int __devinit wl18xx_probe(struct platform_device *pdev) ...@@ -964,6 +964,7 @@ int __devinit wl18xx_probe(struct platform_device *pdev)
} }
wl = hw->priv; wl = hw->priv;
priv = wl->priv;
wl->ops = &wl18xx_ops; wl->ops = &wl18xx_ops;
wl->ptable = wl18xx_ptable; wl->ptable = wl18xx_ptable;
wl->rtable = wl18xx_rtable; wl->rtable = wl18xx_rtable;
...@@ -979,6 +980,24 @@ int __devinit wl18xx_probe(struct platform_device *pdev) ...@@ -979,6 +980,24 @@ int __devinit wl18xx_probe(struct platform_device *pdev)
memcpy(&wl->ht_cap, &wl18xx_mimo_ht_cap, memcpy(&wl->ht_cap, &wl18xx_mimo_ht_cap,
sizeof(wl18xx_mimo_ht_cap)); sizeof(wl18xx_mimo_ht_cap));
if (!board_type_param) {
board_type_param = kstrdup("dvp_evb", GFP_KERNEL);
priv->board_type = BOARD_TYPE_DVP_EVB_18XX;
} else {
if (!strcmp(board_type_param, "fpga"))
priv->board_type = BOARD_TYPE_FPGA_18XX;
else if (!strcmp(board_type_param, "hdk"))
priv->board_type = BOARD_TYPE_HDK_18XX;
else if (!strcmp(board_type_param, "dvp_evb"))
priv->board_type = BOARD_TYPE_DVP_EVB_18XX;
else {
wl1271_error("invalid board type '%s'",
board_type_param);
wlcore_free_hw(wl);
return -EINVAL;
}
}
wl18xx_conf_init(wl); wl18xx_conf_init(wl);
return wlcore_probe(wl, pdev); return wlcore_probe(wl, pdev);
...@@ -1015,6 +1034,9 @@ module_exit(wl18xx_exit); ...@@ -1015,6 +1034,9 @@ module_exit(wl18xx_exit);
module_param_named(ht_mode, ht_mode_param, charp, S_IRUSR); module_param_named(ht_mode, ht_mode_param, charp, S_IRUSR);
MODULE_PARM_DESC(ht_mode, "Force HT mode: wide or mimo"); MODULE_PARM_DESC(ht_mode, "Force HT mode: wide or mimo");
module_param_named(board_type, board_type_param, charp, S_IRUSR);
MODULE_PARM_DESC(board_type, "Board type: fpga, hdk or dvp_evb (default)");
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL v2");
MODULE_AUTHOR("Luciano Coelho <coelho@ti.com>"); MODULE_AUTHOR("Luciano Coelho <coelho@ti.com>");
MODULE_FIRMWARE(WL18XX_FW_NAME); MODULE_FIRMWARE(WL18XX_FW_NAME);
...@@ -34,6 +34,8 @@ struct wl18xx_priv { ...@@ -34,6 +34,8 @@ struct wl18xx_priv {
/* Index of last released Tx desc in FW */ /* Index of last released Tx desc in FW */
u8 last_fw_rls_idx; u8 last_fw_rls_idx;
u8 board_type;
}; };
#define WL18XX_FW_MAX_TX_STATUS_DESC 33 #define WL18XX_FW_MAX_TX_STATUS_DESC 33
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册