Merge master.kernel.org:/pub/scm/linux/kernel/git/bart/ide-2.6

* master.kernel.org:/pub/scm/linux/kernel/git/bart/ide-2.6:
  ide: make legacy IDE VLB modules check for the "probe" kernel params (v2)
  ide: remove some obsoleted kernel params (v2)
  ide/pci/delkin_cb.c: pci_module_init to pci_register_driver
  scc_pata: bugfix for checking DMA IRQ status
  ide: remove a ton of pointless #undef REALLY_SLOW_IO
  siimage: DRAC4 note
  adjust legacy IDE resource setting (v2)
  ide: fix pmac breakage
  ide-cs: Update device table
  ide: ide_get_best_pio_mode() returns incorrect IORDY setting (take 2)
  piix/slc90e66: more tuneproc() fixing (take 2)
  ide: fix drive side 80c cable check, take 2
  cmd64x: fix PIO mode setup (take 3)
  alim15x3: fix PIO mode setup
This commit is contained in:
Linus Torvalds 2007-03-04 13:31:00 -08:00
commit 20b0f65d35
29 changed files with 306 additions and 224 deletions

View File

@ -232,7 +232,9 @@ Summary of ide driver parameters for kernel command line
"hdx=remap63" : remap the drive: add 63 to all sector numbers "hdx=remap63" : remap the drive: add 63 to all sector numbers
(for DM OnTrack) (for DM OnTrack)
"idex=noautotune" : driver will NOT attempt to tune interface speed
"hdx=autotune" : driver will attempt to tune interface speed "hdx=autotune" : driver will attempt to tune interface speed
to the fastest PIO mode supported, to the fastest PIO mode supported,
if possible for this drive only. if possible for this drive only.
@ -267,17 +269,6 @@ Summary of ide driver parameters for kernel command line
"idex=base,ctl" : specify both base and ctl "idex=base,ctl" : specify both base and ctl
"idex=base,ctl,irq" : specify base, ctl, and irq number "idex=base,ctl,irq" : specify base, ctl, and irq number
"idex=autotune" : driver will attempt to tune interface speed
to the fastest PIO mode supported,
for all drives on this interface.
Not fully supported by all chipset types,
and quite likely to cause trouble with
older/odd IDE drives.
"idex=noautotune" : driver will NOT attempt to tune interface speed
This is the default for most chipsets,
except the cmd640.
"idex=serialize" : do not overlap operations on idex. Please note "idex=serialize" : do not overlap operations on idex. Please note
that you will have to specify this option for that you will have to specify this option for
@ -303,13 +294,8 @@ The following are valid ONLY on ide0, which usually corresponds
to the first ATA interface found on the particular host, and the defaults for to the first ATA interface found on the particular host, and the defaults for
the base,ctl ports must not be altered. the base,ctl ports must not be altered.
"ide0=dtc2278" : probe/support DTC2278 interface
"ide0=ht6560b" : probe/support HT6560B interface
"ide0=cmd640_vlb" : *REQUIRED* for VLB cards with the CMD640 chip "ide0=cmd640_vlb" : *REQUIRED* for VLB cards with the CMD640 chip
(not for PCI -- automatically detected) (not for PCI -- automatically detected)
"ide0=qd65xx" : probe/support qd65xx interface
"ide0=ali14xx" : probe/support ali14xx chipsets (ALI M1439/M1443/M1445)
"ide0=umc8672" : probe/support umc8672 chipsets
"ide=doubler" : probe/support IDE doublers on Amiga "ide=doubler" : probe/support IDE doublers on Amiga
@ -317,6 +303,15 @@ There may be more options than shown -- use the source, Luke!
Everything else is rejected with a "BAD OPTION" message. Everything else is rejected with a "BAD OPTION" message.
For legacy IDE VLB host drivers (ali14xx/dtc2278/ht6560b/qd65xx/umc8672)
you need to explicitly enable probing by using "probe" kernel parameter,
i.e. to enable probing for ALI M14xx chipsets (ali14xx host driver) use:
* "ali14xx.probe" boot option when ali14xx driver is built-in the kernel
* "probe" module parameter when ali14xx driver is compiled as module
("modprobe ali14xx probe")
================================================================================ ================================================================================
IDE ATAPI streaming tape driver IDE ATAPI streaming tape driver

View File

@ -1023,7 +1023,7 @@ config BLK_DEV_4DRIVES
config BLK_DEV_ALI14XX config BLK_DEV_ALI14XX
tristate "ALI M14xx support" tristate "ALI M14xx support"
help help
This driver is enabled at runtime using the "ide0=ali14xx" kernel This driver is enabled at runtime using the "ali14xx.probe" kernel
boot parameter. It enables support for the secondary IDE interface boot parameter. It enables support for the secondary IDE interface
of the ALI M1439/1443/1445/1487/1489 chipsets, and permits faster of the ALI M1439/1443/1445/1487/1489 chipsets, and permits faster
I/O speeds to be set as well. See the files I/O speeds to be set as well. See the files
@ -1033,7 +1033,7 @@ config BLK_DEV_ALI14XX
config BLK_DEV_DTC2278 config BLK_DEV_DTC2278
tristate "DTC-2278 support" tristate "DTC-2278 support"
help help
This driver is enabled at runtime using the "ide0=dtc2278" kernel This driver is enabled at runtime using the "dtc2278.probe" kernel
boot parameter. It enables support for the secondary IDE interface boot parameter. It enables support for the secondary IDE interface
of the DTC-2278 card, and permits faster I/O speeds to be set as of the DTC-2278 card, and permits faster I/O speeds to be set as
well. See the <file:Documentation/ide.txt> and well. See the <file:Documentation/ide.txt> and
@ -1042,7 +1042,7 @@ config BLK_DEV_DTC2278
config BLK_DEV_HT6560B config BLK_DEV_HT6560B
tristate "Holtek HT6560B support" tristate "Holtek HT6560B support"
help help
This driver is enabled at runtime using the "ide0=ht6560b" kernel This driver is enabled at runtime using the "ht6560b.probe" kernel
boot parameter. It enables support for the secondary IDE interface boot parameter. It enables support for the secondary IDE interface
of the Holtek card, and permits faster I/O speeds to be set as well. of the Holtek card, and permits faster I/O speeds to be set as well.
See the <file:Documentation/ide.txt> and See the <file:Documentation/ide.txt> and
@ -1051,7 +1051,7 @@ config BLK_DEV_HT6560B
config BLK_DEV_QD65XX config BLK_DEV_QD65XX
tristate "QDI QD65xx support" tristate "QDI QD65xx support"
help help
This driver is enabled at runtime using the "ide0=qd65xx" kernel This driver is enabled at runtime using the "qd65xx.probe" kernel
boot parameter. It permits faster I/O speeds to be set. See the boot parameter. It permits faster I/O speeds to be set. See the
<file:Documentation/ide.txt> and <file:drivers/ide/legacy/qd65xx.c> for <file:Documentation/ide.txt> and <file:drivers/ide/legacy/qd65xx.c> for
more info. more info.
@ -1059,7 +1059,7 @@ config BLK_DEV_QD65XX
config BLK_DEV_UMC8672 config BLK_DEV_UMC8672
tristate "UMC-8672 support" tristate "UMC-8672 support"
help help
This driver is enabled at runtime using the "ide0=umc8672" kernel This driver is enabled at runtime using the "umc8672.probe" kernel
boot parameter. It enables support for the secondary IDE interface boot parameter. It enables support for the secondary IDE interface
of the UMC-8672, and permits faster I/O speeds to be set as well. of the UMC-8672, and permits faster I/O speeds to be set as well.
See the files <file:Documentation/ide.txt> and See the files <file:Documentation/ide.txt> and

View File

@ -17,8 +17,6 @@
* device can't do DMA handshaking for some stupid reason. We don't need to do that. * device can't do DMA handshaking for some stupid reason. We don't need to do that.
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/timer.h> #include <linux/timer.h>

View File

@ -43,8 +43,6 @@
#define IDEDISK_VERSION "1.18" #define IDEDISK_VERSION "1.18"
#undef REALLY_SLOW_IO /* most systems can safely undef this */
//#define DEBUG //#define DEBUG
#include <linux/module.h> #include <linux/module.h>

