aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/ide.c')
-rw-r--r--drivers/ide/ide.c71
1 files changed, 1 insertions, 70 deletions
diff --git a/drivers/ide/ide.c b/drivers/ide/ide.c
index 8823df1b8716..f65be738b16a 100644
--- a/drivers/ide/ide.c
+++ b/drivers/ide/ide.c
@@ -86,9 +86,6 @@ static const u8 ide_hwif_to_major[] = { IDE0_MAJOR, IDE1_MAJOR,
86 IDE6_MAJOR, IDE7_MAJOR, 86 IDE6_MAJOR, IDE7_MAJOR,
87 IDE8_MAJOR, IDE9_MAJOR }; 87 IDE8_MAJOR, IDE9_MAJOR };
88 88
89static int idebus_parameter; /* holds the "idebus=" parameter */
90static int system_bus_speed; /* holds what we think is VESA/PCI bus speed */
91
92DEFINE_MUTEX(ide_cfg_mtx); 89DEFINE_MUTEX(ide_cfg_mtx);
93 __cacheline_aligned_in_smp DEFINE_SPINLOCK(ide_lock); 90 __cacheline_aligned_in_smp DEFINE_SPINLOCK(ide_lock);
94 91
@@ -189,38 +186,6 @@ static void __init init_ide_data (void)
189 } 186 }
190} 187}
191 188
192/**
193 * ide_system_bus_speed - guess bus speed
194 *
195 * ide_system_bus_speed() returns what we think is the system VESA/PCI
196 * bus speed (in MHz). This is used for calculating interface PIO timings.
197 * The default is 40 for known PCI systems, 50 otherwise.
198 * The "idebus=xx" parameter can be used to override this value.
199 * The actual value to be used is computed/displayed the first time
200 * through. Drivers should only use this as a last resort.
201 *
202 * Returns a guessed speed in MHz.
203 */
204
205static int ide_system_bus_speed(void)
206{
207#ifdef CONFIG_PCI
208 static struct pci_device_id pci_default[] = {
209 { PCI_DEVICE(PCI_ANY_ID, PCI_ANY_ID) },
210 { }
211 };
212#else
213#define pci_default 0
214#endif /* CONFIG_PCI */
215
216 /* user supplied value */
217 if (idebus_parameter)
218 return idebus_parameter;
219
220 /* safe default value for PCI or VESA and PCI*/
221 return pci_dev_present(pci_default) ? 33 : 50;
222}
223
224void ide_remove_port_from_hwgroup(ide_hwif_t *hwif) 189void ide_remove_port_from_hwgroup(ide_hwif_t *hwif)
225{ 190{
226 ide_hwgroup_t *hwgroup = hwif->hwgroup; 191 ide_hwgroup_t *hwgroup = hwif->hwgroup;
@@ -540,20 +505,6 @@ static int set_unmaskirq(ide_drive_t *drive, int arg)
540 return 0; 505 return 0;
541} 506}
542 507
543/**
544 * system_bus_clock - clock guess
545 *
546 * External version of the bus clock guess used by very old IDE drivers
547 * for things like VLB timings. Should not be used.
548 */
549
550int system_bus_clock (void)
551{
552 return system_bus_speed;
553}
554
555EXPORT_SYMBOL(system_bus_clock);
556
557static int generic_ide_suspend(struct device *dev, pm_message_t mesg) 508static int generic_ide_suspend(struct device *dev, pm_message_t mesg)
558{ 509{
559 ide_drive_t *drive = dev->driver_data; 510 ide_drive_t *drive = dev->driver_data;
@@ -851,7 +802,7 @@ static int __init ide_setup(char *s)
851 if (strncmp(s,"hd",2) == 0 && s[2] == '=') /* hd= is for hd.c */ 802 if (strncmp(s,"hd",2) == 0 && s[2] == '=') /* hd= is for hd.c */
852 return 0; /* driver and not us */ 803 return 0; /* driver and not us */
853 804
854 if (strncmp(s,"ide",3) && strncmp(s,"idebus",6) && strncmp(s,"hd",2)) 805 if (strncmp(s, "ide", 3) && strncmp(s, "hd", 2))
855 return 0; 806 return 0;
856 807
857 printk(KERN_INFO "ide_setup: %s", s); 808 printk(KERN_INFO "ide_setup: %s", s);
@@ -951,21 +902,6 @@ static int __init ide_setup(char *s)
951 } 902 }
952 } 903 }
953 904
954 if (s[0] != 'i' || s[1] != 'd' || s[2] != 'e')
955 goto bad_option;
956 /*
957 * Look for bus speed option: "idebus="
958 */
959 if (s[3] == 'b' && s[4] == 'u' && s[5] == 's') {
960 if (match_parm(&s[6], NULL, vals, 1) != 1)
961 goto bad_option;
962 if (vals[0] >= 20 && vals[0] <= 66) {
963 idebus_parameter = vals[0];
964 } else
965 printk(" -- BAD BUS SPEED! Expected value from 20 to 66");
966 goto obsolete_option;
967 }
968
969bad_option: 905bad_option:
970 printk(" -- BAD OPTION\n"); 906 printk(" -- BAD OPTION\n");
971 return 1; 907 return 1;
@@ -1287,11 +1223,6 @@ static int __init ide_init(void)
1287 int ret; 1223 int ret;
1288 1224
1289 printk(KERN_INFO "Uniform Multi-Platform E-IDE driver\n"); 1225 printk(KERN_INFO "Uniform Multi-Platform E-IDE driver\n");
1290 system_bus_speed = ide_system_bus_speed();
1291
1292 printk(KERN_INFO "ide: Assuming %dMHz system bus speed "
1293 "for PIO modes%s\n", system_bus_speed,
1294 idebus_parameter ? "" : "; override with idebus=xx");
1295 1226
1296 ret = bus_register(&ide_bus_type); 1227 ret = bus_register(&ide_bus_type);
1297 if (ret < 0) { 1228 if (ret < 0) {