diff options
author | Tejun Heo <tj@kernel.org> | 2008-09-01 02:55:10 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2008-09-01 02:55:10 -0400 |
commit | ddef43a843f620c6742a06633739887a901ec06b (patch) | |
tree | 25eec6c04abf5c7ec3cb9aba2338d249844ffb61 | |
parent | bb23b431db7405f6d79f989ad0236bf6428ba1cb (diff) |
block: restore original behavior of /proc/partition when there's no partition
/proc/partitions didn't use to write out the header if there was no
partition. However, recent commit 66c64afe changed the behavior.
This is nothing major but there's no reason to change user visible
behavior without a good rationale. Restore the original behavior.
Note that 2.6.28 has clean up changes scheduled which will replace
this rather hacky implementation.
Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Greg KH <greg@kroah.com>
Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
-rw-r--r-- | block/genhd.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/block/genhd.c b/block/genhd.c index d9743ff67898..e0ce23ac2ece 100644 --- a/block/genhd.c +++ b/block/genhd.c | |||
@@ -307,7 +307,7 @@ static void *part_start(struct seq_file *part, loff_t *pos) | |||
307 | loff_t k = *pos; | 307 | loff_t k = *pos; |
308 | 308 | ||
309 | if (!k) | 309 | if (!k) |
310 | seq_puts(part, "major minor #blocks name\n\n"); | 310 | part->private = (void *)1LU; /* tell show to print header */ |
311 | 311 | ||
312 | mutex_lock(&block_class_lock); | 312 | mutex_lock(&block_class_lock); |
313 | dev = class_find_device(&block_class, NULL, &k, find_start); | 313 | dev = class_find_device(&block_class, NULL, &k, find_start); |
@@ -349,6 +349,17 @@ static int show_partition(struct seq_file *part, void *v) | |||
349 | int n; | 349 | int n; |
350 | char buf[BDEVNAME_SIZE]; | 350 | char buf[BDEVNAME_SIZE]; |
351 | 351 | ||
352 | /* | ||
353 | * Print header if start told us to do. This is to preserve | ||
354 | * the original behavior of not printing header if no | ||
355 | * partition exists. This hackery will be removed later with | ||
356 | * class iteration clean up. | ||
357 | */ | ||
358 | if (part->private) { | ||
359 | seq_puts(part, "major minor #blocks name\n\n"); | ||
360 | part->private = NULL; | ||
361 | } | ||
362 | |||
352 | /* Don't show non-partitionable removeable devices or empty devices */ | 363 | /* Don't show non-partitionable removeable devices or empty devices */ |
353 | if (!get_capacity(sgp) || | 364 | if (!get_capacity(sgp) || |
354 | (sgp->minors == 1 && (sgp->flags & GENHD_FL_REMOVABLE))) | 365 | (sgp->minors == 1 && (sgp->flags & GENHD_FL_REMOVABLE))) |