View File

@ -583,6 +583,8 @@ u8 eighty_ninty_three (ide_drive_t *drive)
if(!(drive->id->hw_config & 0x4000)) if(!(drive->id->hw_config & 0x4000))
return 0; return 0;
#endif /* CONFIG_IDEDMA_IVB */ #endif /* CONFIG_IDEDMA_IVB */
if (!(drive->id->hw_config & 0x2000))
return 0;
return 1; return 1;
} }

View File

@ -345,16 +345,16 @@ static int ide_scan_pio_blacklist (char *model)
/** /**
* ide_get_best_pio_mode - get PIO mode from drive * ide_get_best_pio_mode - get PIO mode from drive
* @driver: drive to consider * @drive: drive to consider
* @mode_wanted: preferred mode * @mode_wanted: preferred mode
* @max_mode: highest allowed * @max_mode: highest allowed mode
* @d: pio data * @d: PIO data
* *
* This routine returns the recommended PIO settings for a given drive, * This routine returns the recommended PIO settings for a given drive,
* based on the drive->id information and the ide_pio_blacklist[]. * based on the drive->id information and the ide_pio_blacklist[].
* This is used by most chipset support modules when "auto-tuning".
* *
* Drive PIO mode auto selection * Drive PIO mode is auto-selected if 255 is passed as mode_wanted.
* This is used by most chipset support modules when "auto-tuning".
*/ */
u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_pio_data_t *d) u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_pio_data_t *d)
@ -367,6 +367,7 @@ u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_p
if (mode_wanted != 255) { if (mode_wanted != 255) {
pio_mode = mode_wanted; pio_mode = mode_wanted;
use_iordy = (pio_mode > 2);
} else if (!drive->id) { } else if (!drive->id) {
pio_mode = 0; pio_mode = 0;
} else if ((pio_mode = ide_scan_pio_blacklist(id->model)) != -1) { } else if ((pio_mode = ide_scan_pio_blacklist(id->model)) != -1) {
@ -396,19 +397,12 @@ u8 ide_get_best_pio_mode (ide_drive_t *drive, u8 mode_wanted, u8 max_mode, ide_p
} }
} }
#if 0
if (drive->id->major_rev_num & 0x0004) printk("ATA-2 ");
#endif
/* /*
* Conservative "downgrade" for all pre-ATA2 drives * Conservative "downgrade" for all pre-ATA2 drives
*/ */
if (pio_mode && pio_mode < 4) { if (pio_mode && pio_mode < 4) {
pio_mode--; pio_mode--;
overridden = 1; overridden = 1;
#if 0
use_iordy = (pio_mode > 2);
#endif
if (cycle_time && cycle_time < ide_pio_timings[pio_mode].cycle_time) if (cycle_time && cycle_time < ide_pio_timings[pio_mode].cycle_time)
cycle_time = 0; /* use standard timing */ cycle_time = 0; /* use standard timing */
} }

View File

@ -31,8 +31,6 @@
* valid after probe time even with noprobe * valid after probe time even with noprobe
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/string.h> #include <linux/string.h>

View File

@ -126,8 +126,6 @@
#define REVISION "Revision: 7.00alpha2" #define REVISION "Revision: 7.00alpha2"
#define VERSION "Id: ide.c 7.00a2 20020906" #define VERSION "Id: ide.c 7.00a2 20020906"
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#define _IDE_C /* Tell ide.h it's really us */ #define _IDE_C /* Tell ide.h it's really us */
#include <linux/module.h> #include <linux/module.h>
@ -1486,23 +1484,23 @@ static int __init match_parm (char *s, const char *keywords[], int vals[], int m
} }
#ifdef CONFIG_BLK_DEV_ALI14XX #ifdef CONFIG_BLK_DEV_ALI14XX
static int __initdata probe_ali14xx; extern int probe_ali14xx;
extern int ali14xx_init(void); extern int ali14xx_init(void);
#endif #endif
#ifdef CONFIG_BLK_DEV_UMC8672 #ifdef CONFIG_BLK_DEV_UMC8672
static int __initdata probe_umc8672; extern int probe_umc8672;
extern int umc8672_init(void); extern int umc8672_init(void);
#endif #endif
#ifdef CONFIG_BLK_DEV_DTC2278 #ifdef CONFIG_BLK_DEV_DTC2278
static int __initdata probe_dtc2278; extern int probe_dtc2278;
extern int dtc2278_init(void); extern int dtc2278_init(void);
#endif #endif
#ifdef CONFIG_BLK_DEV_HT6560B #ifdef CONFIG_BLK_DEV_HT6560B
static int __initdata probe_ht6560b; extern int probe_ht6560b;
extern int ht6560b_init(void); extern int ht6560b_init(void);
#endif #endif
#ifdef CONFIG_BLK_DEV_QD65XX #ifdef CONFIG_BLK_DEV_QD65XX
static int __initdata probe_qd65xx; extern int probe_qd65xx;
extern int qd65xx_init(void); extern int qd65xx_init(void);
#endif #endif
@ -1580,7 +1578,7 @@ static int __init ide_setup(char *s)
*/ */
if (s[0] == 'h' && s[1] == 'd' && s[2] >= 'a' && s[2] <= max_drive) { if (s[0] == 'h' && s[1] == 'd' && s[2] >= 'a' && s[2] <= max_drive) {
const char *hd_words[] = { const char *hd_words[] = {
"none", "noprobe", "nowerr", "cdrom", "serialize", "none", "noprobe", "nowerr", "cdrom", "minus5",
"autotune", "noautotune", "minus8", "swapdata", "bswap", "autotune", "noautotune", "minus8", "swapdata", "bswap",
"noflush", "remap", "remap63", "scsi", NULL }; "noflush", "remap", "remap63", "scsi", NULL };
unit = s[2] - 'a'; unit = s[2] - 'a';
@ -1608,9 +1606,6 @@ static int __init ide_setup(char *s)
drive->ready_stat = 0; drive->ready_stat = 0;
hwif->noprobe = 0; hwif->noprobe = 0;
goto done; goto done;
case -5: /* "serialize" */
printk(" -- USE \"ide%d=serialize\" INSTEAD", hw);
goto do_serialize;
case -6: /* "autotune" */ case -6: /* "autotune" */
drive->autotune = IDE_TUNE_AUTO; drive->autotune = IDE_TUNE_AUTO;
goto obsolete_option; goto obsolete_option;
@ -1671,7 +1666,7 @@ static int __init ide_setup(char *s)
* (-8, -9, -10) are reserved to ease the hardcoding. * (-8, -9, -10) are reserved to ease the hardcoding.
*/ */
static const char *ide_words[] = { static const char *ide_words[] = {
"noprobe", "serialize", "autotune", "noautotune", "noprobe", "serialize", "minus3", "minus4",
"reset", "dma", "ata66", "minus8", "minus9", "reset", "dma", "ata66", "minus8", "minus9",
"minus10", "four", "qd65xx", "ht6560b", "cmd640_vlb", "minus10", "four", "qd65xx", "ht6560b", "cmd640_vlb",
"dtc2278", "umc8672", "ali14xx", NULL }; "dtc2278", "umc8672", "ali14xx", NULL };
@ -1742,12 +1737,17 @@ static int __init ide_setup(char *s)
hwif->chipset = mate->chipset = ide_4drives; hwif->chipset = mate->chipset = ide_4drives;
mate->irq = hwif->irq; mate->irq = hwif->irq;
memcpy(mate->io_ports, hwif->io_ports, sizeof(hwif->io_ports)); memcpy(mate->io_ports, hwif->io_ports, sizeof(hwif->io_ports));
goto do_serialize; hwif->mate = mate;
mate->mate = hwif;
hwif->serialized = mate->serialized = 1;
goto obsolete_option;
} }
#endif /* CONFIG_BLK_DEV_4DRIVES */ #endif /* CONFIG_BLK_DEV_4DRIVES */
case -10: /* minus10 */ case -10: /* minus10 */
case -9: /* minus9 */ case -9: /* minus9 */
case -8: /* minus8 */ case -8: /* minus8 */
case -4:
case -3:
goto bad_option; goto bad_option;
case -7: /* ata66 */ case -7: /* ata66 */
#ifdef CONFIG_BLK_DEV_IDEPCI #ifdef CONFIG_BLK_DEV_IDEPCI
@ -1762,16 +1762,7 @@ static int __init ide_setup(char *s)
case -5: /* "reset" */ case -5: /* "reset" */
hwif->reset = 1; hwif->reset = 1;
goto obsolete_option; goto obsolete_option;
case -4: /* "noautotune" */
hwif->drives[0].autotune = IDE_TUNE_NOAUTO;
hwif->drives[1].autotune = IDE_TUNE_NOAUTO;
goto obsolete_option;
case -3: /* "autotune" */
hwif->drives[0].autotune = IDE_TUNE_AUTO;
hwif->drives[1].autotune = IDE_TUNE_AUTO;
goto obsolete_option;
case -2: /* "serialize" */ case -2: /* "serialize" */
do_serialize:
hwif->mate = &ide_hwifs[hw^1]; hwif->mate = &ide_hwifs[hw^1];
hwif->mate->mate = hwif; hwif->mate->mate = hwif;
hwif->serialized = hwif->mate->serialized = 1; hwif->serialized = hwif->mate->serialized = 1;
@ -1840,8 +1831,8 @@ static void __init probe_for_hwifs (void)
#endif /* CONFIG_BLK_DEV_CMD640 */ #endif /* CONFIG_BLK_DEV_CMD640 */
#ifdef CONFIG_BLK_DEV_IDE_PMAC #ifdef CONFIG_BLK_DEV_IDE_PMAC
{ {
extern void pmac_ide_probe(void); extern int pmac_ide_probe(void);
pmac_ide_probe(); (void)pmac_ide_probe();
} }
#endif /* CONFIG_BLK_DEV_IDE_PMAC */ #endif /* CONFIG_BLK_DEV_IDE_PMAC */
#ifdef CONFIG_BLK_DEV_GAYLE #ifdef CONFIG_BLK_DEV_GAYLE

