aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--block/genhd.c16
-rw-r--r--drivers/ide/ide-cd.c2
-rw-r--r--drivers/md/dm-ioctl.c2
-rw-r--r--fs/partitions/check.c2
-rw-r--r--include/linux/genhd.h6
5 files changed, 13 insertions, 15 deletions
diff --git a/block/genhd.c b/block/genhd.c
index c70db35076a0..70358f3c7423 100644
--- a/block/genhd.c
+++ b/block/genhd.c
@@ -757,7 +757,7 @@ static ssize_t disk_ro_show(struct device *dev,
757{ 757{
758 struct gendisk *disk = dev_to_disk(dev); 758 struct gendisk *disk = dev_to_disk(dev);
759 759
760 return sprintf(buf, "%d\n", disk->policy ? 1 : 0); 760 return sprintf(buf, "%d\n", get_disk_ro(disk) ? 1 : 0);
761} 761}
762 762
763static ssize_t disk_capability_show(struct device *dev, 763static ssize_t disk_capability_show(struct device *dev,
@@ -1090,10 +1090,7 @@ EXPORT_SYMBOL(put_disk);
1090 1090
1091void set_device_ro(struct block_device *bdev, int flag) 1091void set_device_ro(struct block_device *bdev, int flag)
1092{ 1092{
1093 if (bdev->bd_contains != bdev) 1093 bdev->bd_part->policy = flag;
1094 bdev->bd_part->policy = flag;
1095 else
1096 bdev->bd_disk->policy = flag;
1097} 1094}
1098 1095
1099EXPORT_SYMBOL(set_device_ro); 1096EXPORT_SYMBOL(set_device_ro);
@@ -1103,8 +1100,8 @@ void set_disk_ro(struct gendisk *disk, int flag)
1103 struct disk_part_iter piter; 1100 struct disk_part_iter piter;
1104 struct hd_struct *part; 1101 struct hd_struct *part;
1105 1102
1106 disk->policy = flag; 1103 disk_part_iter_init(&piter, disk,
1107 disk_part_iter_init(&piter, disk, DISK_PITER_INCL_EMPTY); 1104 DISK_PITER_INCL_EMPTY | DISK_PITER_INCL_PART0);
1108 while ((part = disk_part_iter_next(&piter))) 1105 while ((part = disk_part_iter_next(&piter)))
1109 part->policy = flag; 1106 part->policy = flag;
1110 disk_part_iter_exit(&piter); 1107 disk_part_iter_exit(&piter);
@@ -1116,10 +1113,7 @@ int bdev_read_only(struct block_device *bdev)
1116{ 1113{
1117 if (!bdev) 1114 if (!bdev)
1118 return 0; 1115 return 0;
1119 else if (bdev->bd_contains != bdev) 1116 return bdev->bd_part->policy;
1120 return bdev->bd_part->policy;
1121 else
1122 return bdev->bd_disk->policy;
1123} 1117}
1124 1118
1125EXPORT_SYMBOL(bdev_read_only); 1119EXPORT_SYMBOL(bdev_read_only);
diff --git a/drivers/ide/ide-cd.c b/drivers/ide/ide-cd.c
index f16bb4667238..03c2cb6a58bc 100644
--- a/drivers/ide/ide-cd.c
+++ b/drivers/ide/ide-cd.c
@@ -1113,7 +1113,7 @@ static ide_startstop_t cdrom_start_rw(ide_drive_t *drive, struct request *rq)
1113 1113
1114 if (write) { 1114 if (write) {
1115 /* disk has become write protected */ 1115 /* disk has become write protected */
1116 if (cd->disk->policy) { 1116 if (get_disk_ro(cd->disk)) {
1117 cdrom_end_request(drive, 0); 1117 cdrom_end_request(drive, 0);
1118 return ide_stopped; 1118 return ide_stopped;
1119 } 1119 }
diff --git a/drivers/md/dm-ioctl.c b/drivers/md/dm-ioctl.c
index c3de311117a1..5b919159f084 100644
--- a/drivers/md/dm-ioctl.c
+++ b/drivers/md/dm-ioctl.c
@@ -548,7 +548,7 @@ static int __dev_status(struct mapped_device *md, struct dm_ioctl *param)
548 */ 548 */
549 param->open_count = dm_open_count(md); 549 param->open_count = dm_open_count(md);
550 550
551 if (disk->policy) 551 if (get_disk_ro(disk))
552 param->flags |= DM_READONLY_FLAG; 552 param->flags |= DM_READONLY_FLAG;
553 553
554 param->event_nr = dm_get_event_nr(md); 554 param->event_nr = dm_get_event_nr(md);
diff --git a/fs/partitions/check.c b/fs/partitions/check.c
index 24d2c56d7d2d..ace6d03602c7 100644
--- a/fs/partitions/check.c
+++ b/fs/partitions/check.c
@@ -375,7 +375,7 @@ int add_partition(struct gendisk *disk, int partno,
375 p->start_sect = start; 375 p->start_sect = start;
376 p->nr_sects = len; 376 p->nr_sects = len;
377 p->partno = partno; 377 p->partno = partno;
378 p->policy = disk->policy; 378 p->policy = get_disk_ro(disk);
379 379
380 dname = dev_name(ddev); 380 dname = dev_name(ddev);
381 if (isdigit(dname[strlen(dname) - 1])) 381 if (isdigit(dname[strlen(dname) - 1]))
diff --git a/include/linux/genhd.h b/include/linux/genhd.h
index 9cb8380cf0eb..4411bdd671dd 100644
--- a/include/linux/genhd.h
+++ b/include/linux/genhd.h
@@ -145,7 +145,6 @@ struct gendisk {
145 struct kobject *slave_dir; 145 struct kobject *slave_dir;
146 146
147 struct timer_rand_state *random; 147 struct timer_rand_state *random;
148 int policy;
149 148
150 atomic_t sync_io; /* RAID */ 149 atomic_t sync_io; /* RAID */
151 unsigned long stamp; 150 unsigned long stamp;
@@ -403,6 +402,11 @@ extern struct block_device *bdget_disk(struct gendisk *disk, int partno);
403extern void set_device_ro(struct block_device *bdev, int flag); 402extern void set_device_ro(struct block_device *bdev, int flag);
404extern void set_disk_ro(struct gendisk *disk, int flag); 403extern void set_disk_ro(struct gendisk *disk, int flag);
405 404
405static inline int get_disk_ro(struct gendisk *disk)
406{
407 return disk->part0.policy;
408}
409
406/* drivers/char/random.c */ 410/* drivers/char/random.c */
407extern void add_disk_randomness(struct gendisk *disk); 411extern void add_disk_randomness(struct gendisk *disk);
408extern void rand_initialize_disk(struct gendisk *disk); 412extern void rand_initialize_disk(struct gendisk *disk);