}
 
        if (event == VXGE_LL_FULL_RESET) {
+               netif_carrier_off(vdev->ndev);
+
                /* wait for all the vpath reset to complete */
                for (vp_id = 0; vp_id < vdev->no_of_vpath; vp_id++) {
                        while (test_bit(vp_id, &vdev->vp_reset))
                                msleep(50);
                }
 
+               netif_carrier_on(vdev->ndev);
+
                /* if execution mode is set to debug, don't reset the adapter */
                if (unlikely(vdev->exec_mode)) {
                        vxge_debug_init(VXGE_ERR,
  *
  * driver may reset the chip on events of serr, eccerr, etc
  */
-static int vxge_reset(struct vxgedev *vdev)
+static void vxge_reset(struct work_struct *work)
 {
-       return do_vxge_reset(vdev, VXGE_LL_FULL_RESET);
+       struct vxgedev *vdev = container_of(work, struct vxgedev, reset_task);
+
+       if (!netif_running(vdev->ndev))
+               return;
+
+       do_vxge_reset(vdev, VXGE_LL_FULL_RESET);
 }
 
 /**
  * This function is triggered if the Tx Queue is stopped
  * for a pre-defined amount of time when the Interface is still up.
  */
-static void
-vxge_tx_watchdog(struct net_device *dev)
+static void vxge_tx_watchdog(struct net_device *dev)
 {
        struct vxgedev *vdev;
 
 
        vdev->cric_err_event = VXGE_HW_EVENT_RESET_START;
 
-       vxge_reset(vdev);
+       schedule_work(&vdev->reset_task);
        vxge_debug_entryexit(VXGE_TRACE,
                "%s:%d  Exiting...", __func__, __LINE__);
 }
        ndev->netdev_ops = &vxge_netdev_ops;
 
        ndev->watchdog_timeo = VXGE_LL_WATCH_DOG_TIMEOUT;
+       INIT_WORK(&vdev->reset_task, vxge_reset);
 
        vxge_initialize_ethtool_ops(ndev);