View File

@ -37,8 +37,6 @@
* mode 4 for a while now with no trouble.) -Derek * mode 4 for a while now with no trouble.) -Derek
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
@ -230,9 +228,17 @@ static int __init ali14xx_probe(void)
return 0; return 0;
} }
int probe_ali14xx = 0;
module_param_named(probe, probe_ali14xx, bool, 0);
MODULE_PARM_DESC(probe, "probe for ALI M14xx chipsets");
/* Can be called directly from ide.c. */ /* Can be called directly from ide.c. */
int __init ali14xx_init(void) int __init ali14xx_init(void)
{ {
if (probe_ali14xx == 0)
goto out;
/* auto-detect IDE controller port */ /* auto-detect IDE controller port */
if (findPort()) { if (findPort()) {
if (ali14xx_probe()) if (ali14xx_probe())
@ -240,6 +246,7 @@ int __init ali14xx_init(void)
return 0; return 0;
} }
printk(KERN_ERR "ali14xx: not found.\n"); printk(KERN_ERR "ali14xx: not found.\n");
out:
return -ENODEV; return -ENODEV;
} }

View File

@ -4,8 +4,6 @@
* Copyright (C) 1996 Linus Torvalds & author (see below) * Copyright (C) 1996 Linus Torvalds & author (see below)
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
@ -94,7 +92,7 @@ static void tune_dtc2278 (ide_drive_t *drive, u8 pio)
HWIF(drive)->drives[!drive->select.b.unit].io_32bit = 1; HWIF(drive)->drives[!drive->select.b.unit].io_32bit = 1;
} }
static int __init probe_dtc2278(void) static int __init dtc2278_probe(void)
{ {
unsigned long flags; unsigned long flags;
ide_hwif_t *hwif, *mate; ide_hwif_t *hwif, *mate;
@ -145,10 +143,18 @@ static int __init probe_dtc2278(void)
return 0; return 0;
} }
int probe_dtc2278 = 0;
module_param_named(probe, probe_dtc2278, bool, 0);
MODULE_PARM_DESC(probe, "probe for DTC2278xx chipsets");
/* Can be called directly from ide.c. */ /* Can be called directly from ide.c. */
int __init dtc2278_init(void) int __init dtc2278_init(void)
{ {
if (probe_dtc2278()) { if (probe_dtc2278 == 0)
return -ENODEV;
if (dtc2278_probe()) {
printk(KERN_ERR "dtc2278: ide interfaces already in use!\n"); printk(KERN_ERR "dtc2278: ide interfaces already in use!\n");
return -EBUSY; return -EBUSY;
} }

View File

@ -36,8 +36,6 @@
#define HT6560B_VERSION "v0.07" #define HT6560B_VERSION "v0.07"
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
@ -303,12 +301,20 @@ static void tune_ht6560b (ide_drive_t *drive, u8 pio)
#endif #endif
} }
int probe_ht6560b = 0;
module_param_named(probe, probe_ht6560b, bool, 0);
MODULE_PARM_DESC(probe, "probe for HT6560B chipset");
/* Can be called directly from ide.c. */ /* Can be called directly from ide.c. */
int __init ht6560b_init(void) int __init ht6560b_init(void)
{ {
ide_hwif_t *hwif, *mate; ide_hwif_t *hwif, *mate;
int t; int t;
if (probe_ht6560b == 0)
return -ENODEV;
hwif = &ide_hwifs[0]; hwif = &ide_hwifs[0];
mate = &ide_hwifs[1]; mate = &ide_hwifs[1];

View File

@ -359,14 +359,17 @@ void ide_release(struct pcmcia_device *link)
static struct pcmcia_device_id ide_ids[] = { static struct pcmcia_device_id ide_ids[] = {
PCMCIA_DEVICE_FUNC_ID(4), PCMCIA_DEVICE_FUNC_ID(4),
PCMCIA_DEVICE_MANF_CARD(0x0007, 0x0000), /* Hitachi */ PCMCIA_DEVICE_MANF_CARD(0x0007, 0x0000), /* Hitachi */
PCMCIA_DEVICE_MANF_CARD(0x000a, 0x0000), /* I-O Data CFA */
PCMCIA_DEVICE_MANF_CARD(0x001c, 0x0001), /* Mitsubishi CFA */
PCMCIA_DEVICE_MANF_CARD(0x0032, 0x0704), PCMCIA_DEVICE_MANF_CARD(0x0032, 0x0704),
PCMCIA_DEVICE_MANF_CARD(0x0045, 0x0401), PCMCIA_DEVICE_MANF_CARD(0x0045, 0x0401), /* SanDisk CFA */
PCMCIA_DEVICE_MANF_CARD(0x0098, 0x0000), /* Toshiba */ PCMCIA_DEVICE_MANF_CARD(0x0098, 0x0000), /* Toshiba */
PCMCIA_DEVICE_MANF_CARD(0x00a4, 0x002d), PCMCIA_DEVICE_MANF_CARD(0x00a4, 0x002d),
PCMCIA_DEVICE_MANF_CARD(0x00ce, 0x0000), /* Samsung */ PCMCIA_DEVICE_MANF_CARD(0x00ce, 0x0000), /* Samsung */
PCMCIA_DEVICE_MANF_CARD(0x0319, 0x0000), /* Hitachi */ PCMCIA_DEVICE_MANF_CARD(0x0319, 0x0000), /* Hitachi */
PCMCIA_DEVICE_MANF_CARD(0x2080, 0x0001), PCMCIA_DEVICE_MANF_CARD(0x2080, 0x0001),
PCMCIA_DEVICE_MANF_CARD(0x4e01, 0x0200), /* Lexar */ PCMCIA_DEVICE_MANF_CARD(0x4e01, 0x0100), /* Viking CFA */
PCMCIA_DEVICE_MANF_CARD(0x4e01, 0x0200), /* Lexar, Viking CFA */
PCMCIA_DEVICE_PROD_ID123("Caravelle", "PSC-IDE ", "PSC000", 0x8c36137c, 0xd0693ab8, 0x2768a9f0), PCMCIA_DEVICE_PROD_ID123("Caravelle", "PSC-IDE ", "PSC000", 0x8c36137c, 0xd0693ab8, 0x2768a9f0),
PCMCIA_DEVICE_PROD_ID123("CDROM", "IDE", "MCD-601p", 0x1b9179ca, 0xede88951, 0x0d902f74), PCMCIA_DEVICE_PROD_ID123("CDROM", "IDE", "MCD-601p", 0x1b9179ca, 0xede88951, 0x0d902f74),
PCMCIA_DEVICE_PROD_ID123("PCMCIA", "IDE CARD", "F1", 0x281f1c5d, 0x1907960c, 0xf7fde8b9), PCMCIA_DEVICE_PROD_ID123("PCMCIA", "IDE CARD", "F1", 0x281f1c5d, 0x1907960c, 0xf7fde8b9),

View File

@ -16,8 +16,8 @@
* Please set local bus speed using kernel parameter idebus * Please set local bus speed using kernel parameter idebus
* for example, "idebus=33" stands for 33Mhz VLbus * for example, "idebus=33" stands for 33Mhz VLbus
* To activate controller support, use "ide0=qd65xx" * To activate controller support, use "ide0=qd65xx"
* To enable tuning, use "ide0=autotune" * To enable tuning, use "hda=autotune hdb=autotune"
* To enable second channel tuning (qd6580 only), use "ide1=autotune" * To enable 2nd channel tuning (qd6580 only), use "hdc=autotune hdd=autotune"
*/ */
/* /*
@ -25,8 +25,6 @@
* Samuel Thibault <samuel.thibault@fnac.net> * Samuel Thibault <samuel.thibault@fnac.net>
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/module.h> #include <linux/module.h>
#include <linux/types.h> #include <linux/types.h>
#include <linux/kernel.h> #include <linux/kernel.h>
@ -490,9 +488,17 @@ static int __init qd_probe(int base)
return 1; return 1;
} }
int probe_qd65xx = 0;
module_param_named(probe, probe_qd65xx, bool, 0);
MODULE_PARM_DESC(probe, "probe for QD65xx chipsets");
/* Can be called directly from ide.c. */ /* Can be called directly from ide.c. */
int __init qd65xx_init(void) int __init qd65xx_init(void)
{ {
if (probe_qd65xx == 0)
return -ENODEV;
if (qd_probe(0x30)) if (qd_probe(0x30))
qd_probe(0xb0); qd_probe(0xb0);
if (ide_hwifs[0].chipset != ide_qd65xx && if (ide_hwifs[0].chipset != ide_qd65xx &&

View File

@ -165,12 +165,21 @@ static int __init umc8672_probe(void)
return 0; return 0;
} }
int probe_umc8672 = 0;
module_param_named(probe, probe_umc8672, bool, 0);
MODULE_PARM_DESC(probe, "probe for UMC8672 chipset");
/* Can be called directly from ide.c. */ /* Can be called directly from ide.c. */
int __init umc8672_init(void) int __init umc8672_init(void)
{ {
if (umc8672_probe()) if (probe_umc8672 == 0)
return -ENODEV; goto out;
return 0;
if (umc8672_probe() == 0)
return 0;;
out:
return -ENODEV;;
} }
#ifdef MODULE #ifdef MODULE

View File

@ -29,8 +29,6 @@
* Note: for more information, please refer "AMD Alchemy Au1200/Au1550 IDE * Note: for more information, please refer "AMD Alchemy Au1200/Au1550 IDE
* Interface and Linux Device Driver" Application Note. * Interface and Linux Device Driver" Application Note.
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/types.h> #include <linux/types.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/kernel.h> #include <linux/kernel.h>

View File

@ -1,5 +1,5 @@
/* /*
* linux/drivers/ide/pci/alim15x3.c Version 0.17 2003/01/02 * linux/drivers/ide/pci/alim15x3.c Version 0.21 2007/02/03
* *
* Copyright (C) 1998-2000 Michel Aubry, Maintainer * Copyright (C) 1998-2000 Michel Aubry, Maintainer
* Copyright (C) 1998-2000 Andrzej Krzysztofowicz, Maintainer * Copyright (C) 1998-2000 Andrzej Krzysztofowicz, Maintainer
@ -9,6 +9,7 @@
* May be copied or modified under the terms of the GNU General Public License * May be copied or modified under the terms of the GNU General Public License
* Copyright (C) 2002 Alan Cox <alan@redhat.com> * Copyright (C) 2002 Alan Cox <alan@redhat.com>
* ALi (now ULi M5228) support by Clear Zhang <Clear.Zhang@ali.com.tw> * ALi (now ULi M5228) support by Clear Zhang <Clear.Zhang@ali.com.tw>
* Copyright (C) 2007 MontaVista Software, Inc. <source@mvista.com>
* *
* (U)DMA capable version of ali 1533/1543(C), 1535(D) * (U)DMA capable version of ali 1533/1543(C), 1535(D)
* *
@ -280,15 +281,17 @@ static int ali_get_info (char *buffer, char **addr, off_t offset, int count)
#endif /* defined(DISPLAY_ALI_TIMINGS) && defined(CONFIG_PROC_FS) */ #endif /* defined(DISPLAY_ALI_TIMINGS) && defined(CONFIG_PROC_FS) */
/** /**
* ali15x3_tune_drive - set up a drive * ali15x3_tune_pio - set up chipset for PIO mode
* @drive: drive to tune * @drive: drive to tune
* @pio: unused * @pio: desired mode
* *
* Select the best PIO timing for the drive in question. Then * Select the best PIO mode for the drive in question.
* program the controller for this drive set up * Then program the controller for this mode.
*
* Returns the PIO mode programmed.
*/ */
static void ali15x3_tune_drive (ide_drive_t *drive, u8 pio) static u8 ali15x3_tune_pio (ide_drive_t *drive, u8 pio)
{ {
ide_pio_data_t d; ide_pio_data_t d;
ide_hwif_t *hwif = HWIF(drive); ide_hwif_t *hwif = HWIF(drive);
@ -356,6 +359,22 @@ static void ali15x3_tune_drive (ide_drive_t *drive, u8 pio)
* { 20, 50, 30 } PIO Mode 5 with IORDY (nonstandard) * { 20, 50, 30 } PIO Mode 5 with IORDY (nonstandard)
*/ */
return pio;
}
/**
* ali15x3_tune_drive - set up drive for PIO mode
* @drive: drive to tune
* @pio: desired mode
*
* Program the controller with the best PIO timing for the given drive.
* Then set up the drive itself.
*/
static void ali15x3_tune_drive (ide_drive_t *drive, u8 pio)
{
pio = ali15x3_tune_pio(drive, pio);
(void) ide_config_drive_speed(drive, XFER_PIO_0 + pio);
} }
/** /**
@ -430,7 +449,7 @@ static u8 ali15x3_ratemask (ide_drive_t *drive)
} }
/** /**
* ali15x3_tune_chipset - set up chiset for new speed * ali15x3_tune_chipset - set up chipset/drive for new speed
* @drive: drive to configure for * @drive: drive to configure for
* @xferspeed: desired speed * @xferspeed: desired speed
* *
@ -461,7 +480,7 @@ static int ali15x3_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_write_config_byte(dev, m5229_udma, tmpbyte); pci_write_config_byte(dev, m5229_udma, tmpbyte);
if (speed < XFER_SW_DMA_0) if (speed < XFER_SW_DMA_0)
ali15x3_tune_drive(drive, speed); (void) ali15x3_tune_pio(drive, speed - XFER_PIO_0);
} else { } else {
pci_read_config_byte(dev, m5229_udma, &tmpbyte); pci_read_config_byte(dev, m5229_udma, &tmpbyte);
tmpbyte &= (0x0f << ((1-unit) << 2)); tmpbyte &= (0x0f << ((1-unit) << 2));

View File

@ -98,7 +98,6 @@
* (patch courtesy of Zoltan Hidvegi) * (patch courtesy of Zoltan Hidvegi)
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#define CMD640_PREFETCH_MASKS 1 #define CMD640_PREFETCH_MASKS 1
//#define CMD640_DUMP_REGS //#define CMD640_DUMP_REGS

View File

@ -1,6 +1,6 @@
/* $Id: cmd64x.c,v 1.21 2000/01/30 23:23:16 /* $Id: cmd64x.c,v 1.21 2000/01/30 23:23:16
* *
* linux/drivers/ide/pci/cmd64x.c Version 1.30 Sept 10, 2002 * linux/drivers/ide/pci/cmd64x.c Version 1.41 Feb 3, 2007
* *
* cmd64x.c: Enable interrupts at initialization time on Ultra/PCI machines. * cmd64x.c: Enable interrupts at initialization time on Ultra/PCI machines.
* Note, this driver is not used at all on other systems because * Note, this driver is not used at all on other systems because
@ -12,6 +12,7 @@
* Copyright (C) 1998 David S. Miller (davem@redhat.com) * Copyright (C) 1998 David S. Miller (davem@redhat.com)
* *
* Copyright (C) 1999-2002 Andre Hedrick <andre@linux-ide.org> * Copyright (C) 1999-2002 Andre Hedrick <andre@linux-ide.org>
* Copyright (C) 2007 MontaVista Software, Inc. <source@mvista.com>
*/ */
#include <linux/module.h> #include <linux/module.h>
@ -262,43 +263,25 @@ static void program_drive_counts (ide_drive_t *drive, int setup_count, int activ
} }
/* /*
* Attempts to set the interface PIO mode. * This routine selects drive's best PIO mode, calculates setup/active/recovery
* The preferred method of selecting PIO modes (e.g. mode 4) is * counts, and then writes them into the chipset registers.
* "echo 'piomode:4' > /proc/ide/hdx/settings". Special cases are
* 8: prefetch off, 9: prefetch on, 255: auto-select best mode.
* Called with 255 at boot time.
*/ */
static u8 cmd64x_tune_pio (ide_drive_t *drive, u8 mode_wanted)
static void cmd64x_tuneproc (ide_drive_t *drive, u8 mode_wanted)
{ {
int setup_time, active_time, recovery_time; int setup_time, active_time, recovery_time;
int clock_time, pio_mode, cycle_time; int clock_time, pio_mode, cycle_time;
u8 recovery_count2, cycle_count; u8 recovery_count2, cycle_count;
int setup_count, active_count, recovery_count; int setup_count, active_count, recovery_count;
int bus_speed = system_bus_clock(); int bus_speed = system_bus_clock();
/*byte b;*/
ide_pio_data_t d; ide_pio_data_t d;
switch (mode_wanted) { pio_mode = ide_get_best_pio_mode(drive, mode_wanted, 5, &d);
case 8: /* set prefetch off */
case 9: /* set prefetch on */
mode_wanted &= 1;
/*set_prefetch_mode(index, mode_wanted);*/
cmdprintk("%s: %sabled cmd640 prefetch\n",
drive->name, mode_wanted ? "en" : "dis");
return;
}
mode_wanted = ide_get_best_pio_mode (drive, mode_wanted, 5, &d);
pio_mode = d.pio_mode;
cycle_time = d.cycle_time; cycle_time = d.cycle_time;
/* /*
* I copied all this complicated stuff from cmd640.c and made a few * I copied all this complicated stuff from cmd640.c and made a few
* minor changes. For now I am just going to pray that it is correct. * minor changes. For now I am just going to pray that it is correct.
*/ */
if (pio_mode > 5)
pio_mode = 5;
setup_time = ide_pio_timings[pio_mode].setup_time; setup_time = ide_pio_timings[pio_mode].setup_time;
active_time = ide_pio_timings[pio_mode].active_time; active_time = ide_pio_timings[pio_mode].active_time;
recovery_time = cycle_time - (setup_time + active_time); recovery_time = cycle_time - (setup_time + active_time);
@ -320,22 +303,33 @@ static void cmd64x_tuneproc (ide_drive_t *drive, u8 mode_wanted)
if (active_count > 16) if (active_count > 16)
active_count = 16; /* maximum allowed by cmd646 */ active_count = 16; /* maximum allowed by cmd646 */
/*
* In a perfect world, we might set the drive pio mode here
* (using WIN_SETFEATURE) before continuing.
*
* But we do not, because:
* 1) this is the wrong place to do it
* (proper is do_special() in ide.c)
* 2) in practice this is rarely, if ever, necessary
*/
program_drive_counts (drive, setup_count, active_count, recovery_count); program_drive_counts (drive, setup_count, active_count, recovery_count);
cmdprintk("%s: selected cmd646 PIO mode%d : %d (%dns)%s, " cmdprintk("%s: PIO mode wanted %d, selected %d (%dns)%s, "
"clocks=%d/%d/%d\n", "clocks=%d/%d/%d\n",
drive->name, pio_mode, mode_wanted, cycle_time, drive->name, mode_wanted, pio_mode, cycle_time,
d.overridden ? " (overriding vendor mode)" : "", d.overridden ? " (overriding vendor mode)" : "",
setup_count, active_count, recovery_count); setup_count, active_count, recovery_count);
return pio_mode;
}
/*
* Attempts to set drive's PIO mode.
* Special cases are 8: prefetch off, 9: prefetch on (both never worked),
* and 255: auto-select best mode (used at boot time).
*/
static void cmd64x_tune_drive (ide_drive_t *drive, u8 pio)
{
/*
* Filter out the prefetch control values
* to prevent PIO5 from being programmed
*/
if (pio == 8 || pio == 9)
return;
pio = cmd64x_tune_pio(drive, pio);
(void) ide_config_drive_speed(drive, XFER_PIO_0 + pio);
} }
static u8 cmd64x_ratemask (ide_drive_t *drive) static u8 cmd64x_ratemask (ide_drive_t *drive)
@ -387,22 +381,6 @@ static u8 cmd64x_ratemask (ide_drive_t *drive)
return mode; return mode;
} }
static void config_cmd64x_chipset_for_pio (ide_drive_t *drive, u8 set_speed)
{
u8 speed = 0x00;
u8 set_pio = ide_get_best_pio_mode(drive, 4, 5, NULL);
cmd64x_tuneproc(drive, set_pio);
speed = XFER_PIO_0 + set_pio;
if (set_speed)
(void) ide_config_drive_speed(drive, speed);
}
static void config_chipset_for_pio (ide_drive_t *drive, u8 set_speed)
{
config_cmd64x_chipset_for_pio(drive, set_speed);
}
static int cmd64x_tune_chipset (ide_drive_t *drive, u8 xferspeed) static int cmd64x_tune_chipset (ide_drive_t *drive, u8 xferspeed)
{ {
ide_hwif_t *hwif = HWIF(drive); ide_hwif_t *hwif = HWIF(drive);
@ -414,7 +392,7 @@ static int cmd64x_tune_chipset (ide_drive_t *drive, u8 xferspeed)
u8 speed = ide_rate_filter(cmd64x_ratemask(drive), xferspeed); u8 speed = ide_rate_filter(cmd64x_ratemask(drive), xferspeed);
if (speed > XFER_PIO_4) { if (speed >= XFER_SW_DMA_0) {
(void) pci_read_config_byte(dev, pciD, &regD); (void) pci_read_config_byte(dev, pciD, &regD);
(void) pci_read_config_byte(dev, pciU, &regU); (void) pci_read_config_byte(dev, pciU, &regU);
regD &= ~(unit ? 0x40 : 0x20); regD &= ~(unit ? 0x40 : 0x20);
@ -438,17 +416,20 @@ static int cmd64x_tune_chipset (ide_drive_t *drive, u8 xferspeed)
case XFER_SW_DMA_2: regD |= (unit ? 0x40 : 0x10); break; case XFER_SW_DMA_2: regD |= (unit ? 0x40 : 0x10); break;
case XFER_SW_DMA_1: regD |= (unit ? 0x80 : 0x20); break; case XFER_SW_DMA_1: regD |= (unit ? 0x80 : 0x20); break;
case XFER_SW_DMA_0: regD |= (unit ? 0xC0 : 0x30); break; case XFER_SW_DMA_0: regD |= (unit ? 0xC0 : 0x30); break;
case XFER_PIO_4: cmd64x_tuneproc(drive, 4); break; case XFER_PIO_5:
case XFER_PIO_3: cmd64x_tuneproc(drive, 3); break; case XFER_PIO_4:
case XFER_PIO_2: cmd64x_tuneproc(drive, 2); break; case XFER_PIO_3:
case XFER_PIO_1: cmd64x_tuneproc(drive, 1); break; case XFER_PIO_2:
case XFER_PIO_0: cmd64x_tuneproc(drive, 0); break; case XFER_PIO_1:
case XFER_PIO_0:
(void) cmd64x_tune_pio(drive, speed - XFER_PIO_0);
break;
default: default:
return 1; return 1;
} }
if (speed > XFER_PIO_4) { if (speed >= XFER_SW_DMA_0) {
(void) pci_write_config_byte(dev, pciU, regU); (void) pci_write_config_byte(dev, pciU, regU);
regD |= (unit ? 0x40 : 0x20); regD |= (unit ? 0x40 : 0x20);
(void) pci_write_config_byte(dev, pciD, regD); (void) pci_write_config_byte(dev, pciD, regD);
@ -461,8 +442,6 @@ static int config_chipset_for_dma (ide_drive_t *drive)
{ {
u8 speed = ide_dma_speed(drive, cmd64x_ratemask(drive)); u8 speed = ide_dma_speed(drive, cmd64x_ratemask(drive));
config_chipset_for_pio(drive, !speed);
if (!speed) if (!speed)
return 0; return 0;
@ -478,7 +457,7 @@ static int cmd64x_config_drive_for_dma (ide_drive_t *drive)
return 0; return 0;
if (ide_use_fast_pio(drive)) if (ide_use_fast_pio(drive))
config_chipset_for_pio(drive, 1); cmd64x_tune_drive(drive, 255);
return -1; return -1;
} }
@ -679,14 +658,13 @@ static void __devinit init_hwif_cmd64x(ide_hwif_t *hwif)
pci_read_config_dword(dev, PCI_CLASS_REVISION, &class_rev); pci_read_config_dword(dev, PCI_CLASS_REVISION, &class_rev);
class_rev &= 0xff; class_rev &= 0xff;
hwif->tuneproc = &cmd64x_tuneproc; hwif->tuneproc = &cmd64x_tune_drive;
hwif->speedproc = &cmd64x_tune_chipset; hwif->speedproc = &cmd64x_tune_chipset;
if (!hwif->dma_base) { hwif->drives[0].autotune = hwif->drives[1].autotune = 1;
hwif->drives[0].autotune = 1;
hwif->drives[1].autotune = 1; if (!hwif->dma_base)
return; return;
}
hwif->atapi_dma = 1; hwif->atapi_dma = 1;

View File

@ -122,7 +122,7 @@ static struct pci_driver driver = {
static int static int
delkin_cb_init (void) delkin_cb_init (void)
{ {
return pci_module_init(&driver); return pci_register_driver(&driver);
} }
static void static void

View File

@ -21,8 +21,6 @@
* are deemed to be part of the source code. * are deemed to be part of the source code.
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/types.h> #include <linux/types.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/kernel.h> #include <linux/kernel.h>

View File

@ -57,7 +57,7 @@
* There is a 25/33MHz switch in configuration * There is a 25/33MHz switch in configuration
* register, but driver is written for use at any frequency which get * register, but driver is written for use at any frequency which get
* (use idebus=xx to select PCI bus speed). * (use idebus=xx to select PCI bus speed).
* Use ide0=autotune for automatical tune of the PIO modes. * Use hda=autotune and hdb=autotune for automatical tune of the PIO modes.
* If you get strange results, do not use this and set PIO manually * If you get strange results, do not use this and set PIO manually
* by hdparm. * by hdparm.
* *
@ -87,7 +87,6 @@
* 0.5 doesn't work. * 0.5 doesn't work.
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#define OPTI621_DEBUG /* define for debug messages */ #define OPTI621_DEBUG /* define for debug messages */
#include <linux/types.h> #include <linux/types.h>

View File

@ -1,10 +1,10 @@
/* /*
* linux/drivers/ide/pci/piix.c Version 0.46 December 3, 2006 * linux/drivers/ide/pci/piix.c Version 0.47 February 8, 2007
* *
* Copyright (C) 1998-1999 Andrzej Krzysztofowicz, Author and Maintainer * Copyright (C) 1998-1999 Andrzej Krzysztofowicz, Author and Maintainer
* Copyright (C) 1998-2000 Andre Hedrick <andre@linux-ide.org> * Copyright (C) 1998-2000 Andre Hedrick <andre@linux-ide.org>
* Copyright (C) 2003 Red Hat Inc <alan@redhat.com> * Copyright (C) 2003 Red Hat Inc <alan@redhat.com>
* Copyright (C) 2006 MontaVista Software, Inc. <source@mvista.com> * Copyright (C) 2006-2007 MontaVista Software, Inc. <source@mvista.com>
* *
* May be copied or modified under the terms of the GNU General Public License * May be copied or modified under the terms of the GNU General Public License
* *
@ -205,14 +205,13 @@ static u8 piix_dma_2_pio (u8 xfer_rate) {
} }
/** /**
* piix_tune_drive - tune a drive attached to a PIIX * piix_tune_pio - tune PIIX for PIO mode
* @drive: drive to tune * @drive: drive to tune
* @pio: desired PIO mode * @pio: desired PIO mode
* *
* Set the interface PIO mode based upon the settings done by AMI BIOS * Set the interface PIO mode based upon the settings done by AMI BIOS.
* (might be useful if drive is not registered in CMOS for any reason).
*/ */
static void piix_tune_drive (ide_drive_t *drive, u8 pio) static void piix_tune_pio (ide_drive_t *drive, u8 pio)
{ {
ide_hwif_t *hwif = HWIF(drive); ide_hwif_t *hwif = HWIF(drive);
struct pci_dev *dev = hwif->pci_dev; struct pci_dev *dev = hwif->pci_dev;
@ -233,8 +232,6 @@ static void piix_tune_drive (ide_drive_t *drive, u8 pio)
{ 2, 1 }, { 2, 1 },
{ 2, 3 }, }; { 2, 3 }, };
pio = ide_get_best_pio_mode(drive, pio, 4, NULL);
/* /*
* Master vs slave is synchronized above us but the slave register is * Master vs slave is synchronized above us but the slave register is
* shared by the two hwifs so the corner case of two slave timeouts in * shared by the two hwifs so the corner case of two slave timeouts in
@ -253,19 +250,20 @@ static void piix_tune_drive (ide_drive_t *drive, u8 pio)
master_data |= 0x4000; master_data |= 0x4000;
master_data &= ~0x0070; master_data &= ~0x0070;
if (pio > 1) { if (pio > 1) {
/* enable PPE, IE and TIME */ /* Set PPE, IE and TIME */
master_data = master_data | (control << 4); master_data |= control << 4;
} }
pci_read_config_byte(dev, slave_port, &slave_data); pci_read_config_byte(dev, slave_port, &slave_data);
slave_data = slave_data & (hwif->channel ? 0x0f : 0xf0); slave_data &= hwif->channel ? 0x0f : 0xf0;
slave_data = slave_data | (((timings[pio][0] << 2) | timings[pio][1]) << (hwif->channel ? 4 : 0)); slave_data |= ((timings[pio][0] << 2) | timings[pio][1]) <<
(hwif->channel ? 4 : 0);
} else { } else {
master_data &= ~0x3307; master_data &= ~0x3307;
if (pio > 1) { if (pio > 1) {
/* enable PPE, IE and TIME */ /* enable PPE, IE and TIME */
master_data = master_data | control; master_data |= control;
} }
master_data = master_data | (timings[pio][0] << 12) | (timings[pio][1] << 8); master_data |= (timings[pio][0] << 12) | (timings[pio][1] << 8);
} }
pci_write_config_word(dev, master_port, master_data); pci_write_config_word(dev, master_port, master_data);
if (is_slave) if (is_slave)
@ -273,6 +271,21 @@ static void piix_tune_drive (ide_drive_t *drive, u8 pio)
spin_unlock_irqrestore(&tune_lock, flags); spin_unlock_irqrestore(&tune_lock, flags);
} }
/**
* piix_tune_drive - tune a drive attached to PIIX
* @drive: drive to tune
* @pio: desired PIO mode
*
* Set the drive's PIO mode (might be useful if drive is not registered
* in CMOS for any reason).
*/
static void piix_tune_drive (ide_drive_t *drive, u8 pio)
{
pio = ide_get_best_pio_mode(drive, pio, 4, NULL);
piix_tune_pio(drive, pio);
(void) ide_config_drive_speed(drive, XFER_PIO_0 + pio);
}
/** /**
* piix_tune_chipset - tune a PIIX interface * piix_tune_chipset - tune a PIIX interface
* @drive: IDE drive to tune * @drive: IDE drive to tune
@ -348,8 +361,8 @@ static int piix_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_write_config_byte(dev, 0x55, (u8) reg55 & ~w_flag); pci_write_config_byte(dev, 0x55, (u8) reg55 & ~w_flag);
} }
piix_tune_drive(drive, piix_dma_2_pio(speed)); piix_tune_pio(drive, piix_dma_2_pio(speed));
return (ide_config_drive_speed(drive, speed)); return ide_config_drive_speed(drive, speed);
} }
/** /**
@ -392,9 +405,7 @@ static int piix_config_drive_xfer_rate (ide_drive_t *drive)
return 0; return 0;
if (ide_use_fast_pio(drive)) if (ide_use_fast_pio(drive))
/* Find best PIO mode. */ piix_tune_drive(drive, 255);
piix_tune_chipset(drive, XFER_PIO_0 +
ide_get_best_pio_mode(drive, 255, 4, NULL));
return -1; return -1;
} }

View File

@ -15,8 +15,6 @@
* Dunno if this fixes both ports, or only the primary port (?). * Dunno if this fixes both ports, or only the primary port (?).
*/ */
#undef REALLY_SLOW_IO /* most systems can safely undef this */
#include <linux/types.h> #include <linux/types.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/kernel.h> #include <linux/kernel.h>

View File

@ -26,6 +26,11 @@
* If you have strange problems with nVidia chipset systems please * If you have strange problems with nVidia chipset systems please
* see the SI support documentation and update your system BIOS * see the SI support documentation and update your system BIOS
* if neccessary * if neccessary
*
* The Dell DRAC4 has some interesting features including effectively hot
* unplugging/replugging the virtual CD interface when the DRAC is reset.
* This often causes drivers/ide/siimage to panic but is ok with the rather
* smarter code in libata.
*/ */
#include <linux/types.h> #include <linux/types.h>

View File

@ -1,8 +1,8 @@
/* /*
* linux/drivers/ide/pci/slc90e66.c Version 0.13 December 30, 2006 * linux/drivers/ide/pci/slc90e66.c Version 0.14 February 8, 2007
* *
* Copyright (C) 2000-2002 Andre Hedrick <andre@linux-ide.org> * Copyright (C) 2000-2002 Andre Hedrick <andre@linux-ide.org>
* Copyright (C) 2006 MontaVista Software, Inc. <source@mvista.com> * Copyright (C) 2006-2007 MontaVista Software, Inc. <source@mvista.com>
* *
* This is a look-alike variation of the ICH0 PIIX4 Ultra-66, * This is a look-alike variation of the ICH0 PIIX4 Ultra-66,
* but this keeps the ISA-Bridge and slots alive. * but this keeps the ISA-Bridge and slots alive.
@ -57,11 +57,7 @@ static u8 slc90e66_dma_2_pio (u8 xfer_rate) {
} }
} }
/* static void slc90e66_tune_pio (ide_drive_t *drive, u8 pio)
* Based on settings done by AMI BIOS
* (might be useful if drive is not registered in CMOS for any reason).
*/
static void slc90e66_tune_drive (ide_drive_t *drive, u8 pio)
{ {
ide_hwif_t *hwif = HWIF(drive); ide_hwif_t *hwif = HWIF(drive);
struct pci_dev *dev = hwif->pci_dev; struct pci_dev *dev = hwif->pci_dev;
@ -80,7 +76,6 @@ static void slc90e66_tune_drive (ide_drive_t *drive, u8 pio)
{ 2, 1 }, { 2, 1 },
{ 2, 3 }, }; { 2, 3 }, };
pio = ide_get_best_pio_mode(drive, pio, 4, NULL);
spin_lock_irqsave(&ide_lock, flags); spin_lock_irqsave(&ide_lock, flags);
pci_read_config_word(dev, master_port, &master_data); pci_read_config_word(dev, master_port, &master_data);
@ -94,19 +89,20 @@ static void slc90e66_tune_drive (ide_drive_t *drive, u8 pio)
master_data |= 0x4000; master_data |= 0x4000;
master_data &= ~0x0070; master_data &= ~0x0070;
if (pio > 1) { if (pio > 1) {
/* enable PPE, IE and TIME */ /* Set PPE, IE and TIME */
master_data = master_data | (control << 4); master_data |= control << 4;
} }
pci_read_config_byte(dev, slave_port, &slave_data); pci_read_config_byte(dev, slave_port, &slave_data);
slave_data = slave_data & (hwif->channel ? 0x0f : 0xf0); slave_data &= hwif->channel ? 0x0f : 0xf0;
slave_data = slave_data | (((timings[pio][0] << 2) | timings[pio][1]) << (hwif->channel ? 4 : 0)); slave_data |= ((timings[pio][0] << 2) | timings[pio][1]) <<
(hwif->channel ? 4 : 0);
} else { } else {
master_data &= ~0x3307; master_data &= ~0x3307;
if (pio > 1) { if (pio > 1) {
/* enable PPE, IE and TIME */ /* enable PPE, IE and TIME */
master_data = master_data | control; master_data |= control;
} }
master_data = master_data | (timings[pio][0] << 12) | (timings[pio][1] << 8); master_data |= (timings[pio][0] << 12) | (timings[pio][1] << 8);
} }
pci_write_config_word(dev, master_port, master_data); pci_write_config_word(dev, master_port, master_data);
if (is_slave) if (is_slave)
@ -114,6 +110,13 @@ static void slc90e66_tune_drive (ide_drive_t *drive, u8 pio)
spin_unlock_irqrestore(&ide_lock, flags); spin_unlock_irqrestore(&ide_lock, flags);
} }
static void slc90e66_tune_drive (ide_drive_t *drive, u8 pio)
{
pio = ide_get_best_pio_mode(drive, pio, 4, NULL);
slc90e66_tune_pio(drive, pio);
(void) ide_config_drive_speed(drive, XFER_PIO_0 + pio);
}
static int slc90e66_tune_chipset (ide_drive_t *drive, u8 xferspeed) static int slc90e66_tune_chipset (ide_drive_t *drive, u8 xferspeed)
{ {
ide_hwif_t *hwif = HWIF(drive); ide_hwif_t *hwif = HWIF(drive);
@ -162,8 +165,8 @@ static int slc90e66_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_write_config_word(dev, 0x4a, reg4a & ~a_speed); pci_write_config_word(dev, 0x4a, reg4a & ~a_speed);
} }
slc90e66_tune_drive(drive, slc90e66_dma_2_pio(speed)); slc90e66_tune_pio(drive, slc90e66_dma_2_pio(speed));
return (ide_config_drive_speed(drive, speed)); return ide_config_drive_speed(drive, speed);
} }
static int slc90e66_config_drive_for_dma (ide_drive_t *drive) static int slc90e66_config_drive_for_dma (ide_drive_t *drive)
@ -185,8 +188,7 @@ static int slc90e66_config_drive_xfer_rate (ide_drive_t *drive)
return 0; return 0;
if (ide_use_fast_pio(drive)) if (ide_use_fast_pio(drive))
(void)slc90e66_tune_chipset(drive, XFER_PIO_0 + slc90e66_tune_drive(drive, 255);
ide_get_best_pio_mode(drive, 255, 4, NULL));
return -1; return -1;
} }

