diff options
author | Tejun Heo <htejun@gmail.com> | 2006-02-12 09:32:59 -0500 |
---|---|---|
committer | Jeff Garzik <jgarzik@pobox.com> | 2006-02-12 14:36:30 -0500 |
commit | b00eec1d58ee71131375bfeb86e64bceec3f5618 (patch) | |
tree | 03536ad3ecc61d42da0611f40a51fedcd44192b5 /drivers/scsi/sata_sil.c | |
parent | 6e7846e9c548443c86cfbad9e4defb4bdcfc538b (diff) |
[PATCH] libata: add per-device max_sectors
If a low level driver wants to control max_sectors, it had to adjust
ap->host->max_sectors and set ATA_DFLAG_LOCK_SECTORS to tell
ata_scsi_slave_config not to override the limit. This is not only
cumbersome but also incorrect for hosts which support more than one
devices per port.
This patch adds per-device ->max_sectors. If the field is unset
(zero), libata core layer will adjust ->max_sectors according to
default rules. If the field is set, libata honors the setting.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers/scsi/sata_sil.c')
-rw-r--r-- | drivers/scsi/sata_sil.c | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/drivers/scsi/sata_sil.c b/drivers/scsi/sata_sil.c index 61c4ac7ff9db..6c482c8be254 100644 --- a/drivers/scsi/sata_sil.c +++ b/drivers/scsi/sata_sil.c | |||
@@ -354,9 +354,7 @@ static void sil_dev_config(struct ata_port *ap, struct ata_device *dev) | |||
354 | (quirks & SIL_QUIRK_MOD15WRITE))) { | 354 | (quirks & SIL_QUIRK_MOD15WRITE))) { |
355 | printk(KERN_INFO "ata%u(%u): applying Seagate errata fix (mod15write workaround)\n", | 355 | printk(KERN_INFO "ata%u(%u): applying Seagate errata fix (mod15write workaround)\n", |
356 | ap->id, dev->devno); | 356 | ap->id, dev->devno); |
357 | ap->host->max_sectors = 15; | 357 | dev->max_sectors = 15; |
358 | ap->host->hostt->max_sectors = 15; | ||
359 | dev->flags |= ATA_DFLAG_LOCK_SECTORS; | ||
360 | return; | 358 | return; |
361 | } | 359 | } |
362 | 360 | ||