提交 63f0023b 编写于 作者: L Luis Carlos Cobo 提交者: David S. Miller

[PATCH] libertas: pass boot2 version to firmware

Boot2 version used to be hardcoded in the uploaded firmware,
this patch preserves the boot2 version before uploading firmware
and sends it to the firmware again on resume.
Signed-off-by: NLuis Carlos Cobo <luisca@cozybit.com>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 2afc0c5d
...@@ -901,6 +901,17 @@ static int wlan_cmd_mesh_access(wlan_private * priv, ...@@ -901,6 +901,17 @@ static int wlan_cmd_mesh_access(wlan_private * priv,
return 0; return 0;
} }
static int wlan_cmd_set_boot2_ver(wlan_private * priv,
struct cmd_ds_command *cmd,
u16 cmd_action, void *pdata_buf)
{
struct cmd_ds_set_boot2_ver *boot2_ver = &cmd->params.boot2_ver;
cmd->command = cpu_to_le16(CMD_SET_BOOT2_VER);
cmd->size = cpu_to_le16(sizeof(struct cmd_ds_set_boot2_ver) + S_DS_GEN);
boot2_ver->version = priv->boot2_version;
return 0;
}
void libertas_queue_cmd(wlan_adapter * adapter, struct cmd_ctrl_node *cmdnode, u8 addtail) void libertas_queue_cmd(wlan_adapter * adapter, struct cmd_ctrl_node *cmdnode, u8 addtail)
{ {
unsigned long flags; unsigned long flags;
...@@ -1372,6 +1383,10 @@ int libertas_prepare_and_send_command(wlan_private * priv, ...@@ -1372,6 +1383,10 @@ int libertas_prepare_and_send_command(wlan_private * priv,
ret = wlan_cmd_mesh_access(priv, cmdptr, cmd_action, pdata_buf); ret = wlan_cmd_mesh_access(priv, cmdptr, cmd_action, pdata_buf);
break; break;
case CMD_SET_BOOT2_VER:
ret = wlan_cmd_set_boot2_ver(priv, cmdptr, cmd_action, pdata_buf);
break;
case CMD_GET_TSF: case CMD_GET_TSF:
cmdptr->command = cpu_to_le16(CMD_GET_TSF); cmdptr->command = cpu_to_le16(CMD_GET_TSF);
cmdptr->size = cpu_to_le16(sizeof(struct cmd_ds_get_tsf) + cmdptr->size = cpu_to_le16(sizeof(struct cmd_ds_get_tsf) +
......
...@@ -104,6 +104,7 @@ struct _wlan_private { ...@@ -104,6 +104,7 @@ struct _wlan_private {
int mesh_open; int mesh_open;
int infra_open; int infra_open;
int mesh_autostart_enabled; int mesh_autostart_enabled;
__le16 boot2_version;
char name[DEV_NAME_LEN]; char name[DEV_NAME_LEN];
......
...@@ -114,6 +114,8 @@ ...@@ -114,6 +114,8 @@
#define CMD_MESH_ACCESS 0x009b #define CMD_MESH_ACCESS 0x009b
#define CMD_SET_BOOT2_VER 0x00a5
/* For the IEEE Power Save */ /* For the IEEE Power Save */
#define CMD_SUBCMD_ENTER_PS 0x0030 #define CMD_SUBCMD_ENTER_PS 0x0030
#define CMD_SUBCMD_EXIT_PS 0x0031 #define CMD_SUBCMD_EXIT_PS 0x0031
......
...@@ -410,6 +410,11 @@ struct cmd_ds_802_11_monitor_mode { ...@@ -410,6 +410,11 @@ struct cmd_ds_802_11_monitor_mode {
u16 mode; u16 mode;
}; };
struct cmd_ds_set_boot2_ver {
u16 action;
u16 version;
};
struct cmd_ds_802_11_ps_mode { struct cmd_ds_802_11_ps_mode {
__le16 action; __le16 action;
__le16 nullpktinterval; __le16 nullpktinterval;
...@@ -660,6 +665,7 @@ struct cmd_ds_command { ...@@ -660,6 +665,7 @@ struct cmd_ds_command {
struct cmd_ds_bt_access bt; struct cmd_ds_bt_access bt;
struct cmd_ds_fwt_access fwt; struct cmd_ds_fwt_access fwt;
struct cmd_ds_mesh_access mesh; struct cmd_ds_mesh_access mesh;
struct cmd_ds_set_boot2_ver boot2_ver;
struct cmd_ds_get_tsf gettsf; struct cmd_ds_get_tsf gettsf;
struct cmd_ds_802_11_subscribe_event subscribe_event; struct cmd_ds_802_11_subscribe_event subscribe_event;
} params; } params;
......
...@@ -219,6 +219,7 @@ static int if_usb_probe(struct usb_interface *intf, ...@@ -219,6 +219,7 @@ static int if_usb_probe(struct usb_interface *intf,
priv->hw_host_to_card = if_usb_host_to_card; priv->hw_host_to_card = if_usb_host_to_card;
priv->hw_get_int_status = if_usb_get_int_status; priv->hw_get_int_status = if_usb_get_int_status;
priv->hw_read_event_cause = if_usb_read_event_cause; priv->hw_read_event_cause = if_usb_read_event_cause;
priv->boot2_version = udev->descriptor.bcdDevice;
if (libertas_activate_card(priv)) if (libertas_activate_card(priv))
goto err_activate_card; goto err_activate_card;
......
...@@ -981,6 +981,10 @@ static int wlan_setup_station_hw(wlan_private * priv) ...@@ -981,6 +981,10 @@ static int wlan_setup_station_hw(wlan_private * priv)
priv->mesh_autostart_enabled = 0; priv->mesh_autostart_enabled = 0;
} }
/* Set the boot2 version in firmware */
ret = libertas_prepare_and_send_command(priv, CMD_SET_BOOT2_VER,
0, CMD_OPTION_WAITFORRSP, 0, NULL);
ret = 0; ret = 0;
done: done:
lbs_deb_leave_args(LBS_DEB_FW, "ret %d", ret); lbs_deb_leave_args(LBS_DEB_FW, "ret %d", ret);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册