View File

@ -48,7 +48,7 @@
#include <asm/mediabay.h> #include <asm/mediabay.h>
#endif #endif
#include "ide-timing.h" #include "../ide-timing.h"
#undef IDE_PMAC_DEBUG #undef IDE_PMAC_DEBUG
@ -1551,19 +1551,34 @@ static struct pci_driver pmac_ide_pci_driver = {
}; };
MODULE_DEVICE_TABLE(pci, pmac_ide_pci_match); MODULE_DEVICE_TABLE(pci, pmac_ide_pci_match);
void __init int __init pmac_ide_probe(void)
pmac_ide_probe(void)
{ {
int error;
if (!machine_is(powermac)) if (!machine_is(powermac))
return; return -ENODEV;
#ifdef CONFIG_BLK_DEV_IDE_PMAC_ATA100FIRST #ifdef CONFIG_BLK_DEV_IDE_PMAC_ATA100FIRST
pci_register_driver(&pmac_ide_pci_driver); error = pci_register_driver(&pmac_ide_pci_driver);
macio_register_driver(&pmac_ide_macio_driver); if (error)
goto out;
error = macio_register_driver(&pmac_ide_macio_driver);
if (error) {
pci_unregister_driver(&pmac_ide_pci_driver);
goto out;
}
#else #else
macio_register_driver(&pmac_ide_macio_driver); error = macio_register_driver(&pmac_ide_macio_driver);
pci_register_driver(&pmac_ide_pci_driver); if (error)
goto out;
error = pci_register_driver(&pmac_ide_pci_driver);
if (error) {
macio_unregister_driver(&pmac_ide_macio_driver);
goto out;
}
#endif #endif
out:
return error;
} }
#ifdef CONFIG_BLK_DEV_IDEDMA_PMAC #ifdef CONFIG_BLK_DEV_IDEDMA_PMAC
@ -1983,7 +1998,7 @@ static void pmac_ide_dma_host_off(ide_drive_t *drive)
{ {
} }
static int pmac_ide_dma_host_on(ide_drive_t *drive) static void pmac_ide_dma_host_on(ide_drive_t *drive)
{ {
} }

