diff options
Diffstat (limited to 'drivers/scsi/pm8001/pm8001_hwi.c')
-rw-r--r-- | drivers/scsi/pm8001/pm8001_hwi.c | 73 |
1 files changed, 37 insertions, 36 deletions
diff --git a/drivers/scsi/pm8001/pm8001_hwi.c b/drivers/scsi/pm8001/pm8001_hwi.c index 8b7db1e53c10..b7b92f7be2aa 100644 --- a/drivers/scsi/pm8001/pm8001_hwi.c +++ b/drivers/scsi/pm8001/pm8001_hwi.c | |||
@@ -567,11 +567,11 @@ static void init_pci_device_addresses(struct pm8001_hba_info *pm8001_ha) | |||
567 | value = pm8001_cr32(pm8001_ha, 0, 0x44); | 567 | value = pm8001_cr32(pm8001_ha, 0, 0x44); |
568 | offset = value & 0x03FFFFFF; | 568 | offset = value & 0x03FFFFFF; |
569 | PM8001_INIT_DBG(pm8001_ha, | 569 | PM8001_INIT_DBG(pm8001_ha, |
570 | pm8001_printk("Scratchpad 0 Offset: %x \n", offset)); | 570 | pm8001_printk("Scratchpad 0 Offset: %x\n", offset)); |
571 | pcilogic = (value & 0xFC000000) >> 26; | 571 | pcilogic = (value & 0xFC000000) >> 26; |
572 | pcibar = get_pci_bar_index(pcilogic); | 572 | pcibar = get_pci_bar_index(pcilogic); |
573 | PM8001_INIT_DBG(pm8001_ha, | 573 | PM8001_INIT_DBG(pm8001_ha, |
574 | pm8001_printk("Scratchpad 0 PCI BAR: %d \n", pcibar)); | 574 | pm8001_printk("Scratchpad 0 PCI BAR: %d\n", pcibar)); |
575 | pm8001_ha->main_cfg_tbl_addr = base_addr = | 575 | pm8001_ha->main_cfg_tbl_addr = base_addr = |
576 | pm8001_ha->io_mem[pcibar].memvirtaddr + offset; | 576 | pm8001_ha->io_mem[pcibar].memvirtaddr + offset; |
577 | pm8001_ha->general_stat_tbl_addr = | 577 | pm8001_ha->general_stat_tbl_addr = |
@@ -1245,7 +1245,7 @@ static int mpi_build_cmd(struct pm8001_hba_info *pm8001_ha, | |||
1245 | 1245 | ||
1246 | if (mpi_msg_free_get(circularQ, 64, &pMessage) < 0) { | 1246 | if (mpi_msg_free_get(circularQ, 64, &pMessage) < 0) { |
1247 | PM8001_IO_DBG(pm8001_ha, | 1247 | PM8001_IO_DBG(pm8001_ha, |
1248 | pm8001_printk("No free mpi buffer \n")); | 1248 | pm8001_printk("No free mpi buffer\n")); |
1249 | return -1; | 1249 | return -1; |
1250 | } | 1250 | } |
1251 | BUG_ON(!payload); | 1251 | BUG_ON(!payload); |
@@ -1262,7 +1262,7 @@ static int mpi_build_cmd(struct pm8001_hba_info *pm8001_ha, | |||
1262 | pm8001_cw32(pm8001_ha, circularQ->pi_pci_bar, | 1262 | pm8001_cw32(pm8001_ha, circularQ->pi_pci_bar, |
1263 | circularQ->pi_offset, circularQ->producer_idx); | 1263 | circularQ->pi_offset, circularQ->producer_idx); |
1264 | PM8001_IO_DBG(pm8001_ha, | 1264 | PM8001_IO_DBG(pm8001_ha, |
1265 | pm8001_printk("after PI= %d CI= %d \n", circularQ->producer_idx, | 1265 | pm8001_printk("after PI= %d CI= %d\n", circularQ->producer_idx, |
1266 | circularQ->consumer_index)); | 1266 | circularQ->consumer_index)); |
1267 | return 0; | 1267 | return 0; |
1268 | } | 1268 | } |
@@ -1474,7 +1474,7 @@ mpi_ssp_completion(struct pm8001_hba_info *pm8001_ha , void *piomb) | |||
1474 | switch (status) { | 1474 | switch (status) { |
1475 | case IO_SUCCESS: | 1475 | case IO_SUCCESS: |
1476 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("IO_SUCCESS" | 1476 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("IO_SUCCESS" |
1477 | ",param = %d \n", param)); | 1477 | ",param = %d\n", param)); |
1478 | if (param == 0) { | 1478 | if (param == 0) { |
1479 | ts->resp = SAS_TASK_COMPLETE; | 1479 | ts->resp = SAS_TASK_COMPLETE; |
1480 | ts->stat = SAM_STAT_GOOD; | 1480 | ts->stat = SAM_STAT_GOOD; |
@@ -1490,14 +1490,14 @@ mpi_ssp_completion(struct pm8001_hba_info *pm8001_ha , void *piomb) | |||
1490 | break; | 1490 | break; |
1491 | case IO_ABORTED: | 1491 | case IO_ABORTED: |
1492 | PM8001_IO_DBG(pm8001_ha, | 1492 | PM8001_IO_DBG(pm8001_ha, |
1493 | pm8001_printk("IO_ABORTED IOMB Tag \n")); | 1493 | pm8001_printk("IO_ABORTED IOMB Tag\n")); |
1494 | ts->resp = SAS_TASK_COMPLETE; | 1494 | ts->resp = SAS_TASK_COMPLETE; |
1495 | ts->stat = SAS_ABORTED_TASK; | 1495 | ts->stat = SAS_ABORTED_TASK; |
1496 | break; | 1496 | break; |
1497 | case IO_UNDERFLOW: | 1497 | case IO_UNDERFLOW: |
1498 | /* SSP Completion with error */ | 1498 | /* SSP Completion with error */ |
1499 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("IO_UNDERFLOW" | 1499 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("IO_UNDERFLOW" |
1500 | ",param = %d \n", param)); | 1500 | ",param = %d\n", param)); |
1501 | ts->resp = SAS_TASK_COMPLETE; | 1501 | ts->resp = SAS_TASK_COMPLETE; |
1502 | ts->stat = SAS_DATA_UNDERRUN; | 1502 | ts->stat = SAS_DATA_UNDERRUN; |
1503 | ts->residual = param; | 1503 | ts->residual = param; |
@@ -1649,6 +1649,7 @@ mpi_ssp_completion(struct pm8001_hba_info *pm8001_ha , void *piomb) | |||
1649 | ts->resp = SAS_TASK_COMPLETE; | 1649 | ts->resp = SAS_TASK_COMPLETE; |
1650 | ts->stat = SAS_OPEN_REJECT; | 1650 | ts->stat = SAS_OPEN_REJECT; |
1651 | ts->open_rej_reason = SAS_OREJ_RSVD_RETRY; | 1651 | ts->open_rej_reason = SAS_OREJ_RSVD_RETRY; |
1652 | break; | ||
1652 | default: | 1653 | default: |
1653 | PM8001_IO_DBG(pm8001_ha, | 1654 | PM8001_IO_DBG(pm8001_ha, |
1654 | pm8001_printk("Unknown status 0x%x\n", status)); | 1655 | pm8001_printk("Unknown status 0x%x\n", status)); |
@@ -1937,14 +1938,14 @@ mpi_sata_completion(struct pm8001_hba_info *pm8001_ha, void *piomb) | |||
1937 | ts->buf_valid_size = sizeof(*resp); | 1938 | ts->buf_valid_size = sizeof(*resp); |
1938 | } else | 1939 | } else |
1939 | PM8001_IO_DBG(pm8001_ha, | 1940 | PM8001_IO_DBG(pm8001_ha, |
1940 | pm8001_printk("response to large \n")); | 1941 | pm8001_printk("response to large\n")); |
1941 | } | 1942 | } |
1942 | if (pm8001_dev) | 1943 | if (pm8001_dev) |
1943 | pm8001_dev->running_req--; | 1944 | pm8001_dev->running_req--; |
1944 | break; | 1945 | break; |
1945 | case IO_ABORTED: | 1946 | case IO_ABORTED: |
1946 | PM8001_IO_DBG(pm8001_ha, | 1947 | PM8001_IO_DBG(pm8001_ha, |
1947 | pm8001_printk("IO_ABORTED IOMB Tag \n")); | 1948 | pm8001_printk("IO_ABORTED IOMB Tag\n")); |
1948 | ts->resp = SAS_TASK_COMPLETE; | 1949 | ts->resp = SAS_TASK_COMPLETE; |
1949 | ts->stat = SAS_ABORTED_TASK; | 1950 | ts->stat = SAS_ABORTED_TASK; |
1950 | if (pm8001_dev) | 1951 | if (pm8001_dev) |
@@ -2728,11 +2729,11 @@ static int mpi_local_phy_ctl(struct pm8001_hba_info *pm8001_ha, void *piomb) | |||
2728 | u32 phy_op = le32_to_cpu(pPayload->phyop_phyid) & OP_BITS; | 2729 | u32 phy_op = le32_to_cpu(pPayload->phyop_phyid) & OP_BITS; |
2729 | if (status != 0) { | 2730 | if (status != 0) { |
2730 | PM8001_MSG_DBG(pm8001_ha, | 2731 | PM8001_MSG_DBG(pm8001_ha, |
2731 | pm8001_printk("%x phy execute %x phy op failed! \n", | 2732 | pm8001_printk("%x phy execute %x phy op failed!\n", |
2732 | phy_id, phy_op)); | 2733 | phy_id, phy_op)); |
2733 | } else | 2734 | } else |
2734 | PM8001_MSG_DBG(pm8001_ha, | 2735 | PM8001_MSG_DBG(pm8001_ha, |
2735 | pm8001_printk("%x phy execute %x phy op success! \n", | 2736 | pm8001_printk("%x phy execute %x phy op success!\n", |
2736 | phy_id, phy_op)); | 2737 | phy_id, phy_op)); |
2737 | return 0; | 2738 | return 0; |
2738 | } | 2739 | } |
@@ -3018,7 +3019,7 @@ hw_event_phy_down(struct pm8001_hba_info *pm8001_ha, void *piomb) | |||
3018 | break; | 3019 | break; |
3019 | case PORT_INVALID: | 3020 | case PORT_INVALID: |
3020 | PM8001_MSG_DBG(pm8001_ha, | 3021 | PM8001_MSG_DBG(pm8001_ha, |
3021 | pm8001_printk(" PortInvalid portID %d \n", port_id)); | 3022 | pm8001_printk(" PortInvalid portID %d\n", port_id)); |
3022 | PM8001_MSG_DBG(pm8001_ha, | 3023 | PM8001_MSG_DBG(pm8001_ha, |
3023 | pm8001_printk(" Last phy Down and port invalid\n")); | 3024 | pm8001_printk(" Last phy Down and port invalid\n")); |
3024 | port->port_attached = 0; | 3025 | port->port_attached = 0; |
@@ -3027,7 +3028,7 @@ hw_event_phy_down(struct pm8001_hba_info *pm8001_ha, void *piomb) | |||
3027 | break; | 3028 | break; |
3028 | case PORT_IN_RESET: | 3029 | case PORT_IN_RESET: |
3029 | PM8001_MSG_DBG(pm8001_ha, | 3030 | PM8001_MSG_DBG(pm8001_ha, |
3030 | pm8001_printk(" Port In Reset portID %d \n", port_id)); | 3031 | pm8001_printk(" Port In Reset portID %d\n", port_id)); |
3031 | break; | 3032 | break; |
3032 | case PORT_NOT_ESTABLISHED: | 3033 | case PORT_NOT_ESTABLISHED: |
3033 | PM8001_MSG_DBG(pm8001_ha, | 3034 | PM8001_MSG_DBG(pm8001_ha, |
@@ -3220,7 +3221,7 @@ mpi_general_event(struct pm8001_hba_info *pm8001_ha , void *piomb) | |||
3220 | pm8001_printk(" status = 0x%x\n", status)); | 3221 | pm8001_printk(" status = 0x%x\n", status)); |
3221 | for (i = 0; i < GENERAL_EVENT_PAYLOAD; i++) | 3222 | for (i = 0; i < GENERAL_EVENT_PAYLOAD; i++) |
3222 | PM8001_MSG_DBG(pm8001_ha, | 3223 | PM8001_MSG_DBG(pm8001_ha, |
3223 | pm8001_printk("inb_IOMB_payload[0x%x] 0x%x, \n", i, | 3224 | pm8001_printk("inb_IOMB_payload[0x%x] 0x%x,\n", i, |
3224 | pPayload->inb_IOMB_payload[i])); | 3225 | pPayload->inb_IOMB_payload[i])); |
3225 | return 0; | 3226 | return 0; |
3226 | } | 3227 | } |
@@ -3312,12 +3313,12 @@ static int mpi_hw_event(struct pm8001_hba_info *pm8001_ha, void* piomb) | |||
3312 | break; | 3313 | break; |
3313 | case HW_EVENT_SAS_PHY_UP: | 3314 | case HW_EVENT_SAS_PHY_UP: |
3314 | PM8001_MSG_DBG(pm8001_ha, | 3315 | PM8001_MSG_DBG(pm8001_ha, |
3315 | pm8001_printk("HW_EVENT_PHY_START_STATUS \n")); | 3316 | pm8001_printk("HW_EVENT_PHY_START_STATUS\n")); |
3316 | hw_event_sas_phy_up(pm8001_ha, piomb); | 3317 | hw_event_sas_phy_up(pm8001_ha, piomb); |
3317 | break; | 3318 | break; |
3318 | case HW_EVENT_SATA_PHY_UP: | 3319 | case HW_EVENT_SATA_PHY_UP: |
3319 | PM8001_MSG_DBG(pm8001_ha, | 3320 | PM8001_MSG_DBG(pm8001_ha, |
3320 | pm8001_printk("HW_EVENT_SATA_PHY_UP \n")); | 3321 | pm8001_printk("HW_EVENT_SATA_PHY_UP\n")); |
3321 | hw_event_sata_phy_up(pm8001_ha, piomb); | 3322 | hw_event_sata_phy_up(pm8001_ha, piomb); |
3322 | break; | 3323 | break; |
3323 | case HW_EVENT_PHY_STOP_STATUS: | 3324 | case HW_EVENT_PHY_STOP_STATUS: |
@@ -3329,12 +3330,12 @@ static int mpi_hw_event(struct pm8001_hba_info *pm8001_ha, void* piomb) | |||
3329 | break; | 3330 | break; |
3330 | case HW_EVENT_SATA_SPINUP_HOLD: | 3331 | case HW_EVENT_SATA_SPINUP_HOLD: |
3331 | PM8001_MSG_DBG(pm8001_ha, | 3332 | PM8001_MSG_DBG(pm8001_ha, |
3332 | pm8001_printk("HW_EVENT_SATA_SPINUP_HOLD \n")); | 3333 | pm8001_printk("HW_EVENT_SATA_SPINUP_HOLD\n")); |
3333 | sas_ha->notify_phy_event(&phy->sas_phy, PHYE_SPINUP_HOLD); | 3334 | sas_ha->notify_phy_event(&phy->sas_phy, PHYE_SPINUP_HOLD); |
3334 | break; | 3335 | break; |
3335 | case HW_EVENT_PHY_DOWN: | 3336 | case HW_EVENT_PHY_DOWN: |
3336 | PM8001_MSG_DBG(pm8001_ha, | 3337 | PM8001_MSG_DBG(pm8001_ha, |
3337 | pm8001_printk("HW_EVENT_PHY_DOWN \n")); | 3338 | pm8001_printk("HW_EVENT_PHY_DOWN\n")); |
3338 | sas_ha->notify_phy_event(&phy->sas_phy, PHYE_LOSS_OF_SIGNAL); | 3339 | sas_ha->notify_phy_event(&phy->sas_phy, PHYE_LOSS_OF_SIGNAL); |
3339 | phy->phy_attached = 0; | 3340 | phy->phy_attached = 0; |
3340 | phy->phy_state = 0; | 3341 | phy->phy_state = 0; |
@@ -3446,7 +3447,7 @@ static int mpi_hw_event(struct pm8001_hba_info *pm8001_ha, void* piomb) | |||
3446 | break; | 3447 | break; |
3447 | case HW_EVENT_LINK_ERR_PHY_RESET_FAILED: | 3448 | case HW_EVENT_LINK_ERR_PHY_RESET_FAILED: |
3448 | PM8001_MSG_DBG(pm8001_ha, | 3449 | PM8001_MSG_DBG(pm8001_ha, |
3449 | pm8001_printk("HW_EVENT_LINK_ERR_PHY_RESET_FAILED \n")); | 3450 | pm8001_printk("HW_EVENT_LINK_ERR_PHY_RESET_FAILED\n")); |
3450 | pm8001_hw_event_ack_req(pm8001_ha, 0, | 3451 | pm8001_hw_event_ack_req(pm8001_ha, 0, |
3451 | HW_EVENT_LINK_ERR_PHY_RESET_FAILED, | 3452 | HW_EVENT_LINK_ERR_PHY_RESET_FAILED, |
3452 | port_id, phy_id, 0, 0); | 3453 | port_id, phy_id, 0, 0); |
@@ -3456,25 +3457,25 @@ static int mpi_hw_event(struct pm8001_hba_info *pm8001_ha, void* piomb) | |||
3456 | break; | 3457 | break; |
3457 | case HW_EVENT_PORT_RESET_TIMER_TMO: | 3458 | case HW_EVENT_PORT_RESET_TIMER_TMO: |
3458 | PM8001_MSG_DBG(pm8001_ha, | 3459 | PM8001_MSG_DBG(pm8001_ha, |
3459 | pm8001_printk("HW_EVENT_PORT_RESET_TIMER_TMO \n")); | 3460 | pm8001_printk("HW_EVENT_PORT_RESET_TIMER_TMO\n")); |
3460 | sas_phy_disconnected(sas_phy); | 3461 | sas_phy_disconnected(sas_phy); |
3461 | phy->phy_attached = 0; | 3462 | phy->phy_attached = 0; |
3462 | sas_ha->notify_port_event(sas_phy, PORTE_LINK_RESET_ERR); | 3463 | sas_ha->notify_port_event(sas_phy, PORTE_LINK_RESET_ERR); |
3463 | break; | 3464 | break; |
3464 | case HW_EVENT_PORT_RECOVERY_TIMER_TMO: | 3465 | case HW_EVENT_PORT_RECOVERY_TIMER_TMO: |
3465 | PM8001_MSG_DBG(pm8001_ha, | 3466 | PM8001_MSG_DBG(pm8001_ha, |
3466 | pm8001_printk("HW_EVENT_PORT_RECOVERY_TIMER_TMO \n")); | 3467 | pm8001_printk("HW_EVENT_PORT_RECOVERY_TIMER_TMO\n")); |
3467 | sas_phy_disconnected(sas_phy); | 3468 | sas_phy_disconnected(sas_phy); |
3468 | phy->phy_attached = 0; | 3469 | phy->phy_attached = 0; |
3469 | sas_ha->notify_port_event(sas_phy, PORTE_LINK_RESET_ERR); | 3470 | sas_ha->notify_port_event(sas_phy, PORTE_LINK_RESET_ERR); |
3470 | break; | 3471 | break; |
3471 | case HW_EVENT_PORT_RECOVER: | 3472 | case HW_EVENT_PORT_RECOVER: |
3472 | PM8001_MSG_DBG(pm8001_ha, | 3473 | PM8001_MSG_DBG(pm8001_ha, |
3473 | pm8001_printk("HW_EVENT_PORT_RECOVER \n")); | 3474 | pm8001_printk("HW_EVENT_PORT_RECOVER\n")); |
3474 | break; | 3475 | break; |
3475 | case HW_EVENT_PORT_RESET_COMPLETE: | 3476 | case HW_EVENT_PORT_RESET_COMPLETE: |
3476 | PM8001_MSG_DBG(pm8001_ha, | 3477 | PM8001_MSG_DBG(pm8001_ha, |
3477 | pm8001_printk("HW_EVENT_PORT_RESET_COMPLETE \n")); | 3478 | pm8001_printk("HW_EVENT_PORT_RESET_COMPLETE\n")); |
3478 | break; | 3479 | break; |
3479 | case EVENT_BROADCAST_ASYNCH_EVENT: | 3480 | case EVENT_BROADCAST_ASYNCH_EVENT: |
3480 | PM8001_MSG_DBG(pm8001_ha, | 3481 | PM8001_MSG_DBG(pm8001_ha, |
@@ -3502,21 +3503,21 @@ static void process_one_iomb(struct pm8001_hba_info *pm8001_ha, void *piomb) | |||
3502 | 3503 | ||
3503 | switch (opc) { | 3504 | switch (opc) { |
3504 | case OPC_OUB_ECHO: | 3505 | case OPC_OUB_ECHO: |
3505 | PM8001_MSG_DBG(pm8001_ha, pm8001_printk("OPC_OUB_ECHO \n")); | 3506 | PM8001_MSG_DBG(pm8001_ha, pm8001_printk("OPC_OUB_ECHO\n")); |
3506 | break; | 3507 | break; |
3507 | case OPC_OUB_HW_EVENT: | 3508 | case OPC_OUB_HW_EVENT: |
3508 | PM8001_MSG_DBG(pm8001_ha, | 3509 | PM8001_MSG_DBG(pm8001_ha, |
3509 | pm8001_printk("OPC_OUB_HW_EVENT \n")); | 3510 | pm8001_printk("OPC_OUB_HW_EVENT\n")); |
3510 | mpi_hw_event(pm8001_ha, piomb); | 3511 | mpi_hw_event(pm8001_ha, piomb); |
3511 | break; | 3512 | break; |
3512 | case OPC_OUB_SSP_COMP: | 3513 | case OPC_OUB_SSP_COMP: |
3513 | PM8001_MSG_DBG(pm8001_ha, | 3514 | PM8001_MSG_DBG(pm8001_ha, |
3514 | pm8001_printk("OPC_OUB_SSP_COMP \n")); | 3515 | pm8001_printk("OPC_OUB_SSP_COMP\n")); |
3515 | mpi_ssp_completion(pm8001_ha, piomb); | 3516 | mpi_ssp_completion(pm8001_ha, piomb); |
3516 | break; | 3517 | break; |
3517 | case OPC_OUB_SMP_COMP: | 3518 | case OPC_OUB_SMP_COMP: |
3518 | PM8001_MSG_DBG(pm8001_ha, | 3519 | PM8001_MSG_DBG(pm8001_ha, |
3519 | pm8001_printk("OPC_OUB_SMP_COMP \n")); | 3520 | pm8001_printk("OPC_OUB_SMP_COMP\n")); |
3520 | mpi_smp_completion(pm8001_ha, piomb); | 3521 | mpi_smp_completion(pm8001_ha, piomb); |
3521 | break; | 3522 | break; |
3522 | case OPC_OUB_LOCAL_PHY_CNTRL: | 3523 | case OPC_OUB_LOCAL_PHY_CNTRL: |
@@ -3526,26 +3527,26 @@ static void process_one_iomb(struct pm8001_hba_info *pm8001_ha, void *piomb) | |||
3526 | break; | 3527 | break; |
3527 | case OPC_OUB_DEV_REGIST: | 3528 | case OPC_OUB_DEV_REGIST: |
3528 | PM8001_MSG_DBG(pm8001_ha, | 3529 | PM8001_MSG_DBG(pm8001_ha, |
3529 | pm8001_printk("OPC_OUB_DEV_REGIST \n")); | 3530 | pm8001_printk("OPC_OUB_DEV_REGIST\n")); |
3530 | mpi_reg_resp(pm8001_ha, piomb); | 3531 | mpi_reg_resp(pm8001_ha, piomb); |
3531 | break; | 3532 | break; |
3532 | case OPC_OUB_DEREG_DEV: | 3533 | case OPC_OUB_DEREG_DEV: |
3533 | PM8001_MSG_DBG(pm8001_ha, | 3534 | PM8001_MSG_DBG(pm8001_ha, |
3534 | pm8001_printk("unresgister the deviece \n")); | 3535 | pm8001_printk("unresgister the deviece\n")); |
3535 | mpi_dereg_resp(pm8001_ha, piomb); | 3536 | mpi_dereg_resp(pm8001_ha, piomb); |
3536 | break; | 3537 | break; |
3537 | case OPC_OUB_GET_DEV_HANDLE: | 3538 | case OPC_OUB_GET_DEV_HANDLE: |
3538 | PM8001_MSG_DBG(pm8001_ha, | 3539 | PM8001_MSG_DBG(pm8001_ha, |
3539 | pm8001_printk("OPC_OUB_GET_DEV_HANDLE \n")); | 3540 | pm8001_printk("OPC_OUB_GET_DEV_HANDLE\n")); |
3540 | break; | 3541 | break; |
3541 | case OPC_OUB_SATA_COMP: | 3542 | case OPC_OUB_SATA_COMP: |
3542 | PM8001_MSG_DBG(pm8001_ha, | 3543 | PM8001_MSG_DBG(pm8001_ha, |
3543 | pm8001_printk("OPC_OUB_SATA_COMP \n")); | 3544 | pm8001_printk("OPC_OUB_SATA_COMP\n")); |
3544 | mpi_sata_completion(pm8001_ha, piomb); | 3545 | mpi_sata_completion(pm8001_ha, piomb); |
3545 | break; | 3546 | break; |
3546 | case OPC_OUB_SATA_EVENT: | 3547 | case OPC_OUB_SATA_EVENT: |
3547 | PM8001_MSG_DBG(pm8001_ha, | 3548 | PM8001_MSG_DBG(pm8001_ha, |
3548 | pm8001_printk("OPC_OUB_SATA_EVENT \n")); | 3549 | pm8001_printk("OPC_OUB_SATA_EVENT\n")); |
3549 | mpi_sata_event(pm8001_ha, piomb); | 3550 | mpi_sata_event(pm8001_ha, piomb); |
3550 | break; | 3551 | break; |
3551 | case OPC_OUB_SSP_EVENT: | 3552 | case OPC_OUB_SSP_EVENT: |
@@ -3858,19 +3859,19 @@ static int pm8001_chip_sata_req(struct pm8001_hba_info *pm8001_ha, | |||
3858 | circularQ = &pm8001_ha->inbnd_q_tbl[0]; | 3859 | circularQ = &pm8001_ha->inbnd_q_tbl[0]; |
3859 | if (task->data_dir == PCI_DMA_NONE) { | 3860 | if (task->data_dir == PCI_DMA_NONE) { |
3860 | ATAP = 0x04; /* no data*/ | 3861 | ATAP = 0x04; /* no data*/ |
3861 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("no data \n")); | 3862 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("no data\n")); |
3862 | } else if (likely(!task->ata_task.device_control_reg_update)) { | 3863 | } else if (likely(!task->ata_task.device_control_reg_update)) { |
3863 | if (task->ata_task.dma_xfer) { | 3864 | if (task->ata_task.dma_xfer) { |
3864 | ATAP = 0x06; /* DMA */ | 3865 | ATAP = 0x06; /* DMA */ |
3865 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("DMA \n")); | 3866 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("DMA\n")); |
3866 | } else { | 3867 | } else { |
3867 | ATAP = 0x05; /* PIO*/ | 3868 | ATAP = 0x05; /* PIO*/ |
3868 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("PIO \n")); | 3869 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("PIO\n")); |
3869 | } | 3870 | } |
3870 | if (task->ata_task.use_ncq && | 3871 | if (task->ata_task.use_ncq && |
3871 | dev->sata_dev.command_set != ATAPI_COMMAND_SET) { | 3872 | dev->sata_dev.command_set != ATAPI_COMMAND_SET) { |
3872 | ATAP = 0x07; /* FPDMA */ | 3873 | ATAP = 0x07; /* FPDMA */ |
3873 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("FPDMA \n")); | 3874 | PM8001_IO_DBG(pm8001_ha, pm8001_printk("FPDMA\n")); |
3874 | } | 3875 | } |
3875 | } | 3876 | } |
3876 | if (task->ata_task.use_ncq && pm8001_get_ncq_tag(task, &hdr_tag)) | 3877 | if (task->ata_task.use_ncq && pm8001_get_ncq_tag(task, &hdr_tag)) |