diff options
author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-12-29 14:27:34 -0500 |
---|---|---|
committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-12-29 14:27:34 -0500 |
commit | 6b4924962c49655494d2c8e9d3faab0e349a3062 (patch) | |
tree | 5236d3ef808f8c781b40b7a6328f65fe3f25891b | |
parent | 7f1ac8c4b9dadc55ec656b368f5f470f2cbe3083 (diff) |
ide: add ->max_sectors field to struct ide_port_info
* Add ->max_sectors field to struct ide_port_info to allow host drivers
to specify value used for hwif->rqsize (if smaller than the default).
* Convert pdc202xx_old to use ->max_sectors and remove no longer needed
IDE_HFLAG_RQSIZE_256 flag.
There should be no functional changes caused by this patch.
Acked-by: Sergei Shtyltov <sshtylyov@ru.mvista.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
-rw-r--r-- | drivers/ide/ide-probe.c | 4 | ||||
-rw-r--r-- | drivers/ide/pdc202xx_old.c | 9 | ||||
-rw-r--r-- | include/linux/ide.h | 5 |
3 files changed, 10 insertions, 8 deletions
diff --git a/drivers/ide/ide-probe.c b/drivers/ide/ide-probe.c index 81f61e8ea97f..f76c22c45086 100644 --- a/drivers/ide/ide-probe.c +++ b/drivers/ide/ide-probe.c | |||
@@ -1442,8 +1442,8 @@ static void ide_init_port(ide_hwif_t *hwif, unsigned int port, | |||
1442 | hwif->mate->serialized = hwif->serialized = 1; | 1442 | hwif->mate->serialized = hwif->serialized = 1; |
1443 | } | 1443 | } |
1444 | 1444 | ||
1445 | if (d->host_flags & IDE_HFLAG_RQSIZE_256) | 1445 | if (d->max_sectors) |
1446 | hwif->rqsize = 256; | 1446 | hwif->rqsize = d->max_sectors; |
1447 | 1447 | ||
1448 | /* call chipset specific routine for each enabled port */ | 1448 | /* call chipset specific routine for each enabled port */ |
1449 | if (d->init_hwif) | 1449 | if (d->init_hwif) |
diff --git a/drivers/ide/pdc202xx_old.c b/drivers/ide/pdc202xx_old.c index 799557c25eef..624e62e5cc9a 100644 --- a/drivers/ide/pdc202xx_old.c +++ b/drivers/ide/pdc202xx_old.c | |||
@@ -350,16 +350,17 @@ static const struct ide_dma_ops pdc2026x_dma_ops = { | |||
350 | .dma_timeout = pdc202xx_dma_timeout, | 350 | .dma_timeout = pdc202xx_dma_timeout, |
351 | }; | 351 | }; |
352 | 352 | ||
353 | #define DECLARE_PDC2026X_DEV(udma, extra_flags) \ | 353 | #define DECLARE_PDC2026X_DEV(udma, sectors) \ |
354 | { \ | 354 | { \ |
355 | .name = DRV_NAME, \ | 355 | .name = DRV_NAME, \ |
356 | .init_chipset = init_chipset_pdc202xx, \ | 356 | .init_chipset = init_chipset_pdc202xx, \ |
357 | .port_ops = &pdc2026x_port_ops, \ | 357 | .port_ops = &pdc2026x_port_ops, \ |
358 | .dma_ops = &pdc2026x_dma_ops, \ | 358 | .dma_ops = &pdc2026x_dma_ops, \ |
359 | .host_flags = IDE_HFLAGS_PDC202XX | extra_flags, \ | 359 | .host_flags = IDE_HFLAGS_PDC202XX, \ |
360 | .pio_mask = ATA_PIO4, \ | 360 | .pio_mask = ATA_PIO4, \ |
361 | .mwdma_mask = ATA_MWDMA2, \ | 361 | .mwdma_mask = ATA_MWDMA2, \ |
362 | .udma_mask = udma, \ | 362 | .udma_mask = udma, \ |
363 | .max_sectors = sectors, \ | ||
363 | } | 364 | } |
364 | 365 | ||
365 | static const struct ide_port_info pdc202xx_chipsets[] __devinitdata = { | 366 | static const struct ide_port_info pdc202xx_chipsets[] __devinitdata = { |
@@ -376,8 +377,8 @@ static const struct ide_port_info pdc202xx_chipsets[] __devinitdata = { | |||
376 | 377 | ||
377 | /* 1: PDC2026{2,3} */ | 378 | /* 1: PDC2026{2,3} */ |
378 | DECLARE_PDC2026X_DEV(ATA_UDMA4, 0), | 379 | DECLARE_PDC2026X_DEV(ATA_UDMA4, 0), |
379 | /* 2: PDC2026{5,7} */ | 380 | /* 2: PDC2026{5,7}: UDMA5, limit LBA48 requests to 256 sectors */ |
380 | DECLARE_PDC2026X_DEV(ATA_UDMA5, IDE_HFLAG_RQSIZE_256), | 381 | DECLARE_PDC2026X_DEV(ATA_UDMA5, 256), |
381 | }; | 382 | }; |
382 | 383 | ||
383 | /** | 384 | /** |
diff --git a/include/linux/ide.h b/include/linux/ide.h index fc1a966c7b7d..2574dda4a3e7 100644 --- a/include/linux/ide.h +++ b/include/linux/ide.h | |||
@@ -1372,8 +1372,6 @@ enum { | |||
1372 | IDE_HFLAG_LEGACY_IRQS = (1 << 21), | 1372 | IDE_HFLAG_LEGACY_IRQS = (1 << 21), |
1373 | /* force use of legacy IRQs */ | 1373 | /* force use of legacy IRQs */ |
1374 | IDE_HFLAG_FORCE_LEGACY_IRQS = (1 << 22), | 1374 | IDE_HFLAG_FORCE_LEGACY_IRQS = (1 << 22), |
1375 | /* limit LBA48 requests to 256 sectors */ | ||
1376 | IDE_HFLAG_RQSIZE_256 = (1 << 23), | ||
1377 | /* use 32-bit I/O ops */ | 1375 | /* use 32-bit I/O ops */ |
1378 | IDE_HFLAG_IO_32BIT = (1 << 24), | 1376 | IDE_HFLAG_IO_32BIT = (1 << 24), |
1379 | /* unmask IRQs */ | 1377 | /* unmask IRQs */ |
@@ -1411,6 +1409,9 @@ struct ide_port_info { | |||
1411 | 1409 | ||
1412 | ide_pci_enablebit_t enablebits[2]; | 1410 | ide_pci_enablebit_t enablebits[2]; |
1413 | hwif_chipset_t chipset; | 1411 | hwif_chipset_t chipset; |
1412 | |||
1413 | u16 max_sectors; /* if < than the default one */ | ||
1414 | |||
1414 | u32 host_flags; | 1415 | u32 host_flags; |
1415 | u8 pio_mask; | 1416 | u8 pio_mask; |
1416 | u8 swdma_mask; | 1417 | u8 swdma_mask; |