[PATCH] sem2mutex: drivers/md

Semaphore to mutex conversion.

The conversion was generated via scripts, and the result was validated
automatically via a script as well.

Signed-off-by: Arjan van de Ven <arjan@infradead.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Cc: Neil Brown <neilb@cse.unsw.edu.au>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
Arjan van de Ven 2006-03-27 01:18:20 -08:00 committed by Linus Torvalds
parent 2f889129de
commit 48c9c27b8b
4 changed files with 28 additions and 24 deletions

View file

@ -14,6 +14,7 @@
#include <linux/ctype.h> #include <linux/ctype.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/mutex.h>
#include <asm/atomic.h> #include <asm/atomic.h>
#define MAX_DEPTH 16 #define MAX_DEPTH 16
@ -770,14 +771,14 @@ int dm_table_complete(struct dm_table *t)
return r; return r;
} }
static DECLARE_MUTEX(_event_lock); static DEFINE_MUTEX(_event_lock);
void dm_table_event_callback(struct dm_table *t, void dm_table_event_callback(struct dm_table *t,
void (*fn)(void *), void *context) void (*fn)(void *), void *context)
{ {
down(&_event_lock); mutex_lock(&_event_lock);
t->event_fn = fn; t->event_fn = fn;
t->event_context = context; t->event_context = context;
up(&_event_lock); mutex_unlock(&_event_lock);
} }
void dm_table_event(struct dm_table *t) void dm_table_event(struct dm_table *t)
@ -788,10 +789,10 @@ void dm_table_event(struct dm_table *t)
*/ */
BUG_ON(in_interrupt()); BUG_ON(in_interrupt());
down(&_event_lock); mutex_lock(&_event_lock);
if (t->event_fn) if (t->event_fn)
t->event_fn(t->event_context); t->event_fn(t->event_context);
up(&_event_lock); mutex_unlock(&_event_lock);
} }
sector_t dm_table_get_size(struct dm_table *t) sector_t dm_table_get_size(struct dm_table *t)

View file

@ -10,6 +10,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/mutex.h>
#include <linux/moduleparam.h> #include <linux/moduleparam.h>
#include <linux/blkpg.h> #include <linux/blkpg.h>
#include <linux/bio.h> #include <linux/bio.h>
@ -743,14 +744,14 @@ static int dm_any_congested(void *congested_data, int bdi_bits)
/*----------------------------------------------------------------- /*-----------------------------------------------------------------
* An IDR is used to keep track of allocated minor numbers. * An IDR is used to keep track of allocated minor numbers.
*---------------------------------------------------------------*/ *---------------------------------------------------------------*/
static DECLARE_MUTEX(_minor_lock); static DEFINE_MUTEX(_minor_lock);
static DEFINE_IDR(_minor_idr); static DEFINE_IDR(_minor_idr);
static void free_minor(unsigned int minor) static void free_minor(unsigned int minor)
{ {
down(&_minor_lock); mutex_lock(&_minor_lock);
idr_remove(&_minor_idr, minor); idr_remove(&_minor_idr, minor);
up(&_minor_lock); mutex_unlock(&_minor_lock);
} }
/* /*
@ -763,7 +764,7 @@ static int specific_minor(struct mapped_device *md, unsigned int minor)
if (minor >= (1 << MINORBITS)) if (minor >= (1 << MINORBITS))
return -EINVAL; return -EINVAL;
down(&_minor_lock); mutex_lock(&_minor_lock);
if (idr_find(&_minor_idr, minor)) { if (idr_find(&_minor_idr, minor)) {
r = -EBUSY; r = -EBUSY;
@ -788,7 +789,7 @@ static int specific_minor(struct mapped_device *md, unsigned int minor)
} }
out: out:
up(&_minor_lock); mutex_unlock(&_minor_lock);
return r; return r;
} }
@ -797,7 +798,7 @@ static int next_free_minor(struct mapped_device *md, unsigned int *minor)
int r; int r;
unsigned int m; unsigned int m;
down(&_minor_lock); mutex_lock(&_minor_lock);
r = idr_pre_get(&_minor_idr, GFP_KERNEL); r = idr_pre_get(&_minor_idr, GFP_KERNEL);
if (!r) { if (!r) {
@ -819,7 +820,7 @@ static int next_free_minor(struct mapped_device *md, unsigned int *minor)
*minor = m; *minor = m;
out: out:
up(&_minor_lock); mutex_unlock(&_minor_lock);
return r; return r;
} }
@ -1014,13 +1015,13 @@ static struct mapped_device *dm_find_md(dev_t dev)
if (MAJOR(dev) != _major || minor >= (1 << MINORBITS)) if (MAJOR(dev) != _major || minor >= (1 << MINORBITS))
return NULL; return NULL;
down(&_minor_lock); mutex_lock(&_minor_lock);
md = idr_find(&_minor_idr, minor); md = idr_find(&_minor_idr, minor);
if (!md || (dm_disk(md)->first_minor != minor)) if (!md || (dm_disk(md)->first_minor != minor))
md = NULL; md = NULL;
up(&_minor_lock); mutex_unlock(&_minor_lock);
return md; return md;
} }

View file

@ -22,6 +22,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
#include <linux/workqueue.h> #include <linux/workqueue.h>
#include <linux/mutex.h>
#include "kcopyd.h" #include "kcopyd.h"
@ -581,21 +582,21 @@ int kcopyd_cancel(struct kcopyd_job *job, int block)
/*----------------------------------------------------------------- /*-----------------------------------------------------------------
* Unit setup * Unit setup
*---------------------------------------------------------------*/ *---------------------------------------------------------------*/
static DECLARE_MUTEX(_client_lock); static DEFINE_MUTEX(_client_lock);
static LIST_HEAD(_clients); static LIST_HEAD(_clients);
static void client_add(struct kcopyd_client *kc) static void client_add(struct kcopyd_client *kc)
{ {
down(&_client_lock); mutex_lock(&_client_lock);
list_add(&kc->list, &_clients); list_add(&kc->list, &_clients);
up(&_client_lock); mutex_unlock(&_client_lock);
} }
static void client_del(struct kcopyd_client *kc) static void client_del(struct kcopyd_client *kc)
{ {
down(&_client_lock); mutex_lock(&_client_lock);
list_del(&kc->list); list_del(&kc->list);
up(&_client_lock); mutex_unlock(&_client_lock);
} }
static DEFINE_MUTEX(kcopyd_init_lock); static DEFINE_MUTEX(kcopyd_init_lock);

