Commit 30816f83 authored by Malcolm Priestley's avatar Malcolm Priestley Committed by Greg Kroah-Hartman

staging: vt6656: mac80211 conversion: add vnt_init to bScheduleCommand

start driver by linking vnt_init to vt6656_probe use bScheduleCommand
to schedule new command WLAN_CMD_INIT_MAC80211

vResetCommandTimer is now used to initiate command timer.
Signed-off-by: default avatarMalcolm Priestley <tvboxspy@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 110f97e9
...@@ -397,6 +397,7 @@ struct vnt_private { ...@@ -397,6 +397,7 @@ struct vnt_private {
/* mac80211 */ /* mac80211 */
struct ieee80211_hw *hw; struct ieee80211_hw *hw;
struct ieee80211_vif *vif; struct ieee80211_vif *vif;
u8 mac_hw;
/* netdev */ /* netdev */
struct usb_device *usb; struct usb_device *usb;
struct net_device *dev; struct net_device *dev;
...@@ -744,5 +745,6 @@ struct vnt_private { ...@@ -744,5 +745,6 @@ struct vnt_private {
int device_alloc_frag_buf(struct vnt_private *, PSDeFragControlBlock pDeF); int device_alloc_frag_buf(struct vnt_private *, PSDeFragControlBlock pDeF);
void vnt_configure_filter(struct vnt_private *); void vnt_configure_filter(struct vnt_private *);
int vnt_init(struct vnt_private *priv);
#endif #endif
...@@ -1383,6 +1383,8 @@ int vnt_init(struct vnt_private *priv) ...@@ -1383,6 +1383,8 @@ int vnt_init(struct vnt_private *priv)
if (ieee80211_register_hw(priv->hw)) if (ieee80211_register_hw(priv->hw))
return -ENODEV; return -ENODEV;
priv->mac_hw = true;
return 0; return 0;
} }
...@@ -1443,6 +1445,11 @@ vt6656_probe(struct usb_interface *intf, const struct usb_device_id *id) ...@@ -1443,6 +1445,11 @@ vt6656_probe(struct usb_interface *intf, const struct usb_device_id *id)
usb_device_reset(priv); usb_device_reset(priv);
MP_CLEAR_FLAG(priv, fMP_DISCONNECTED);
vResetCommandTimer(priv);
bScheduleCommand(priv, WLAN_CMD_INIT_MAC80211, NULL);
return 0; return 0;
err_nomem: err_nomem:
...@@ -1458,7 +1465,8 @@ static void vt6656_disconnect(struct usb_interface *intf) ...@@ -1458,7 +1465,8 @@ static void vt6656_disconnect(struct usb_interface *intf)
if (!priv) if (!priv)
return; return;
ieee80211_unregister_hw(priv->hw); if (priv->mac_hw)
ieee80211_unregister_hw(priv->hw);
usb_set_intfdata(intf, NULL); usb_set_intfdata(intf, NULL);
usb_put_dev(interface_to_usbdev(intf)); usb_put_dev(interface_to_usbdev(intf));
......
...@@ -287,7 +287,20 @@ void vRunCommand(struct work_struct *work) ...@@ -287,7 +287,20 @@ void vRunCommand(struct work_struct *work)
return; return;
switch (pDevice->eCommandState) { switch (pDevice->eCommandState) {
case WLAN_CMD_INIT_MAC80211_START:
if (pDevice->mac_hw)
break;
dev_info(&pDevice->usb->dev, "Starting mac80211\n");
if (vnt_init(pDevice)) {
/* If fail all ends TODO retry */
dev_err(&pDevice->usb->dev, "failed to start\n");
ieee80211_free_hw(pDevice->hw);
return;
}
break;
case WLAN_CMD_SCAN_START: case WLAN_CMD_SCAN_START:
pDevice->byReAssocCount = 0; pDevice->byReAssocCount = 0;
...@@ -915,6 +928,10 @@ static int s_bCommandComplete(struct vnt_private *pDevice) ...@@ -915,6 +928,10 @@ static int s_bCommandComplete(struct vnt_private *pDevice)
pDevice->cbFreeCmdQueue++; pDevice->cbFreeCmdQueue++;
pDevice->bCmdRunning = true; pDevice->bCmdRunning = true;
switch (pDevice->eCommand) { switch (pDevice->eCommand) {
case WLAN_CMD_INIT_MAC80211:
pDevice->eCommandState = WLAN_CMD_INIT_MAC80211_START;
break;
case WLAN_CMD_BSSID_SCAN: case WLAN_CMD_BSSID_SCAN:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"eCommandState= WLAN_CMD_BSSID_SCAN\n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"eCommandState= WLAN_CMD_BSSID_SCAN\n");
pDevice->eCommandState = WLAN_CMD_SCAN_START; pDevice->eCommandState = WLAN_CMD_SCAN_START;
...@@ -1083,8 +1100,6 @@ static int s_bClearBSSID_SCAN(struct vnt_private *pDevice) ...@@ -1083,8 +1100,6 @@ static int s_bClearBSSID_SCAN(struct vnt_private *pDevice)
//mike add:reset command timer //mike add:reset command timer
void vResetCommandTimer(struct vnt_private *pDevice) void vResetCommandTimer(struct vnt_private *pDevice)
{ {
cancel_delayed_work_sync(&pDevice->run_command_work);
pDevice->cbFreeCmdQueue = CMD_Q_SIZE; pDevice->cbFreeCmdQueue = CMD_Q_SIZE;
pDevice->uCmdDequeueIdx = 0; pDevice->uCmdDequeueIdx = 0;
pDevice->uCmdEnqueueIdx = 0; pDevice->uCmdEnqueueIdx = 0;
......
...@@ -37,6 +37,7 @@ ...@@ -37,6 +37,7 @@
// Command code // Command code
typedef enum tagCMD_CODE { typedef enum tagCMD_CODE {
WLAN_CMD_INIT_MAC80211,
WLAN_CMD_BSSID_SCAN, WLAN_CMD_BSSID_SCAN,
WLAN_CMD_SSID, WLAN_CMD_SSID,
WLAN_CMD_DISASSOCIATE, WLAN_CMD_DISASSOCIATE,
...@@ -78,6 +79,7 @@ typedef struct tagCMD_ITEM { ...@@ -78,6 +79,7 @@ typedef struct tagCMD_ITEM {
// Command state // Command state
typedef enum tagCMD_STATE { typedef enum tagCMD_STATE {
WLAN_CMD_INIT_MAC80211_START,
WLAN_CMD_SCAN_START, WLAN_CMD_SCAN_START,
WLAN_CMD_SCAN_END, WLAN_CMD_SCAN_END,
WLAN_CMD_DISASSOCIATE_START, WLAN_CMD_DISASSOCIATE_START,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment