aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Documentation/ide/ide.txt31
-rw-r--r--drivers/ide/ide.c71
2 files changed, 80 insertions, 22 deletions
diff --git a/Documentation/ide/ide.txt b/Documentation/ide/ide.txt
index 5bff93c89a23..caf24b21e7f5 100644
--- a/Documentation/ide/ide.txt
+++ b/Documentation/ide/ide.txt
@@ -82,17 +82,16 @@ Drives are normally found by auto-probing and/or examining the CMOS/BIOS data.
82For really weird situations, the apparent (fdisk) geometry can also be specified 82For really weird situations, the apparent (fdisk) geometry can also be specified
83on the kernel "command line" using LILO. The format of such lines is: 83on the kernel "command line" using LILO. The format of such lines is:
84 84
85 hdx=cyls,heads,sects 85 ide_core.chs=[interface_number.device_number]:cyls,heads,sects
86or hdx=cdrom 86or ide_core.cdrom=[interface_number.device_number]
87 87
88where hdx can be any of hda through hdh, Three values are required 88For example:
89(cyls,heads,sects). For example:
90 89
91 hdc=1050,32,64 hdd=cdrom 90 ide_core.chs=1.0:1050,32,64 ide_core.cdrom=1.1
92 91
93either {hda,hdb} or {hdc,hdd}. The results of successful auto-probing may 92The results of successful auto-probing may override the physical geometry/irq
94override the physical geometry/irq specified, though the "original" geometry 93specified, though the "original" geometry may be retained as the "logical"
95may be retained as the "logical" geometry for partitioning purposes (fdisk). 94geometry for partitioning purposes (fdisk).
96 95
97If the auto-probing during boot time confuses a drive (ie. the drive works 96If the auto-probing during boot time confuses a drive (ie. the drive works
98with hd.c but not with ide.c), then an command line option may be specified 97with hd.c but not with ide.c), then an command line option may be specified
@@ -101,7 +100,7 @@ probe/identification sequence. For example:
101 100
102 ide_core.noprobe=0.1 101 ide_core.noprobe=0.1
103or 102or
104 hdc=768,16,32 103 ide_core.chs=1.0:768,16,32
105 ide_core.noprobe=1.0 104 ide_core.noprobe=1.0
106 105
107Note that when only one IDE device is attached to an interface, it should be 106Note that when only one IDE device is attached to an interface, it should be
@@ -118,9 +117,9 @@ If for some reason your cdrom drive is *not* found at boot time, you can force
118the probe to look harder by supplying a kernel command line parameter 117the probe to look harder by supplying a kernel command line parameter
119via LILO, such as: 118via LILO, such as:
120 119
121 hdc=cdrom /* hdc = "master" on second interface */ 120 ide_core.cdrom=1.0 /* "master" on second interface (hdc) */
122or 121or
123 hdd=cdrom /* hdd = "slave" on second interface */ 122 ide_core.cdrom=1.1 /* "slave" on second interface (hdd) */
124 123
125For example, a GW2000 system might have a hard drive on the primary 124For example, a GW2000 system might have a hard drive on the primary
126interface (/dev/hda) and an IDE cdrom drive on the secondary interface 125interface (/dev/hda) and an IDE cdrom drive on the secondary interface
@@ -182,12 +181,6 @@ driver using the "options=" keyword to insmod, while replacing any ',' with
182Summary of ide driver parameters for kernel command line 181Summary of ide driver parameters for kernel command line
183-------------------------------------------------------- 182--------------------------------------------------------
184 183
185 "hdx=" is recognized for all "x" from "a" to "u", such as "hdc".
186
187 "hdx=cdrom" : drive is present, and is a cdrom drive
188
189 "hdx=cyl,head,sect" : disk drive is present, with specified geometry
190
191 "ide=doubler" : probe/support IDE doublers on Amiga 184 "ide=doubler" : probe/support IDE doublers on Amiga
192 185
193There may be more options than shown -- use the source, Luke! 186There may be more options than shown -- use the source, Luke!
@@ -230,6 +223,10 @@ Other kernel parameters for ide_core are:
230 223
231* "nowerr=[interface_number.device_number]" to ignore the WRERR_STAT bit 224* "nowerr=[interface_number.device_number]" to ignore the WRERR_STAT bit
232 225
226* "cdrom=[interface_number.device_number]" to force device as a CD-ROM
227
228* "chs=[interface_number.device_number]" to force device as a disk (using CHS)
229
233================================================================================ 230================================================================================
234 231
235Some Terminology 232Some Terminology
diff --git a/drivers/ide/ide.c b/drivers/ide/ide.c
index d8f40ee74ce8..a4bceeecde70 100644
--- a/drivers/ide/ide.c
+++ b/drivers/ide/ide.c
@@ -924,7 +924,7 @@ static int __init ide_setup(char *s)
924 drive->media = ide_cdrom; 924 drive->media = ide_cdrom;
925 /* an ATAPI device ignores DRDY */ 925 /* an ATAPI device ignores DRDY */
926 drive->ready_stat = 0; 926 drive->ready_stat = 0;
927 goto done; 927 goto obsolete_option;
928 case -5: /* nodma */ 928 case -5: /* nodma */
929 drive->nodma = 1; 929 drive->nodma = 1;
930 goto obsolete_option; 930 goto obsolete_option;
@@ -948,7 +948,7 @@ static int __init ide_setup(char *s)
948 drive->sect = drive->bios_sect = vals[2]; 948 drive->sect = drive->bios_sect = vals[2];
949 drive->present = 1; 949 drive->present = 1;
950 drive->forced_geom = 1; 950 drive->forced_geom = 1;
951 goto done; 951 goto obsolete_option;
952 default: 952 default:
953 goto bad_option; 953 goto bad_option;
954 } 954 }
@@ -975,9 +975,6 @@ bad_option:
975obsolete_option: 975obsolete_option:
976 printk(" -- OBSOLETE OPTION, WILL BE REMOVED SOON!\n"); 976 printk(" -- OBSOLETE OPTION, WILL BE REMOVED SOON!\n");
977 return 1; 977 return 1;
978done:
979 printk("\n");
980 return 1;
981} 978}
982 979
983EXPORT_SYMBOL(ide_lock); 980EXPORT_SYMBOL(ide_lock);
@@ -1167,6 +1164,51 @@ static unsigned int ide_nowerr;
1167module_param_call(nowerr, ide_set_dev_param_mask, NULL, &ide_nowerr, 0); 1164module_param_call(nowerr, ide_set_dev_param_mask, NULL, &ide_nowerr, 0);
1168MODULE_PARM_DESC(nowerr, "ignore the WRERR_STAT bit for a device"); 1165MODULE_PARM_DESC(nowerr, "ignore the WRERR_STAT bit for a device");
1169 1166
1167static unsigned int ide_cdroms;
1168
1169module_param_call(cdrom, ide_set_dev_param_mask, NULL, &ide_cdroms, 0);
1170MODULE_PARM_DESC(cdrom, "force device as a CD-ROM");
1171
1172struct chs_geom {
1173 unsigned int cyl;
1174 u8 head;
1175 u8 sect;
1176};
1177
1178static unsigned int ide_disks;
1179static struct chs_geom ide_disks_chs[MAX_HWIFS * MAX_DRIVES];
1180
1181static int ide_set_disk_chs(const char *str, struct kernel_param *kp)
1182{
1183 int a, b, c = 0, h = 0, s = 0, i, j = 1;
1184
1185 if (sscanf(str, "%d.%d:%d,%d,%d", &a, &b, &c, &h, &s) != 5 &&
1186 sscanf(str, "%d.%d:%d", &a, &b, &j) != 3)
1187 return -EINVAL;
1188
1189 i = a * MAX_DRIVES + b;
1190
1191 if (i >= MAX_HWIFS * MAX_DRIVES || j < 0 || j > 1)
1192 return -EINVAL;
1193
1194 if (c > INT_MAX || h > 255 || s > 255)
1195 return -EINVAL;
1196
1197 if (j)
1198 ide_disks |= (1 << i);
1199 else
1200 ide_disks &= (1 << i);
1201
1202 ide_disks_chs[i].cyl = c;
1203 ide_disks_chs[i].head = h;
1204 ide_disks_chs[i].sect = s;
1205
1206 return 0;
1207}
1208
1209module_param_call(chs, ide_set_disk_chs, NULL, NULL, 0);
1210MODULE_PARM_DESC(chs, "force device as a disk (using CHS)");
1211
1170static void ide_dev_apply_params(ide_drive_t *drive) 1212static void ide_dev_apply_params(ide_drive_t *drive)
1171{ 1213{
1172 int i = drive->hwif->index * MAX_DRIVES + drive->select.b.unit; 1214 int i = drive->hwif->index * MAX_DRIVES + drive->select.b.unit;
@@ -1189,6 +1231,25 @@ static void ide_dev_apply_params(ide_drive_t *drive)
1189 drive->name); 1231 drive->name);
1190 drive->bad_wstat = BAD_R_STAT; 1232 drive->bad_wstat = BAD_R_STAT;
1191 } 1233 }
1234 if (ide_cdroms & (1 << i)) {
1235 printk(KERN_INFO "ide: forcing %s as a CD-ROM\n", drive->name);
1236 drive->present = 1;
1237 drive->media = ide_cdrom;
1238 /* an ATAPI device ignores DRDY */
1239 drive->ready_stat = 0;
1240 }
1241 if (ide_disks & (1 << i)) {
1242 drive->cyl = drive->bios_cyl = ide_disks_chs[i].cyl;
1243 drive->head = drive->bios_head = ide_disks_chs[i].head;
1244 drive->sect = drive->bios_sect = ide_disks_chs[i].sect;
1245 drive->forced_geom = 1;
1246 printk(KERN_INFO "ide: forcing %s as a disk (%d/%d/%d)\n",
1247 drive->name,
1248 drive->cyl, drive->head, drive->sect);
1249 drive->present = 1;
1250 drive->media = ide_disk;
1251 drive->ready_stat = READY_STAT;
1252 }
1192} 1253}
1193 1254
1194static unsigned int ide_ignore_cable; 1255static unsigned int ide_ignore_cable;