diff options
author | Madhuranath Iyengar <Madhu.Iyengar@qlogic.com> | 2011-02-23 18:27:06 -0500 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2011-02-25 12:21:52 -0500 |
commit | f5e3e40b398d3593e26fcced987d4bd7b8f9e57a (patch) | |
tree | b77d8852cfe3e50ccbddff722afebe73cf646450 /drivers/scsi | |
parent | 038d9446a9e601d7972926ca69fee10eeda6f3c7 (diff) |
[SCSI] qla2xxx: Remove host_lock in queuecommand function
Also in qla_os.c, rename the function, remove DEF_SCSI_QCMD, etc.
Signed-off-by: Madhuranath Iyengar <Madhu.Iyengar@qlogic.com>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi')
-rw-r--r-- | drivers/scsi/qla2xxx/qla_os.c | 22 |
1 files changed, 6 insertions, 16 deletions
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c index c194c23ca1fb..a37ac8b73e55 100644 --- a/drivers/scsi/qla2xxx/qla_os.c +++ b/drivers/scsi/qla2xxx/qla_os.c | |||
@@ -506,7 +506,7 @@ qla24xx_fw_version_str(struct scsi_qla_host *vha, char *str) | |||
506 | 506 | ||
507 | static inline srb_t * | 507 | static inline srb_t * |
508 | qla2x00_get_new_sp(scsi_qla_host_t *vha, fc_port_t *fcport, | 508 | qla2x00_get_new_sp(scsi_qla_host_t *vha, fc_port_t *fcport, |
509 | struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *)) | 509 | struct scsi_cmnd *cmd) |
510 | { | 510 | { |
511 | srb_t *sp; | 511 | srb_t *sp; |
512 | struct qla_hw_data *ha = vha->hw; | 512 | struct qla_hw_data *ha = vha->hw; |
@@ -520,14 +520,13 @@ qla2x00_get_new_sp(scsi_qla_host_t *vha, fc_port_t *fcport, | |||
520 | sp->cmd = cmd; | 520 | sp->cmd = cmd; |
521 | sp->flags = 0; | 521 | sp->flags = 0; |
522 | CMD_SP(cmd) = (void *)sp; | 522 | CMD_SP(cmd) = (void *)sp; |
523 | cmd->scsi_done = done; | ||
524 | sp->ctx = NULL; | 523 | sp->ctx = NULL; |
525 | 524 | ||
526 | return sp; | 525 | return sp; |
527 | } | 526 | } |
528 | 527 | ||
529 | static int | 528 | static int |
530 | qla2xxx_queuecommand_lck(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *)) | 529 | qla2xxx_queuecommand(struct Scsi_Host *host, struct scsi_cmnd *cmd) |
531 | { | 530 | { |
532 | scsi_qla_host_t *vha = shost_priv(cmd->device->host); | 531 | scsi_qla_host_t *vha = shost_priv(cmd->device->host); |
533 | fc_port_t *fcport = (struct fc_port *) cmd->device->hostdata; | 532 | fc_port_t *fcport = (struct fc_port *) cmd->device->hostdata; |
@@ -537,7 +536,6 @@ qla2xxx_queuecommand_lck(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *) | |||
537 | srb_t *sp; | 536 | srb_t *sp; |
538 | int rval; | 537 | int rval; |
539 | 538 | ||
540 | spin_unlock_irq(vha->host->host_lock); | ||
541 | if (ha->flags.eeh_busy) { | 539 | if (ha->flags.eeh_busy) { |
542 | if (ha->flags.pci_channel_io_perm_failure) | 540 | if (ha->flags.pci_channel_io_perm_failure) |
543 | cmd->result = DID_NO_CONNECT << 16; | 541 | cmd->result = DID_NO_CONNECT << 16; |
@@ -570,40 +568,32 @@ qla2xxx_queuecommand_lck(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *) | |||
570 | goto qc24_target_busy; | 568 | goto qc24_target_busy; |
571 | } | 569 | } |
572 | 570 | ||
573 | sp = qla2x00_get_new_sp(base_vha, fcport, cmd, done); | 571 | sp = qla2x00_get_new_sp(base_vha, fcport, cmd); |
574 | if (!sp) | 572 | if (!sp) |
575 | goto qc24_host_busy_lock; | 573 | goto qc24_host_busy; |
576 | 574 | ||
577 | rval = ha->isp_ops->start_scsi(sp); | 575 | rval = ha->isp_ops->start_scsi(sp); |
578 | if (rval != QLA_SUCCESS) | 576 | if (rval != QLA_SUCCESS) |
579 | goto qc24_host_busy_free_sp; | 577 | goto qc24_host_busy_free_sp; |
580 | 578 | ||
581 | spin_lock_irq(vha->host->host_lock); | ||
582 | |||
583 | return 0; | 579 | return 0; |
584 | 580 | ||
585 | qc24_host_busy_free_sp: | 581 | qc24_host_busy_free_sp: |
586 | qla2x00_sp_free_dma(sp); | 582 | qla2x00_sp_free_dma(sp); |
587 | mempool_free(sp, ha->srb_mempool); | 583 | mempool_free(sp, ha->srb_mempool); |
588 | 584 | ||
589 | qc24_host_busy_lock: | 585 | qc24_host_busy: |
590 | spin_lock_irq(vha->host->host_lock); | ||
591 | return SCSI_MLQUEUE_HOST_BUSY; | 586 | return SCSI_MLQUEUE_HOST_BUSY; |
592 | 587 | ||
593 | qc24_target_busy: | 588 | qc24_target_busy: |
594 | spin_lock_irq(vha->host->host_lock); | ||
595 | return SCSI_MLQUEUE_TARGET_BUSY; | 589 | return SCSI_MLQUEUE_TARGET_BUSY; |
596 | 590 | ||
597 | qc24_fail_command: | 591 | qc24_fail_command: |
598 | spin_lock_irq(vha->host->host_lock); | 592 | cmd->scsi_done(cmd); |
599 | done(cmd); | ||
600 | 593 | ||
601 | return 0; | 594 | return 0; |
602 | } | 595 | } |
603 | 596 | ||
604 | static DEF_SCSI_QCMD(qla2xxx_queuecommand) | ||
605 | |||
606 | |||
607 | /* | 597 | /* |
608 | * qla2x00_eh_wait_on_command | 598 | * qla2x00_eh_wait_on_command |
609 | * Waits for the command to be returned by the Firmware for some | 599 | * Waits for the command to be returned by the Firmware for some |