Commit afdda878 authored by Ching Huang's avatar Ching Huang Committed by Martin K. Petersen

scsi: arcmsr: Fix suspend/resume of ACB_ADAPTER_TYPE_B

From Ching Huang <ching2048@areca.com.tw>

Fix suspend/resume of ACB_ADAPTER_TYPE_B
Signed-off-by: default avatarChing Huang <ching2048@areca.com.tw>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 1d120c61
...@@ -1110,12 +1110,21 @@ static int arcmsr_resume(struct pci_dev *pdev) ...@@ -1110,12 +1110,21 @@ static int arcmsr_resume(struct pci_dev *pdev)
pci_set_master(pdev); pci_set_master(pdev);
if (arcmsr_request_irq(pdev, acb) == FAILED) if (arcmsr_request_irq(pdev, acb) == FAILED)
goto controller_stop; goto controller_stop;
if (acb->adapter_type == ACB_ADAPTER_TYPE_E) { switch (acb->adapter_type) {
case ACB_ADAPTER_TYPE_B: {
struct MessageUnit_B *reg = acb->pmuB;
reg->post_qbuffer[0] = 0;
reg->postq_index = 0;
reg->doneq_index = 0;
break;
}
case ACB_ADAPTER_TYPE_E:
writel(0, &acb->pmuE->host_int_status); writel(0, &acb->pmuE->host_int_status);
writel(ARCMSR_HBEMU_DOORBELL_SYNC, &acb->pmuE->iobound_doorbell); writel(ARCMSR_HBEMU_DOORBELL_SYNC, &acb->pmuE->iobound_doorbell);
acb->in_doorbell = 0; acb->in_doorbell = 0;
acb->out_doorbell = 0; acb->out_doorbell = 0;
acb->doneq_index = 0; acb->doneq_index = 0;
break;
} }
arcmsr_iop_init(acb); arcmsr_iop_init(acb);
arcmsr_init_get_devmap_timer(acb); arcmsr_init_get_devmap_timer(acb);
......
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