Commit a7dee8f4 authored by James Bottomley's avatar James Bottomley

Merge branch 'fixes' into misc

parents 7ee7895c 5ecee0a3
...@@ -1191,6 +1191,8 @@ static void dm_unprep_request(struct request *rq) ...@@ -1191,6 +1191,8 @@ static void dm_unprep_request(struct request *rq)
if (clone) if (clone)
free_rq_clone(clone); free_rq_clone(clone);
else if (!tio->md->queue->mq_ops)
free_rq_tio(tio);
} }
/* /*
......
...@@ -2232,6 +2232,7 @@ static int omap_hsmmc_probe(struct platform_device *pdev) ...@@ -2232,6 +2232,7 @@ static int omap_hsmmc_probe(struct platform_device *pdev)
dma_release_channel(host->tx_chan); dma_release_channel(host->tx_chan);
if (host->rx_chan) if (host->rx_chan)
dma_release_channel(host->rx_chan); dma_release_channel(host->rx_chan);
pm_runtime_dont_use_autosuspend(host->dev);
pm_runtime_put_sync(host->dev); pm_runtime_put_sync(host->dev);
pm_runtime_disable(host->dev); pm_runtime_disable(host->dev);
if (host->dbclk) if (host->dbclk)
...@@ -2253,6 +2254,7 @@ static int omap_hsmmc_remove(struct platform_device *pdev) ...@@ -2253,6 +2254,7 @@ static int omap_hsmmc_remove(struct platform_device *pdev)
dma_release_channel(host->tx_chan); dma_release_channel(host->tx_chan);
dma_release_channel(host->rx_chan); dma_release_channel(host->rx_chan);
pm_runtime_dont_use_autosuspend(host->dev);
pm_runtime_put_sync(host->dev); pm_runtime_put_sync(host->dev);
pm_runtime_disable(host->dev); pm_runtime_disable(host->dev);
device_init_wakeup(&pdev->dev, false); device_init_wakeup(&pdev->dev, false);
......
...@@ -4493,6 +4493,7 @@ static int beiscsi_setup_boot_info(struct beiscsi_hba *phba) ...@@ -4493,6 +4493,7 @@ static int beiscsi_setup_boot_info(struct beiscsi_hba *phba)
scsi_host_put(phba->shost); scsi_host_put(phba->shost);
free_kset: free_kset:
iscsi_boot_destroy_kset(phba->boot_kset); iscsi_boot_destroy_kset(phba->boot_kset);
phba->boot_kset = NULL;
return -ENOMEM; return -ENOMEM;
} }
......
...@@ -4002,6 +4002,7 @@ static ssize_t ipr_store_update_fw(struct device *dev, ...@@ -4002,6 +4002,7 @@ static ssize_t ipr_store_update_fw(struct device *dev,
struct ipr_sglist *sglist; struct ipr_sglist *sglist;
char fname[100]; char fname[100];
char *src; char *src;
char *endline;
int result, dnld_size; int result, dnld_size;
if (!capable(CAP_SYS_ADMIN)) if (!capable(CAP_SYS_ADMIN))
...@@ -4009,6 +4010,10 @@ static ssize_t ipr_store_update_fw(struct device *dev, ...@@ -4009,6 +4010,10 @@ static ssize_t ipr_store_update_fw(struct device *dev,
snprintf(fname, sizeof(fname), "%s", buf); snprintf(fname, sizeof(fname), "%s", buf);
endline = strchr(fname, '\n');
if (endline)
*endline = '\0';
if (request_firmware(&fw_entry, fname, &ioa_cfg->pdev->dev)) { if (request_firmware(&fw_entry, fname, &ioa_cfg->pdev->dev)) {
dev_err(&ioa_cfg->pdev->dev, "Firmware file %s not found\n", fname); dev_err(&ioa_cfg->pdev->dev, "Firmware file %s not found\n", fname);
return -EIO; return -EIO;
......
...@@ -1344,6 +1344,7 @@ scsi_prep_return(struct request_queue *q, struct request *req, int ret) ...@@ -1344,6 +1344,7 @@ scsi_prep_return(struct request_queue *q, struct request *req, int ret)
switch (ret) { switch (ret) {
case BLKPREP_KILL: case BLKPREP_KILL:
case BLKPREP_INVALID:
req->errors = DID_NO_CONNECT << 16; req->errors = DID_NO_CONNECT << 16;
/* release the command and kill it */ /* release the command and kill it */
if (req->special) { if (req->special) {
......
...@@ -648,7 +648,7 @@ static void sd_config_discard(struct scsi_disk *sdkp, unsigned int mode) ...@@ -648,7 +648,7 @@ static void sd_config_discard(struct scsi_disk *sdkp, unsigned int mode)
*/ */
if (sdkp->lbprz) { if (sdkp->lbprz) {
q->limits.discard_alignment = 0; q->limits.discard_alignment = 0;
q->limits.discard_granularity = 1; q->limits.discard_granularity = logical_block_size;
} else { } else {
q->limits.discard_alignment = sdkp->unmap_alignment * q->limits.discard_alignment = sdkp->unmap_alignment *
logical_block_size; logical_block_size;
......
...@@ -652,7 +652,8 @@ sg_write(struct file *filp, const char __user *buf, size_t count, loff_t * ppos) ...@@ -652,7 +652,8 @@ sg_write(struct file *filp, const char __user *buf, size_t count, loff_t * ppos)
else else
hp->dxfer_direction = (mxsize > 0) ? SG_DXFER_FROM_DEV : SG_DXFER_NONE; hp->dxfer_direction = (mxsize > 0) ? SG_DXFER_FROM_DEV : SG_DXFER_NONE;
hp->dxfer_len = mxsize; hp->dxfer_len = mxsize;
if (hp->dxfer_direction == SG_DXFER_TO_DEV) if ((hp->dxfer_direction == SG_DXFER_TO_DEV) ||
(hp->dxfer_direction == SG_DXFER_TO_FROM_DEV))
hp->dxferp = (char __user *)buf + cmd_size; hp->dxferp = (char __user *)buf + cmd_size;
else else
hp->dxferp = NULL; hp->dxferp = NULL;
......
...@@ -914,8 +914,9 @@ static void storvsc_handle_error(struct vmscsi_request *vm_srb, ...@@ -914,8 +914,9 @@ static void storvsc_handle_error(struct vmscsi_request *vm_srb,
do_work = true; do_work = true;
process_err_fn = storvsc_remove_lun; process_err_fn = storvsc_remove_lun;
break; break;
case (SRB_STATUS_ABORTED | SRB_STATUS_AUTOSENSE_VALID): case SRB_STATUS_ABORTED:
if ((asc == 0x2a) && (ascq == 0x9)) { if (vm_srb->srb_status & SRB_STATUS_AUTOSENSE_VALID &&
(asc == 0x2a) && (ascq == 0x9)) {
do_work = true; do_work = true;
process_err_fn = storvsc_device_scan; process_err_fn = storvsc_device_scan;
/* /*
......
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