All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH][2.5.75] fix removable partitioned media with devfs
@ 2003-07-13 14:38 Andrey Borzenkov
  0 siblings, 0 replies; only message in thread
From: Andrey Borzenkov @ 2003-07-13 14:38 UTC (permalink / raw)
  To: linux-kernel; +Cc: devfs

[-- Attachment #1: Type: text/plain, Size: 1148 bytes --]

Current 2.5 does not register any device node in devfs for empty media 
(capacity == 0) case. This makes removables unusable with devfs. Partition 
rescan is done only on bdev open, but without any device node for device it 
is impossible to open it.

In 2.4 it was finally solved by always registering .../disc node as 
representation for "whole" disk and using devfsd action to force partition 
rescan on access to (non-existing) partition name. For primary names it was 
handled internally by devfs - it kept track of removable devices in directory 
and initiated partition rescan when name was not found.

Both are obviously broken now. You can't do partition rescan because no node 
is registered at all and internal handling was removed. Very nice.

The attached patch makes resgister_disk always register at least disc node. 
This now works for old and new compat names as per devfsd configuration; 
canonical names are still broken:

{pts/3}% ll /dev/scsi/host1/bus0/target4/lun0/part4
ls: /dev/scsi/host1/bus0/target4/lun0/part4: No such file or directory

but it can be fixed using the same technique as above so I won't push it.

-andrey

[-- Attachment #2: 2.5.75-removable_media_with_devfs.patch --]
[-- Type: text/x-diff, Size: 709 bytes --]

--- linux-2.5.75-smp/fs/partitions/check.c.removable	2003-06-26 21:41:24.000000000 +0400
+++ linux-2.5.75-smp/fs/partitions/check.c	2003-07-13 17:20:16.000000000 +0400
@@ -348,6 +348,9 @@ void register_disk(struct gendisk *disk)
 		return;
 	}
 
+	/* always add handle for the whole disk */
+	devfs_add_partitioned(disk);
+
 	/* No such device (e.g., media were just removed) */
 	if (!get_capacity(disk))
 		return;
@@ -356,7 +359,6 @@ void register_disk(struct gendisk *disk)
 	if (blkdev_get(bdev, FMODE_READ, 0, BDEV_RAW) < 0)
 		return;
 	state = check_partition(disk, bdev);
-	devfs_add_partitioned(disk);
 	if (state) {
 		for (j = 1; j < state->limit; j++) {
 			sector_t size = state->parts[j].size;

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2003-07-13 14:59 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-07-13 14:38 [PATCH][2.5.75] fix removable partitioned media with devfs Andrey Borzenkov

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.