diff options
author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2006-12-08 05:36:14 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.osdl.org> | 2006-12-08 11:28:38 -0500 |
commit | 35a6027f1ab6594068cb8bca7705e4567753946b (patch) | |
tree | 43c4a501343b5d1531b2043408061f5f03d96ae6 /fs/block_dev.c | |
parent | 2e7b651df113c8a463853e4169951c52c39f9d19 (diff) |
[PATCH] new bd_mutex lockdep annotation
Use the gendisk partition number to set a lock class.
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Neil Brown <neilb@cse.unsw.edu.au>
Cc: Ingo Molnar <mingo@elte.hu>
Acked-by: Arjan van de Ven <arjan@linux.intel.com>
Cc: Jason Baron <jbaron@redhat.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'fs/block_dev.c')
-rw-r--r-- | fs/block_dev.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/fs/block_dev.c b/fs/block_dev.c index 36c38f48a4ed..528cf053ce96 100644 --- a/fs/block_dev.c +++ b/fs/block_dev.c | |||
@@ -355,10 +355,14 @@ static int bdev_set(struct inode *inode, void *data) | |||
355 | 355 | ||
356 | static LIST_HEAD(all_bdevs); | 356 | static LIST_HEAD(all_bdevs); |
357 | 357 | ||
358 | static struct lock_class_key bdev_part_lock_key; | ||
359 | |||
358 | struct block_device *bdget(dev_t dev) | 360 | struct block_device *bdget(dev_t dev) |
359 | { | 361 | { |
360 | struct block_device *bdev; | 362 | struct block_device *bdev; |
361 | struct inode *inode; | 363 | struct inode *inode; |
364 | struct gendisk *disk; | ||
365 | int part = 0; | ||
362 | 366 | ||
363 | inode = iget5_locked(bd_mnt->mnt_sb, hash(dev), | 367 | inode = iget5_locked(bd_mnt->mnt_sb, hash(dev), |
364 | bdev_test, bdev_set, &dev); | 368 | bdev_test, bdev_set, &dev); |
@@ -384,6 +388,11 @@ struct block_device *bdget(dev_t dev) | |||
384 | list_add(&bdev->bd_list, &all_bdevs); | 388 | list_add(&bdev->bd_list, &all_bdevs); |
385 | spin_unlock(&bdev_lock); | 389 | spin_unlock(&bdev_lock); |
386 | unlock_new_inode(inode); | 390 | unlock_new_inode(inode); |
391 | mutex_init(&bdev->bd_mutex); | ||
392 | disk = get_gendisk(dev, &part); | ||
393 | if (part) | ||
394 | lockdep_set_class(&bdev->bd_mutex, &bdev_part_lock_key); | ||
395 | put_disk(disk); | ||
387 | } | 396 | } |
388 | return bdev; | 397 | return bdev; |
389 | } | 398 | } |