diff options
Diffstat (limited to 'fs/gfs2/locking.c')
-rw-r--r-- | fs/gfs2/locking.c | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/fs/gfs2/locking.c b/fs/gfs2/locking.c index 0f4c50ebcbad..6a78aacb26af 100644 --- a/fs/gfs2/locking.c +++ b/fs/gfs2/locking.c | |||
@@ -28,7 +28,7 @@ struct lmh_wrapper { | |||
28 | of them by name at mount time, e.g. lock_nolock, lock_dlm. */ | 28 | of them by name at mount time, e.g. lock_nolock, lock_dlm. */ |
29 | 29 | ||
30 | static struct list_head lmh_list; | 30 | static struct list_head lmh_list; |
31 | static struct semaphore lmh_lock; | 31 | static struct mutex lmh_lock; |
32 | 32 | ||
33 | /** | 33 | /** |
34 | * gfs_register_lockproto - Register a low-level locking protocol | 34 | * gfs_register_lockproto - Register a low-level locking protocol |
@@ -41,11 +41,11 @@ int gfs_register_lockproto(struct lm_lockops *proto) | |||
41 | { | 41 | { |
42 | struct lmh_wrapper *lw; | 42 | struct lmh_wrapper *lw; |
43 | 43 | ||
44 | down(&lmh_lock); | 44 | mutex_lock(&lmh_lock); |
45 | 45 | ||
46 | list_for_each_entry(lw, &lmh_list, lw_list) { | 46 | list_for_each_entry(lw, &lmh_list, lw_list) { |
47 | if (!strcmp(lw->lw_ops->lm_proto_name, proto->lm_proto_name)) { | 47 | if (!strcmp(lw->lw_ops->lm_proto_name, proto->lm_proto_name)) { |
48 | up(&lmh_lock); | 48 | mutex_unlock(&lmh_lock); |
49 | printk(KERN_INFO "GFS2: protocol %s already exists\n", | 49 | printk(KERN_INFO "GFS2: protocol %s already exists\n", |
50 | proto->lm_proto_name); | 50 | proto->lm_proto_name); |
51 | return -EEXIST; | 51 | return -EEXIST; |
@@ -54,14 +54,14 @@ int gfs_register_lockproto(struct lm_lockops *proto) | |||
54 | 54 | ||
55 | lw = kzalloc(sizeof(struct lmh_wrapper), GFP_KERNEL); | 55 | lw = kzalloc(sizeof(struct lmh_wrapper), GFP_KERNEL); |
56 | if (!lw) { | 56 | if (!lw) { |
57 | up(&lmh_lock); | 57 | mutex_unlock(&lmh_lock); |
58 | return -ENOMEM; | 58 | return -ENOMEM; |
59 | } | 59 | } |
60 | 60 | ||
61 | lw->lw_ops = proto; | 61 | lw->lw_ops = proto; |
62 | list_add(&lw->lw_list, &lmh_list); | 62 | list_add(&lw->lw_list, &lmh_list); |
63 | 63 | ||
64 | up(&lmh_lock); | 64 | mutex_unlock(&lmh_lock); |
65 | 65 | ||
66 | return 0; | 66 | return 0; |
67 | } | 67 | } |
@@ -76,18 +76,18 @@ void gfs_unregister_lockproto(struct lm_lockops *proto) | |||
76 | { | 76 | { |
77 | struct lmh_wrapper *lw; | 77 | struct lmh_wrapper *lw; |
78 | 78 | ||
79 | down(&lmh_lock); | 79 | mutex_lock(&lmh_lock); |
80 | 80 | ||
81 | list_for_each_entry(lw, &lmh_list, lw_list) { | 81 | list_for_each_entry(lw, &lmh_list, lw_list) { |
82 | if (!strcmp(lw->lw_ops->lm_proto_name, proto->lm_proto_name)) { | 82 | if (!strcmp(lw->lw_ops->lm_proto_name, proto->lm_proto_name)) { |
83 | list_del(&lw->lw_list); | 83 | list_del(&lw->lw_list); |
84 | up(&lmh_lock); | 84 | mutex_unlock(&lmh_lock); |
85 | kfree(lw); | 85 | kfree(lw); |
86 | return; | 86 | return; |
87 | } | 87 | } |
88 | } | 88 | } |
89 | 89 | ||
90 | up(&lmh_lock); | 90 | mutex_unlock(&lmh_lock); |
91 | 91 | ||
92 | printk(KERN_WARNING "GFS2: can't unregister lock protocol %s\n", | 92 | printk(KERN_WARNING "GFS2: can't unregister lock protocol %s\n", |
93 | proto->lm_proto_name); | 93 | proto->lm_proto_name); |
@@ -118,7 +118,7 @@ int gfs2_mount_lockproto(char *proto_name, char *table_name, char *host_data, | |||
118 | int error, found; | 118 | int error, found; |
119 | 119 | ||
120 | retry: | 120 | retry: |
121 | down(&lmh_lock); | 121 | mutex_lock(&lmh_lock); |
122 | 122 | ||
123 | found = 0; | 123 | found = 0; |
124 | list_for_each_entry(lw, &lmh_list, lw_list) { | 124 | list_for_each_entry(lw, &lmh_list, lw_list) { |
@@ -131,7 +131,7 @@ int gfs2_mount_lockproto(char *proto_name, char *table_name, char *host_data, | |||
131 | if (!found) { | 131 | if (!found) { |
132 | if (!try && capable(CAP_SYS_MODULE)) { | 132 | if (!try && capable(CAP_SYS_MODULE)) { |
133 | try = 1; | 133 | try = 1; |
134 | up(&lmh_lock); | 134 | mutex_unlock(&lmh_lock); |
135 | request_module(proto_name); | 135 | request_module(proto_name); |
136 | goto retry; | 136 | goto retry; |
137 | } | 137 | } |
@@ -142,7 +142,7 @@ int gfs2_mount_lockproto(char *proto_name, char *table_name, char *host_data, | |||
142 | 142 | ||
143 | if (!try_module_get(lw->lw_ops->lm_owner)) { | 143 | if (!try_module_get(lw->lw_ops->lm_owner)) { |
144 | try = 0; | 144 | try = 0; |
145 | up(&lmh_lock); | 145 | mutex_unlock(&lmh_lock); |
146 | msleep(1000); | 146 | msleep(1000); |
147 | goto retry; | 147 | goto retry; |
148 | } | 148 | } |
@@ -152,17 +152,17 @@ int gfs2_mount_lockproto(char *proto_name, char *table_name, char *host_data, | |||
152 | if (error) | 152 | if (error) |
153 | module_put(lw->lw_ops->lm_owner); | 153 | module_put(lw->lw_ops->lm_owner); |
154 | out: | 154 | out: |
155 | up(&lmh_lock); | 155 | mutex_unlock(&lmh_lock); |
156 | return error; | 156 | return error; |
157 | } | 157 | } |
158 | 158 | ||
159 | void gfs2_unmount_lockproto(struct lm_lockstruct *lockstruct) | 159 | void gfs2_unmount_lockproto(struct lm_lockstruct *lockstruct) |
160 | { | 160 | { |
161 | down(&lmh_lock); | 161 | mutex_lock(&lmh_lock); |
162 | lockstruct->ls_ops->lm_unmount(lockstruct->ls_lockspace); | 162 | lockstruct->ls_ops->lm_unmount(lockstruct->ls_lockspace); |
163 | if (lockstruct->ls_ops->lm_owner) | 163 | if (lockstruct->ls_ops->lm_owner) |
164 | module_put(lockstruct->ls_ops->lm_owner); | 164 | module_put(lockstruct->ls_ops->lm_owner); |
165 | up(&lmh_lock); | 165 | mutex_unlock(&lmh_lock); |
166 | } | 166 | } |
167 | 167 | ||
168 | /** | 168 | /** |
@@ -173,16 +173,16 @@ void gfs2_unmount_lockproto(struct lm_lockstruct *lockstruct) | |||
173 | 173 | ||
174 | void gfs2_withdraw_lockproto(struct lm_lockstruct *lockstruct) | 174 | void gfs2_withdraw_lockproto(struct lm_lockstruct *lockstruct) |
175 | { | 175 | { |
176 | down(&lmh_lock); | 176 | mutex_lock(&lmh_lock); |
177 | lockstruct->ls_ops->lm_withdraw(lockstruct->ls_lockspace); | 177 | lockstruct->ls_ops->lm_withdraw(lockstruct->ls_lockspace); |
178 | if (lockstruct->ls_ops->lm_owner) | 178 | if (lockstruct->ls_ops->lm_owner) |
179 | module_put(lockstruct->ls_ops->lm_owner); | 179 | module_put(lockstruct->ls_ops->lm_owner); |
180 | up(&lmh_lock); | 180 | mutex_unlock(&lmh_lock); |
181 | } | 181 | } |
182 | 182 | ||
183 | void __init gfs2_init_lmh(void) | 183 | void __init gfs2_init_lmh(void) |
184 | { | 184 | { |
185 | init_MUTEX(&lmh_lock); | 185 | mutex_init(&lmh_lock); |
186 | INIT_LIST_HEAD(&lmh_list); | 186 | INIT_LIST_HEAD(&lmh_list); |
187 | } | 187 | } |
188 | 188 | ||