diff options
Diffstat (limited to 'drivers/scsi/libata-core.c')
-rw-r--r-- | drivers/scsi/libata-core.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c index 8fda8228159c..a07ab77d32d6 100644 --- a/drivers/scsi/libata-core.c +++ b/drivers/scsi/libata-core.c | |||
@@ -5153,9 +5153,18 @@ static void ata_host_remove(struct ata_port *ap, unsigned int do_unregister) | |||
5153 | void ata_dev_init(struct ata_device *dev) | 5153 | void ata_dev_init(struct ata_device *dev) |
5154 | { | 5154 | { |
5155 | struct ata_port *ap = dev->ap; | 5155 | struct ata_port *ap = dev->ap; |
5156 | unsigned long flags; | ||
5157 | |||
5158 | /* High bits of dev->flags are used to record warm plug | ||
5159 | * requests which occur asynchronously. Synchronize using | ||
5160 | * host_set lock. | ||
5161 | */ | ||
5162 | spin_lock_irqsave(&ap->host_set->lock, flags); | ||
5163 | dev->flags &= ~ATA_DFLAG_INIT_MASK; | ||
5164 | spin_unlock_irqrestore(&ap->host_set->lock, flags); | ||
5156 | 5165 | ||
5157 | memset((void *)dev, 0, sizeof(*dev)); | 5166 | memset((void *)dev + ATA_DEVICE_CLEAR_OFFSET, 0, |
5158 | dev->devno = dev - ap->device; | 5167 | sizeof(*dev) - ATA_DEVICE_CLEAR_OFFSET); |
5159 | dev->pio_mask = UINT_MAX; | 5168 | dev->pio_mask = UINT_MAX; |
5160 | dev->mwdma_mask = UINT_MAX; | 5169 | dev->mwdma_mask = UINT_MAX; |
5161 | dev->udma_mask = UINT_MAX; | 5170 | dev->udma_mask = UINT_MAX; |
@@ -5218,6 +5227,7 @@ static void ata_host_init(struct ata_port *ap, struct Scsi_Host *host, | |||
5218 | for (i = 0; i < ATA_MAX_DEVICES; i++) { | 5227 | for (i = 0; i < ATA_MAX_DEVICES; i++) { |
5219 | struct ata_device *dev = &ap->device[i]; | 5228 | struct ata_device *dev = &ap->device[i]; |
5220 | dev->ap = ap; | 5229 | dev->ap = ap; |
5230 | dev->devno = i; | ||
5221 | ata_dev_init(dev); | 5231 | ata_dev_init(dev); |
5222 | } | 5232 | } |
5223 | 5233 | ||