Commit 16ba73f3 authored by Alan Cox's avatar Alan Cox Committed by Linus Torvalds

[PATCH] ide-proc - fix crash on identify

We cannot do an identify on a drive with no driver loaded. The kernel
has a ton of half backed "if no driver" cases but they dont cover all
cases and its a mess.

For now we rely on the probe time identify unless a driver is loaded. A
proper fix (an 'ide-unassigned' driver) will follow later
parent 989e85fa
...@@ -407,20 +407,40 @@ int proc_ide_read_identify ...@@ -407,20 +407,40 @@ int proc_ide_read_identify
{ {
ide_drive_t *drive = (ide_drive_t *)data; ide_drive_t *drive = (ide_drive_t *)data;
int len = 0, i = 0; int len = 0, i = 0;
int err = 0;
if (drive && !taskfile_lib_get_identify(drive, page)) { len = sprintf(page, "\n");
if (drive)
{
unsigned short *val = (unsigned short *) page; unsigned short *val = (unsigned short *) page;
char *out = ((char *)val) + (SECTOR_WORDS * 4);
page = out; /*
do { * The current code can't handle a driverless
out += sprintf(out, "%04x%c", * identify query taskfile. Now the right fix is
le16_to_cpu(*val), (++i & 7) ? ' ' : '\n'); * to add a 'default' driver but that is a bit
val += 1; * more work.
} while (i < (SECTOR_WORDS * 2)); *
len = out - page; * FIXME: this has to be fixed for hotswap devices
*/
if(DRIVER(drive))
err = taskfile_lib_get_identify(drive, page);
else /* This relies on the ID changes */
val = (unsigned short *)drive->id;
if(!err)
{
char *out = ((char *)page) + (SECTOR_WORDS * 4);
page = out;
do {
out += sprintf(out, "%04x%c",
le16_to_cpu(*val), (++i & 7) ? ' ' : '\n');
val += 1;
} while (i < (SECTOR_WORDS * 2));
len = out - page;
}
} }
else
len = sprintf(page, "\n");
PROC_IDE_READ_RETURN(page,start,off,count,eof,len); PROC_IDE_READ_RETURN(page,start,off,count,eof,len);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment