[prev in list] [next in list] [prev in thread] [next in thread]
List: linux-ide
Subject: [PATCH] ide-floppy: Fix unformatted media crash
From: Alan <alan () lxorguk ! ukuu ! org ! uk>
Date: 2007-01-31 17:41:23
Message-ID: 20070131174123.17aba9d1 () localhost ! localdomain
[Download RAW message or body]
A ZIP or similar with unformatted media will cause crashes when attempts
are made to read/write it in some cases. This is because bs_factor is
zero and we divide by it causing an oops.
As the size of a non-accessible/non-existant media is really a bit of a
zen question it doesn't matter if non-existant media is 512 bytes per
sector or zero. Setting it to 1 causes us to generate 512 bytes/sector
accesses and error properly.
Signed-off-by: Alan Cox <alan@redhat.com>
Based on a fix found lurking in an ancient bugzilla entry since about 2004 (ugghhh)
diff -u --new-file --recursive --exclude-from /usr/src/exclude \
linux.vanilla-2.6.20-rc6-mm3/drivers/ide/ide-floppy.c \
linux-2.6.20-rc6-mm3/drivers/ide/ide-floppy.c
--- linux.vanilla-2.6.20-rc6-mm3/drivers/ide/ide-floppy.c 2007-01-31 \
14:20:40.000000000 +0000
+++ linux-2.6.20-rc6-mm3/drivers/ide/ide-floppy.c 2007-01-31 14:33:42.000000000 +0000
@@ -1434,7 +1434,8 @@
drive->bios_cyl = 0;
drive->bios_head = drive->bios_sect = 0;
- floppy->blocks = floppy->bs_factor = 0;
+ floppy->blocks = 0;
+ floppy->bs_factor = 1;
set_capacity(floppy->disk, 0);
idefloppy_create_read_capacity_cmd(&pc);
-
To unsubscribe from this list: send the line "unsubscribe linux-ide" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic