diff options
author | shaohua.li@intel.com <shaohua.li@intel.com> | 2011-05-06 13:35:31 -0400 |
---|---|---|
committer | Jens Axboe <jaxboe@fusionio.com> | 2011-05-06 13:36:25 -0400 |
commit | 900e599eb0c16390ff671652a44e0ea90532220e (patch) | |
tree | bc2104ee827b8dad81bc9f32cd0b4e68a4ef117a /drivers/ata/libata-scsi.c | |
parent | 3ac0cc4508709d42ec9aa351086c7d38bfc0660c (diff) |
SATA: enable non-queueable flush flag
Enable non-queueable flush flag for SATA.
Stable: 2.6.39 only
Cc: stable@kernel.org
Signed-off-by: Shaohua Li <shaohua.li@intel.com>
Acked-by: Tejun Heo <tj@kernel.org>
Acked-by: Jeff Garzik <jgarzik@redhat.com>
Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
Diffstat (limited to 'drivers/ata/libata-scsi.c')
-rw-r--r-- | drivers/ata/libata-scsi.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c index e2f57e9e12f0..dad2c952e0d2 100644 --- a/drivers/ata/libata-scsi.c +++ b/drivers/ata/libata-scsi.c | |||
@@ -1089,21 +1089,21 @@ static int atapi_drain_needed(struct request *rq) | |||
1089 | static int ata_scsi_dev_config(struct scsi_device *sdev, | 1089 | static int ata_scsi_dev_config(struct scsi_device *sdev, |
1090 | struct ata_device *dev) | 1090 | struct ata_device *dev) |
1091 | { | 1091 | { |
1092 | struct request_queue *q = sdev->request_queue; | ||
1093 | |||
1092 | if (!ata_id_has_unload(dev->id)) | 1094 | if (!ata_id_has_unload(dev->id)) |
1093 | dev->flags |= ATA_DFLAG_NO_UNLOAD; | 1095 | dev->flags |= ATA_DFLAG_NO_UNLOAD; |
1094 | 1096 | ||
1095 | /* configure max sectors */ | 1097 | /* configure max sectors */ |
1096 | blk_queue_max_hw_sectors(sdev->request_queue, dev->max_sectors); | 1098 | blk_queue_max_hw_sectors(q, dev->max_sectors); |
1097 | 1099 | ||
1098 | if (dev->class == ATA_DEV_ATAPI) { | 1100 | if (dev->class == ATA_DEV_ATAPI) { |
1099 | struct request_queue *q = sdev->request_queue; | ||
1100 | void *buf; | 1101 | void *buf; |
1101 | 1102 | ||
1102 | sdev->sector_size = ATA_SECT_SIZE; | 1103 | sdev->sector_size = ATA_SECT_SIZE; |
1103 | 1104 | ||
1104 | /* set DMA padding */ | 1105 | /* set DMA padding */ |
1105 | blk_queue_update_dma_pad(sdev->request_queue, | 1106 | blk_queue_update_dma_pad(q, ATA_DMA_PAD_SZ - 1); |
1106 | ATA_DMA_PAD_SZ - 1); | ||
1107 | 1107 | ||
1108 | /* configure draining */ | 1108 | /* configure draining */ |
1109 | buf = kmalloc(ATAPI_MAX_DRAIN, q->bounce_gfp | GFP_KERNEL); | 1109 | buf = kmalloc(ATAPI_MAX_DRAIN, q->bounce_gfp | GFP_KERNEL); |
@@ -1131,8 +1131,7 @@ static int ata_scsi_dev_config(struct scsi_device *sdev, | |||
1131 | "sector_size=%u > PAGE_SIZE, PIO may malfunction\n", | 1131 | "sector_size=%u > PAGE_SIZE, PIO may malfunction\n", |
1132 | sdev->sector_size); | 1132 | sdev->sector_size); |
1133 | 1133 | ||
1134 | blk_queue_update_dma_alignment(sdev->request_queue, | 1134 | blk_queue_update_dma_alignment(q, sdev->sector_size - 1); |
1135 | sdev->sector_size - 1); | ||
1136 | 1135 | ||
1137 | if (dev->flags & ATA_DFLAG_AN) | 1136 | if (dev->flags & ATA_DFLAG_AN) |
1138 | set_bit(SDEV_EVT_MEDIA_CHANGE, sdev->supported_events); | 1137 | set_bit(SDEV_EVT_MEDIA_CHANGE, sdev->supported_events); |
@@ -1145,6 +1144,8 @@ static int ata_scsi_dev_config(struct scsi_device *sdev, | |||
1145 | scsi_adjust_queue_depth(sdev, MSG_SIMPLE_TAG, depth); | 1144 | scsi_adjust_queue_depth(sdev, MSG_SIMPLE_TAG, depth); |
1146 | } | 1145 | } |
1147 | 1146 | ||
1147 | blk_queue_flush_queueable(q, false); | ||
1148 | |||
1148 | dev->sdev = sdev; | 1149 | dev->sdev = sdev; |
1149 | return 0; | 1150 | return 0; |
1150 | } | 1151 | } |