|
@@ -740,6 +740,7 @@ static int qlcnic_83xx_idc_unknown_state(struct qlcnic_adapter *adapter)
|
|
adapter->ahw->idc.err_code = -EIO;
|
|
adapter->ahw->idc.err_code = -EIO;
|
|
dev_err(&adapter->pdev->dev,
|
|
dev_err(&adapter->pdev->dev,
|
|
"%s: Device in unknown state\n", __func__);
|
|
"%s: Device in unknown state\n", __func__);
|
|
|
|
+ clear_bit(__QLCNIC_RESETTING, &adapter->state);
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -818,7 +819,6 @@ static int qlcnic_83xx_idc_ready_state(struct qlcnic_adapter *adapter)
|
|
struct qlcnic_hardware_context *ahw = adapter->ahw;
|
|
struct qlcnic_hardware_context *ahw = adapter->ahw;
|
|
struct qlcnic_mailbox *mbx = ahw->mailbox;
|
|
struct qlcnic_mailbox *mbx = ahw->mailbox;
|
|
int ret = 0;
|
|
int ret = 0;
|
|
- u32 owner;
|
|
|
|
u32 val;
|
|
u32 val;
|
|
|
|
|
|
/* Perform NIC configuration based ready state entry actions */
|
|
/* Perform NIC configuration based ready state entry actions */
|
|
@@ -848,9 +848,9 @@ static int qlcnic_83xx_idc_ready_state(struct qlcnic_adapter *adapter)
|
|
set_bit(__QLCNIC_RESETTING, &adapter->state);
|
|
set_bit(__QLCNIC_RESETTING, &adapter->state);
|
|
qlcnic_83xx_idc_enter_need_reset_state(adapter, 1);
|
|
qlcnic_83xx_idc_enter_need_reset_state(adapter, 1);
|
|
} else {
|
|
} else {
|
|
- owner = qlcnic_83xx_idc_find_reset_owner_id(adapter);
|
|
|
|
- if (ahw->pci_func == owner)
|
|
|
|
- qlcnic_dump_fw(adapter);
|
|
|
|
|
|
+ netdev_info(adapter->netdev, "%s: Auto firmware recovery is disabled\n",
|
|
|
|
+ __func__);
|
|
|
|
+ qlcnic_83xx_idc_enter_failed_state(adapter, 1);
|
|
}
|
|
}
|
|
return -EIO;
|
|
return -EIO;
|
|
}
|
|
}
|
|
@@ -948,13 +948,26 @@ static int qlcnic_83xx_idc_need_quiesce_state(struct qlcnic_adapter *adapter)
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
-static int qlcnic_83xx_idc_failed_state(struct qlcnic_adapter *adapter)
|
|
|
|
|
|
+static void qlcnic_83xx_idc_failed_state(struct qlcnic_adapter *adapter)
|
|
{
|
|
{
|
|
- dev_err(&adapter->pdev->dev, "%s: please restart!!\n", __func__);
|
|
|
|
|
|
+ struct qlcnic_hardware_context *ahw = adapter->ahw;
|
|
|
|
+ u32 val, owner;
|
|
|
|
+
|
|
|
|
+ val = QLCRDX(adapter->ahw, QLC_83XX_IDC_CTRL);
|
|
|
|
+ if (val & QLC_83XX_IDC_DISABLE_FW_RESET_RECOVERY) {
|
|
|
|
+ owner = qlcnic_83xx_idc_find_reset_owner_id(adapter);
|
|
|
|
+ if (ahw->pci_func == owner) {
|
|
|
|
+ qlcnic_83xx_stop_hw(adapter);
|
|
|
|
+ qlcnic_dump_fw(adapter);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ netdev_warn(adapter->netdev, "%s: Reboot will be required to recover the adapter!!\n",
|
|
|
|
+ __func__);
|
|
clear_bit(__QLCNIC_RESETTING, &adapter->state);
|
|
clear_bit(__QLCNIC_RESETTING, &adapter->state);
|
|
- adapter->ahw->idc.err_code = -EIO;
|
|
|
|
|
|
+ ahw->idc.err_code = -EIO;
|
|
|
|
|
|
- return 0;
|
|
|
|
|
|
+ return;
|
|
}
|
|
}
|
|
|
|
|
|
static int qlcnic_83xx_idc_quiesce_state(struct qlcnic_adapter *adapter)
|
|
static int qlcnic_83xx_idc_quiesce_state(struct qlcnic_adapter *adapter)
|
|
@@ -1063,12 +1076,6 @@ void qlcnic_83xx_idc_poll_dev_state(struct work_struct *work)
|
|
adapter->ahw->idc.prev_state = adapter->ahw->idc.curr_state;
|
|
adapter->ahw->idc.prev_state = adapter->ahw->idc.curr_state;
|
|
qlcnic_83xx_periodic_tasks(adapter);
|
|
qlcnic_83xx_periodic_tasks(adapter);
|
|
|
|
|
|
- /* Do not reschedule if firmaware is in hanged state and auto
|
|
|
|
- * recovery is disabled
|
|
|
|
- */
|
|
|
|
- if ((adapter->flags & QLCNIC_FW_HANG) && !qlcnic_auto_fw_reset)
|
|
|
|
- return;
|
|
|
|
-
|
|
|
|
/* Re-schedule the function */
|
|
/* Re-schedule the function */
|
|
if (test_bit(QLC_83XX_MODULE_LOADED, &adapter->ahw->idc.status))
|
|
if (test_bit(QLC_83XX_MODULE_LOADED, &adapter->ahw->idc.status))
|
|
qlcnic_schedule_work(adapter, qlcnic_83xx_idc_poll_dev_state,
|
|
qlcnic_schedule_work(adapter, qlcnic_83xx_idc_poll_dev_state,
|
|
@@ -1219,10 +1226,10 @@ void qlcnic_83xx_idc_request_reset(struct qlcnic_adapter *adapter, u32 key)
|
|
}
|
|
}
|
|
|
|
|
|
val = QLCRDX(adapter->ahw, QLC_83XX_IDC_CTRL);
|
|
val = QLCRDX(adapter->ahw, QLC_83XX_IDC_CTRL);
|
|
- if ((val & QLC_83XX_IDC_DISABLE_FW_RESET_RECOVERY) ||
|
|
|
|
- !qlcnic_auto_fw_reset) {
|
|
|
|
- dev_err(&adapter->pdev->dev,
|
|
|
|
- "%s:failed, device in non reset mode\n", __func__);
|
|
|
|
|
|
+ if (val & QLC_83XX_IDC_DISABLE_FW_RESET_RECOVERY) {
|
|
|
|
+ netdev_info(adapter->netdev, "%s: Auto firmware recovery is disabled\n",
|
|
|
|
+ __func__);
|
|
|
|
+ qlcnic_83xx_idc_enter_failed_state(adapter, 0);
|
|
qlcnic_83xx_unlock_driver(adapter);
|
|
qlcnic_83xx_unlock_driver(adapter);
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
@@ -1254,24 +1261,24 @@ static int qlcnic_83xx_copy_bootloader(struct qlcnic_adapter *adapter)
|
|
if (size & 0xF)
|
|
if (size & 0xF)
|
|
size = (size + 16) & ~0xF;
|
|
size = (size + 16) & ~0xF;
|
|
|
|
|
|
- p_cache = kzalloc(size, GFP_KERNEL);
|
|
|
|
|
|
+ p_cache = vzalloc(size);
|
|
if (p_cache == NULL)
|
|
if (p_cache == NULL)
|
|
return -ENOMEM;
|
|
return -ENOMEM;
|
|
|
|
|
|
ret = qlcnic_83xx_lockless_flash_read32(adapter, src, p_cache,
|
|
ret = qlcnic_83xx_lockless_flash_read32(adapter, src, p_cache,
|
|
size / sizeof(u32));
|
|
size / sizeof(u32));
|
|
if (ret) {
|
|
if (ret) {
|
|
- kfree(p_cache);
|
|
|
|
|
|
+ vfree(p_cache);
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
/* 16 byte write to MS memory */
|
|
/* 16 byte write to MS memory */
|
|
ret = qlcnic_83xx_ms_mem_write128(adapter, dest, (u32 *)p_cache,
|
|
ret = qlcnic_83xx_ms_mem_write128(adapter, dest, (u32 *)p_cache,
|
|
size / 16);
|
|
size / 16);
|
|
if (ret) {
|
|
if (ret) {
|
|
- kfree(p_cache);
|
|
|
|
|
|
+ vfree(p_cache);
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
- kfree(p_cache);
|
|
|
|
|
|
+ vfree(p_cache);
|
|
|
|
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
@@ -1939,7 +1946,7 @@ static void qlcnic_83xx_exec_template_cmd(struct qlcnic_adapter *p_dev,
|
|
p_dev->ahw->reset.seq_index = index;
|
|
p_dev->ahw->reset.seq_index = index;
|
|
}
|
|
}
|
|
|
|
|
|
-static void qlcnic_83xx_stop_hw(struct qlcnic_adapter *p_dev)
|
|
|
|
|
|
+void qlcnic_83xx_stop_hw(struct qlcnic_adapter *p_dev)
|
|
{
|
|
{
|
|
p_dev->ahw->reset.seq_index = 0;
|
|
p_dev->ahw->reset.seq_index = 0;
|
|
|
|
|
|
@@ -1994,6 +2001,14 @@ static int qlcnic_83xx_restart_hw(struct qlcnic_adapter *adapter)
|
|
val = QLCRDX(adapter->ahw, QLC_83XX_IDC_CTRL);
|
|
val = QLCRDX(adapter->ahw, QLC_83XX_IDC_CTRL);
|
|
if (!(val & QLC_83XX_IDC_GRACEFULL_RESET))
|
|
if (!(val & QLC_83XX_IDC_GRACEFULL_RESET))
|
|
qlcnic_dump_fw(adapter);
|
|
qlcnic_dump_fw(adapter);
|
|
|
|
+
|
|
|
|
+ if (val & QLC_83XX_IDC_DISABLE_FW_RESET_RECOVERY) {
|
|
|
|
+ netdev_info(adapter->netdev, "%s: Auto firmware recovery is disabled\n",
|
|
|
|
+ __func__);
|
|
|
|
+ qlcnic_83xx_idc_enter_failed_state(adapter, 1);
|
|
|
|
+ return err;
|
|
|
|
+ }
|
|
|
|
+
|
|
qlcnic_83xx_init_hw(adapter);
|
|
qlcnic_83xx_init_hw(adapter);
|
|
|
|
|
|
if (qlcnic_83xx_copy_bootloader(adapter))
|
|
if (qlcnic_83xx_copy_bootloader(adapter))
|
|
@@ -2073,8 +2088,8 @@ int qlcnic_83xx_configure_opmode(struct qlcnic_adapter *adapter)
|
|
ahw->nic_mode = QLCNIC_DEFAULT_MODE;
|
|
ahw->nic_mode = QLCNIC_DEFAULT_MODE;
|
|
adapter->nic_ops->init_driver = qlcnic_83xx_init_default_driver;
|
|
adapter->nic_ops->init_driver = qlcnic_83xx_init_default_driver;
|
|
ahw->idc.state_entry = qlcnic_83xx_idc_ready_state_entry;
|
|
ahw->idc.state_entry = qlcnic_83xx_idc_ready_state_entry;
|
|
- adapter->max_sds_rings = ahw->max_rx_ques;
|
|
|
|
- adapter->max_tx_rings = ahw->max_tx_ques;
|
|
|
|
|
|
+ adapter->max_sds_rings = QLCNIC_MAX_SDS_RINGS;
|
|
|
|
+ adapter->max_tx_rings = QLCNIC_MAX_TX_RINGS;
|
|
} else {
|
|
} else {
|
|
return -EIO;
|
|
return -EIO;
|
|
}
|
|
}
|