Merge tag 'scsi-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi
Pull SCSI updates from James Bottomley: "This patch set consists of the usual driver updates (megaraid_sas, arcmsr, be2iscsi, lpfc, mpt2sas, mpt3sas, qla2xxx, ufs) plus several assorted fixes and miscellaneous updates (including the pci_msix_enable_range() changes that have been pending for a while)" * tag 'scsi-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (202 commits) scsi: add a CONFIG_SCSI_MQ_DEFAULT option ufs: definitions for phy interface ufs: tune bkops while power managment events ufs: Add support for clock scaling using devfreq framework ufs: Add freq-table-hz property for UFS device ufs: Add support for clock gating ufs: refactor configuring power mode ufs: add UFS power management support ufs: introduce well known logical unit in ufs ufs: manually add well known logical units ufs: Active Power Mode - configuring bActiveICCLevel ufs: improve init sequence ufs: refactor query descriptor API support ufs: add voting support for host controller power ufs: Add clock initialization support ufs: Add regulator enable support ufs: Allow vendor specific initialization scsi: don't add scsi_device if its already visible scsi: fix the type for well known LUs scsi: fix comment in struct Scsi_Host definition ...
此提交包含在:
@@ -645,16 +645,18 @@ static void scsi_mq_free_sgtables(struct scsi_cmnd *cmd)
|
||||
static void scsi_mq_uninit_cmd(struct scsi_cmnd *cmd)
|
||||
{
|
||||
struct scsi_device *sdev = cmd->device;
|
||||
struct Scsi_Host *shost = sdev->host;
|
||||
unsigned long flags;
|
||||
|
||||
BUG_ON(list_empty(&cmd->list));
|
||||
|
||||
scsi_mq_free_sgtables(cmd);
|
||||
scsi_uninit_cmd(cmd);
|
||||
|
||||
spin_lock_irqsave(&sdev->list_lock, flags);
|
||||
list_del_init(&cmd->list);
|
||||
spin_unlock_irqrestore(&sdev->list_lock, flags);
|
||||
if (shost->use_cmd_list) {
|
||||
BUG_ON(list_empty(&cmd->list));
|
||||
spin_lock_irqsave(&sdev->list_lock, flags);
|
||||
list_del_init(&cmd->list);
|
||||
spin_unlock_irqrestore(&sdev->list_lock, flags);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -1816,13 +1818,11 @@ static int scsi_mq_prep_fn(struct request *req)
|
||||
INIT_DELAYED_WORK(&cmd->abort_work, scmd_eh_abort_handler);
|
||||
cmd->jiffies_at_alloc = jiffies;
|
||||
|
||||
/*
|
||||
* XXX: cmd_list lookups are only used by two drivers, try to get
|
||||
* rid of this list in common code.
|
||||
*/
|
||||
spin_lock_irq(&sdev->list_lock);
|
||||
list_add_tail(&cmd->list, &sdev->cmd_list);
|
||||
spin_unlock_irq(&sdev->list_lock);
|
||||
if (shost->use_cmd_list) {
|
||||
spin_lock_irq(&sdev->list_lock);
|
||||
list_add_tail(&cmd->list, &sdev->cmd_list);
|
||||
spin_unlock_irq(&sdev->list_lock);
|
||||
}
|
||||
|
||||
sg = (void *)cmd + sizeof(struct scsi_cmnd) + shost->hostt->cmd_size;
|
||||
cmd->sdb.table.sgl = sg;
|
||||
|
新增問題並參考
封鎖使用者