aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/netxen/netxen_nic_ctx.c16
1 files changed, 15 insertions, 1 deletions
diff --git a/drivers/net/netxen/netxen_nic_ctx.c b/drivers/net/netxen/netxen_nic_ctx.c
index 3a41b6a84a6..12612127a08 100644
--- a/drivers/net/netxen/netxen_nic_ctx.c
+++ b/drivers/net/netxen/netxen_nic_ctx.c
@@ -255,6 +255,19 @@ out_free_rq:
255} 255}
256 256
257static void 257static void
258nx_fw_cmd_reset_ctx(struct netxen_adapter *adapter)
259{
260
261 netxen_issue_cmd(adapter, adapter->ahw.pci_func, NXHAL_VERSION,
262 adapter->ahw.pci_func, NX_DESTROY_CTX_RESET, 0,
263 NX_CDRP_CMD_DESTROY_RX_CTX);
264
265 netxen_issue_cmd(adapter, adapter->ahw.pci_func, NXHAL_VERSION,
266 adapter->ahw.pci_func, NX_DESTROY_CTX_RESET, 0,
267 NX_CDRP_CMD_DESTROY_TX_CTX);
268}
269
270static void
258nx_fw_cmd_destroy_rx_ctx(struct netxen_adapter *adapter) 271nx_fw_cmd_destroy_rx_ctx(struct netxen_adapter *adapter)
259{ 272{
260 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; 273 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx;
@@ -685,7 +698,8 @@ int netxen_alloc_hw_resources(struct netxen_adapter *adapter)
685 if (!NX_IS_REVISION_P2(adapter->ahw.revision_id)) { 698 if (!NX_IS_REVISION_P2(adapter->ahw.revision_id)) {
686 if (test_and_set_bit(__NX_FW_ATTACHED, &adapter->state)) 699 if (test_and_set_bit(__NX_FW_ATTACHED, &adapter->state))
687 goto done; 700 goto done;
688 701 if (reset_devices)
702 nx_fw_cmd_reset_ctx(adapter);
689 err = nx_fw_cmd_create_rx_ctx(adapter); 703 err = nx_fw_cmd_create_rx_ctx(adapter);
690 if (err) 704 if (err)
691 goto err_out_free; 705 goto err_out_free;