diff options
author | Tejun Heo <tj@kernel.org> | 2008-08-25 06:56:05 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2008-10-09 02:56:07 -0400 |
commit | ed9e1982347b36573cd622ee5f4e2a7ccd79b3fd (patch) | |
tree | 79d834094d655ec97cfc0a382a9207ebc8e711a5 /include/linux/genhd.h | |
parent | 870d6656126add8e383645732b03df2b7ccd4f94 (diff) |
block: implement and use {disk|part}_to_dev()
Implement {disk|part}_to_dev() and use them to access generic device
instead of directly dereferencing {disk|part}->dev. To make sure no
user is left behind, rename generic devices fields to __dev.
This is in preparation of unifying partition 0 handling with other
partitions.
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
Diffstat (limited to 'include/linux/genhd.h')
-rw-r--r-- | include/linux/genhd.h | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/include/linux/genhd.h b/include/linux/genhd.h index 6fc532424062..e4e18c509ac5 100644 --- a/include/linux/genhd.h +++ b/include/linux/genhd.h | |||
@@ -15,9 +15,11 @@ | |||
15 | 15 | ||
16 | #ifdef CONFIG_BLOCK | 16 | #ifdef CONFIG_BLOCK |
17 | 17 | ||
18 | #define kobj_to_dev(k) container_of(k, struct device, kobj) | 18 | #define kobj_to_dev(k) container_of((k), struct device, kobj) |
19 | #define dev_to_disk(device) container_of(device, struct gendisk, dev) | 19 | #define dev_to_disk(device) container_of((device), struct gendisk, __dev) |
20 | #define dev_to_part(device) container_of(device, struct hd_struct, dev) | 20 | #define dev_to_part(device) container_of((device), struct hd_struct, __dev) |
21 | #define disk_to_dev(disk) (&((disk)->__dev)) | ||
22 | #define part_to_dev(part) (&((part)->__dev)) | ||
21 | 23 | ||
22 | extern struct device_type part_type; | 24 | extern struct device_type part_type; |
23 | extern struct kobject *block_depr; | 25 | extern struct kobject *block_depr; |
@@ -88,7 +90,7 @@ struct disk_stats { | |||
88 | struct hd_struct { | 90 | struct hd_struct { |
89 | sector_t start_sect; | 91 | sector_t start_sect; |
90 | sector_t nr_sects; | 92 | sector_t nr_sects; |
91 | struct device dev; | 93 | struct device __dev; |
92 | struct kobject *holder_dir; | 94 | struct kobject *holder_dir; |
93 | int policy, partno; | 95 | int policy, partno; |
94 | #ifdef CONFIG_FAIL_MAKE_REQUEST | 96 | #ifdef CONFIG_FAIL_MAKE_REQUEST |
@@ -139,7 +141,7 @@ struct gendisk { | |||
139 | 141 | ||
140 | int flags; | 142 | int flags; |
141 | struct device *driverfs_dev; // FIXME: remove | 143 | struct device *driverfs_dev; // FIXME: remove |
142 | struct device dev; | 144 | struct device __dev; |
143 | struct kobject *holder_dir; | 145 | struct kobject *holder_dir; |
144 | struct kobject *slave_dir; | 146 | struct kobject *slave_dir; |
145 | 147 | ||
@@ -163,7 +165,7 @@ struct gendisk { | |||
163 | static inline struct gendisk *part_to_disk(struct hd_struct *part) | 165 | static inline struct gendisk *part_to_disk(struct hd_struct *part) |
164 | { | 166 | { |
165 | if (likely(part)) | 167 | if (likely(part)) |
166 | return dev_to_disk((part)->dev.parent); | 168 | return dev_to_disk(part_to_dev(part)->parent); |
167 | return NULL; | 169 | return NULL; |
168 | } | 170 | } |
169 | 171 | ||
@@ -174,12 +176,12 @@ static inline int disk_max_parts(struct gendisk *disk) | |||
174 | 176 | ||
175 | static inline dev_t disk_devt(struct gendisk *disk) | 177 | static inline dev_t disk_devt(struct gendisk *disk) |
176 | { | 178 | { |
177 | return disk->dev.devt; | 179 | return disk_to_dev(disk)->devt; |
178 | } | 180 | } |
179 | 181 | ||
180 | static inline dev_t part_devt(struct hd_struct *part) | 182 | static inline dev_t part_devt(struct hd_struct *part) |
181 | { | 183 | { |
182 | return part->dev.devt; | 184 | return part_to_dev(part)->devt; |
183 | } | 185 | } |
184 | 186 | ||
185 | extern struct hd_struct *disk_get_part(struct gendisk *disk, int partno); | 187 | extern struct hd_struct *disk_get_part(struct gendisk *disk, int partno); |
@@ -187,7 +189,7 @@ extern struct hd_struct *disk_get_part(struct gendisk *disk, int partno); | |||
187 | static inline void disk_put_part(struct hd_struct *part) | 189 | static inline void disk_put_part(struct hd_struct *part) |
188 | { | 190 | { |
189 | if (likely(part)) | 191 | if (likely(part)) |
190 | put_device(&part->dev); | 192 | put_device(part_to_dev(part)); |
191 | } | 193 | } |
192 | 194 | ||
193 | /* | 195 | /* |