View file

@ -43,6 +43,7 @@
#include <linux/buffer_head.h> /* for invalidate_bdev */ #include <linux/buffer_head.h> /* for invalidate_bdev */
#include <linux/suspend.h> #include <linux/suspend.h>
#include <linux/poll.h> #include <linux/poll.h>
#include <linux/mutex.h>
#include <linux/init.h> #include <linux/init.h>
@ -2500,7 +2501,7 @@ int mdp_major = 0;
static struct kobject *md_probe(dev_t dev, int *part, void *data) static struct kobject *md_probe(dev_t dev, int *part, void *data)
{ {
static DECLARE_MUTEX(disks_sem); static DEFINE_MUTEX(disks_mutex);
mddev_t *mddev = mddev_find(dev); mddev_t *mddev = mddev_find(dev);
struct gendisk *disk; struct gendisk *disk;
int partitioned = (MAJOR(dev) != MD_MAJOR); int partitioned = (MAJOR(dev) != MD_MAJOR);
@ -2510,15 +2511,15 @@ static struct kobject *md_probe(dev_t dev, int *part, void *data)
if (!mddev) if (!mddev)
return NULL; return NULL;
down(&disks_sem); mutex_lock(&disks_mutex);
if (mddev->gendisk) { if (mddev->gendisk) {
up(&disks_sem); mutex_unlock(&disks_mutex);
mddev_put(mddev); mddev_put(mddev);
return NULL; return NULL;
} }
disk = alloc_disk(1 << shift); disk = alloc_disk(1 << shift);
if (!disk) { if (!disk) {
up(&disks_sem); mutex_unlock(&disks_mutex);
mddev_put(mddev); mddev_put(mddev);
return NULL; return NULL;
} }
@ -2536,7 +2537,7 @@ static struct kobject *md_probe(dev_t dev, int *part, void *data)
disk->queue = mddev->queue; disk->queue = mddev->queue;
add_disk(disk); add_disk(disk);
mddev->gendisk = disk; mddev->gendisk = disk;
up(&disks_sem); mutex_unlock(&disks_mutex);
mddev->kobj.parent = &disk->kobj; mddev->kobj.parent = &disk->kobj;
mddev->kobj.k_name = NULL; mddev->kobj.k_name = NULL;
snprintf(mddev->kobj.name, KOBJ_NAME_LEN, "%s", "md"); snprintf(mddev->kobj.name, KOBJ_NAME_LEN, "%s", "md");