View File

@ -509,6 +509,32 @@ static int scc_ide_dma_end(ide_drive_t * drive)
return __ide_dma_end(drive); return __ide_dma_end(drive);
} }
/* returns 1 if dma irq issued, 0 otherwise */
static int scc_dma_test_irq(ide_drive_t *drive)
{
ide_hwif_t *hwif = HWIF(drive);
u8 dma_stat = hwif->INB(hwif->dma_status);
/* return 1 if INTR asserted */
if ((dma_stat & 4) == 4)
return 1;
/* Workaround for PTERADD: emulate DMA_INTR when
* - IDE_STATUS[ERR] = 1
* - INT_STATUS[INTRQ] = 1
* - DMA_STATUS[IORACTA] = 1
*/
if (in_be32((void __iomem *)IDE_ALTSTATUS_REG) & ERR_STAT &&
in_be32((void __iomem *)(hwif->dma_base + 0x014)) & INTSTS_INTRQ &&
dma_stat & 1)
return 1;
if (!drive->waiting_for_dma)
printk(KERN_WARNING "%s: (%s) called while not waiting\n",
drive->name, __FUNCTION__);
return 0;
}
/** /**
* setup_mmio_scc - map CTRL/BMID region * setup_mmio_scc - map CTRL/BMID region
* @dev: PCI device we are configuring * @dev: PCI device we are configuring
@ -712,6 +738,7 @@ static void __devinit init_hwif_scc(ide_hwif_t *hwif)
hwif->speedproc = scc_tune_chipset; hwif->speedproc = scc_tune_chipset;
hwif->tuneproc = scc_tuneproc; hwif->tuneproc = scc_tuneproc;
hwif->ide_dma_check = scc_config_drive_for_dma; hwif->ide_dma_check = scc_config_drive_for_dma;
hwif->ide_dma_test_irq = scc_dma_test_irq;
hwif->drives[0].autotune = IDE_TUNE_AUTO; hwif->drives[0].autotune = IDE_TUNE_AUTO;
hwif->drives[1].autotune = IDE_TUNE_AUTO; hwif->drives[1].autotune = IDE_TUNE_AUTO;

View File

@ -682,7 +682,34 @@ static void pci_read_irq(struct pci_dev *dev)
dev->irq = irq; dev->irq = irq;
} }
#define LEGACY_IO_RESOURCE (IORESOURCE_IO | IORESOURCE_PCI_FIXED) static void change_legacy_io_resource(struct pci_dev * dev, unsigned index,
unsigned start, unsigned end)
{
unsigned base = start & PCI_BASE_ADDRESS_IO_MASK;
unsigned len = (end | ~PCI_BASE_ADDRESS_IO_MASK) - base + 1;
/*
* Some X versions get confused when the BARs reported through
* /sys or /proc differ from those seen in config space, thus
* try to update the config space values, too.
*/
if (!(pci_resource_flags(dev, index) & IORESOURCE_IO))
printk(KERN_WARNING "%s: cannot adjust BAR%u (not I/O)\n",
pci_name(dev), index);
else if (pci_resource_len(dev, index) != len)
printk(KERN_WARNING "%s: cannot adjust BAR%u (size %04X)\n",
pci_name(dev), index, (unsigned)pci_resource_len(dev, index));
else {
printk(KERN_INFO "%s: trying to change BAR%u from %04X to %04X\n",
pci_name(dev), index,
(unsigned)pci_resource_start(dev, index), base);
pci_write_config_dword(dev, PCI_BASE_ADDRESS_0 + index * 4, base);
}
pci_resource_start(dev, index) = start;
pci_resource_end(dev, index) = end;
pci_resource_flags(dev, index) =
IORESOURCE_IO | IORESOURCE_PCI_FIXED | PCI_BASE_ADDRESS_SPACE_IO;
}
/** /**
* pci_setup_device - fill in class and map information of a device * pci_setup_device - fill in class and map information of a device
@ -735,20 +762,12 @@ static int pci_setup_device(struct pci_dev * dev)
u8 progif; u8 progif;
pci_read_config_byte(dev, PCI_CLASS_PROG, &progif); pci_read_config_byte(dev, PCI_CLASS_PROG, &progif);
if ((progif & 1) == 0) { if ((progif & 1) == 0) {
dev->resource[0].start = 0x1F0; change_legacy_io_resource(dev, 0, 0x1F0, 0x1F7);
dev->resource[0].end = 0x1F7; change_legacy_io_resource(dev, 1, 0x3F6, 0x3F6);
dev->resource[0].flags = LEGACY_IO_RESOURCE;
dev->resource[1].start = 0x3F6;
dev->resource[1].end = 0x3F6;
dev->resource[1].flags = LEGACY_IO_RESOURCE;
} }
if ((progif & 4) == 0) { if ((progif & 4) == 0) {
dev->resource[2].start = 0x170; change_legacy_io_resource(dev, 2, 0x170, 0x177);
dev->resource[2].end = 0x177; change_legacy_io_resource(dev, 3, 0x376, 0x376);
dev->resource[2].flags = LEGACY_IO_RESOURCE;
dev->resource[3].start = 0x376;
dev->resource[3].end = 0x376;
dev->resource[3].flags = LEGACY_IO_RESOURCE;
} }
} }
break; break;

View File

@ -1359,7 +1359,8 @@ u8 ide_dump_status(ide_drive_t *, const char *, u8);
typedef struct ide_pio_timings_s { typedef struct ide_pio_timings_s {
int setup_time; /* Address setup (ns) minimum */ int setup_time; /* Address setup (ns) minimum */
int active_time; /* Active pulse (ns) minimum */ int active_time; /* Active pulse (ns) minimum */
int cycle_time; /* Cycle time (ns) minimum = (setup + active + recovery) */ int cycle_time; /* Cycle time (ns) minimum = */
/* active + recovery (+ setup for some chips) */
} ide_pio_timings_t; } ide_pio_timings_t;
typedef struct ide_pio_data_s { typedef struct ide_pio_data_s {