blob: 295c47f7aba2829d3289e8e8d0f5135b24e54998 [file] [log] [blame]
Mark Fashehccd979b2005-12-15 14:31:24 -08001/* -*- mode: c; c-basic-offset: 8; -*-
2 * vim: noexpandtab sw=8 ts=8 sts=0:
3 *
4 * dlmglue.c
5 *
6 * Code which implements an OCFS2 specific interface to our DLM.
7 *
8 * Copyright (C) 2003, 2004 Oracle. All rights reserved.
9 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public
12 * License as published by the Free Software Foundation; either
13 * version 2 of the License, or (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 * General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public
21 * License along with this program; if not, write to the
22 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
23 * Boston, MA 021110-1307, USA.
24 */
25
26#include <linux/types.h>
27#include <linux/slab.h>
28#include <linux/highmem.h>
29#include <linux/mm.h>
Mark Fashehccd979b2005-12-15 14:31:24 -080030#include <linux/kthread.h>
31#include <linux/pagemap.h>
32#include <linux/debugfs.h>
33#include <linux/seq_file.h>
34
Mark Fashehccd979b2005-12-15 14:31:24 -080035#define MLOG_MASK_PREFIX ML_DLM_GLUE
36#include <cluster/masklog.h>
37
38#include "ocfs2.h"
Joel Beckerd24fbcd2008-01-25 17:02:21 -080039#include "ocfs2_lockingver.h"
Mark Fashehccd979b2005-12-15 14:31:24 -080040
41#include "alloc.h"
Mark Fashehd680efe2006-09-08 14:14:34 -070042#include "dcache.h"
Mark Fashehccd979b2005-12-15 14:31:24 -080043#include "dlmglue.h"
44#include "extent_map.h"
Tiger Yang7f1a37e2006-11-15 15:48:42 +080045#include "file.h"
Mark Fashehccd979b2005-12-15 14:31:24 -080046#include "heartbeat.h"
47#include "inode.h"
48#include "journal.h"
Joel Becker24ef1812008-01-29 17:37:32 -080049#include "stackglue.h"
Mark Fashehccd979b2005-12-15 14:31:24 -080050#include "slot_map.h"
51#include "super.h"
52#include "uptodate.h"
Mark Fashehccd979b2005-12-15 14:31:24 -080053
54#include "buffer_head_io.h"
55
56struct ocfs2_mask_waiter {
57 struct list_head mw_item;
58 int mw_status;
59 struct completion mw_complete;
60 unsigned long mw_mask;
61 unsigned long mw_goal;
62};
63
Mark Fasheh54a7e752006-09-12 21:49:13 -070064static struct ocfs2_super *ocfs2_get_dentry_osb(struct ocfs2_lock_res *lockres);
65static struct ocfs2_super *ocfs2_get_inode_osb(struct ocfs2_lock_res *lockres);
Mark Fashehcf8e06f2007-12-20 16:43:10 -080066static struct ocfs2_super *ocfs2_get_file_osb(struct ocfs2_lock_res *lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -080067
Mark Fashehd680efe2006-09-08 14:14:34 -070068/*
Mark Fashehcc567d82006-09-13 21:52:21 -070069 * Return value from ->downconvert_worker functions.
Mark Fashehd680efe2006-09-08 14:14:34 -070070 *
Mark Fashehb5e500e2006-09-13 22:01:16 -070071 * These control the precise actions of ocfs2_unblock_lock()
Mark Fashehd680efe2006-09-08 14:14:34 -070072 * and ocfs2_process_blocked_lock()
73 *
74 */
75enum ocfs2_unblock_action {
76 UNBLOCK_CONTINUE = 0, /* Continue downconvert */
77 UNBLOCK_CONTINUE_POST = 1, /* Continue downconvert, fire
78 * ->post_unlock callback */
79 UNBLOCK_STOP_POST = 2, /* Do not downconvert, fire
80 * ->post_unlock() callback. */
81};
82
83struct ocfs2_unblock_ctl {
84 int requeue;
85 enum ocfs2_unblock_action unblock_action;
86};
87
Mark Fasheh810d5ae2006-09-13 21:39:52 -070088static int ocfs2_check_meta_downconvert(struct ocfs2_lock_res *lockres,
89 int new_level);
90static void ocfs2_set_meta_lvb(struct ocfs2_lock_res *lockres);
91
Mark Fashehcc567d82006-09-13 21:52:21 -070092static int ocfs2_data_convert_worker(struct ocfs2_lock_res *lockres,
93 int blocking);
94
Mark Fashehcc567d82006-09-13 21:52:21 -070095static int ocfs2_dentry_convert_worker(struct ocfs2_lock_res *lockres,
96 int blocking);
Mark Fashehd680efe2006-09-08 14:14:34 -070097
98static void ocfs2_dentry_post_unlock(struct ocfs2_super *osb,
99 struct ocfs2_lock_res *lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -0800100
Adrian Bunk6cb129f2007-04-26 00:29:35 -0700101
102#define mlog_meta_lvb(__level, __lockres) ocfs2_dump_meta_lvb_info(__level, __PRETTY_FUNCTION__, __LINE__, __lockres)
103
104/* This aids in debugging situations where a bad LVB might be involved. */
105static void ocfs2_dump_meta_lvb_info(u64 level,
106 const char *function,
107 unsigned int line,
108 struct ocfs2_lock_res *lockres)
109{
Joel Becker8f2c9c12008-02-01 12:16:57 -0800110 struct ocfs2_meta_lvb *lvb =
111 (struct ocfs2_meta_lvb *)ocfs2_dlm_lvb(&lockres->l_lksb);
Adrian Bunk6cb129f2007-04-26 00:29:35 -0700112
113 mlog(level, "LVB information for %s (called from %s:%u):\n",
114 lockres->l_name, function, line);
115 mlog(level, "version: %u, clusters: %u, generation: 0x%x\n",
116 lvb->lvb_version, be32_to_cpu(lvb->lvb_iclusters),
117 be32_to_cpu(lvb->lvb_igeneration));
118 mlog(level, "size: %llu, uid %u, gid %u, mode 0x%x\n",
119 (unsigned long long)be64_to_cpu(lvb->lvb_isize),
120 be32_to_cpu(lvb->lvb_iuid), be32_to_cpu(lvb->lvb_igid),
121 be16_to_cpu(lvb->lvb_imode));
122 mlog(level, "nlink %u, atime_packed 0x%llx, ctime_packed 0x%llx, "
123 "mtime_packed 0x%llx iattr 0x%x\n", be16_to_cpu(lvb->lvb_inlink),
124 (long long)be64_to_cpu(lvb->lvb_iatime_packed),
125 (long long)be64_to_cpu(lvb->lvb_ictime_packed),
126 (long long)be64_to_cpu(lvb->lvb_imtime_packed),
127 be32_to_cpu(lvb->lvb_iattr));
128}
129
130
Mark Fashehf625c972006-09-12 21:24:53 -0700131/*
132 * OCFS2 Lock Resource Operations
133 *
134 * These fine tune the behavior of the generic dlmglue locking infrastructure.
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -0700135 *
136 * The most basic of lock types can point ->l_priv to their respective
137 * struct ocfs2_super and allow the default actions to manage things.
138 *
139 * Right now, each lock type also needs to implement an init function,
140 * and trivial lock/unlock wrappers. ocfs2_simple_drop_lockres()
141 * should be called when the lock is no longer needed (i.e., object
142 * destruction time).
Mark Fashehf625c972006-09-12 21:24:53 -0700143 */
Mark Fashehccd979b2005-12-15 14:31:24 -0800144struct ocfs2_lock_res_ops {
Mark Fasheh54a7e752006-09-12 21:49:13 -0700145 /*
146 * Translate an ocfs2_lock_res * into an ocfs2_super *. Define
147 * this callback if ->l_priv is not an ocfs2_super pointer
148 */
149 struct ocfs2_super * (*get_osb)(struct ocfs2_lock_res *);
Mark Fashehb5e500e2006-09-13 22:01:16 -0700150
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -0700151 /*
Mark Fasheh34d024f2007-09-24 15:56:19 -0700152 * Optionally called in the downconvert thread after a
153 * successful downconvert. The lockres will not be referenced
154 * after this callback is called, so it is safe to free
155 * memory, etc.
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -0700156 *
157 * The exact semantics of when this is called are controlled
158 * by ->downconvert_worker()
159 */
Mark Fashehd680efe2006-09-08 14:14:34 -0700160 void (*post_unlock)(struct ocfs2_super *, struct ocfs2_lock_res *);
Mark Fashehf625c972006-09-12 21:24:53 -0700161
162 /*
Mark Fasheh16d5b952006-09-13 21:10:12 -0700163 * Allow a lock type to add checks to determine whether it is
164 * safe to downconvert a lock. Return 0 to re-queue the
165 * downconvert at a later time, nonzero to continue.
166 *
167 * For most locks, the default checks that there are no
168 * incompatible holders are sufficient.
169 *
170 * Called with the lockres spinlock held.
171 */
172 int (*check_downconvert)(struct ocfs2_lock_res *, int);
173
174 /*
Mark Fasheh5ef0d4e2006-09-13 21:21:52 -0700175 * Allows a lock type to populate the lock value block. This
176 * is called on downconvert, and when we drop a lock.
177 *
178 * Locks that want to use this should set LOCK_TYPE_USES_LVB
179 * in the flags field.
180 *
181 * Called with the lockres spinlock held.
182 */
183 void (*set_lvb)(struct ocfs2_lock_res *);
184
185 /*
Mark Fashehcc567d82006-09-13 21:52:21 -0700186 * Called from the downconvert thread when it is determined
187 * that a lock will be downconverted. This is called without
188 * any locks held so the function can do work that might
189 * schedule (syncing out data, etc).
190 *
191 * This should return any one of the ocfs2_unblock_action
192 * values, depending on what it wants the thread to do.
193 */
194 int (*downconvert_worker)(struct ocfs2_lock_res *, int);
195
196 /*
Mark Fashehf625c972006-09-12 21:24:53 -0700197 * LOCK_TYPE_* flags which describe the specific requirements
198 * of a lock type. Descriptions of each individual flag follow.
199 */
200 int flags;
Mark Fashehccd979b2005-12-15 14:31:24 -0800201};
202
Mark Fashehf625c972006-09-12 21:24:53 -0700203/*
204 * Some locks want to "refresh" potentially stale data when a
205 * meaningful (PRMODE or EXMODE) lock level is first obtained. If this
206 * flag is set, the OCFS2_LOCK_NEEDS_REFRESH flag will be set on the
207 * individual lockres l_flags member from the ast function. It is
208 * expected that the locking wrapper will clear the
209 * OCFS2_LOCK_NEEDS_REFRESH flag when done.
210 */
211#define LOCK_TYPE_REQUIRES_REFRESH 0x1
212
Mark Fashehb80fc012006-09-12 22:08:14 -0700213/*
Mark Fasheh5ef0d4e2006-09-13 21:21:52 -0700214 * Indicate that a lock type makes use of the lock value block. The
215 * ->set_lvb lock type callback must be defined.
Mark Fashehb80fc012006-09-12 22:08:14 -0700216 */
217#define LOCK_TYPE_USES_LVB 0x2
218
Mark Fashehccd979b2005-12-15 14:31:24 -0800219static struct ocfs2_lock_res_ops ocfs2_inode_rw_lops = {
Mark Fasheh54a7e752006-09-12 21:49:13 -0700220 .get_osb = ocfs2_get_inode_osb,
Mark Fashehf625c972006-09-12 21:24:53 -0700221 .flags = 0,
Mark Fashehccd979b2005-12-15 14:31:24 -0800222};
223
Mark Fashehe63aecb62007-10-18 15:30:42 -0700224static struct ocfs2_lock_res_ops ocfs2_inode_inode_lops = {
Mark Fasheh54a7e752006-09-12 21:49:13 -0700225 .get_osb = ocfs2_get_inode_osb,
Mark Fasheh810d5ae2006-09-13 21:39:52 -0700226 .check_downconvert = ocfs2_check_meta_downconvert,
227 .set_lvb = ocfs2_set_meta_lvb,
Mark Fashehf1f54062007-10-18 15:13:59 -0700228 .downconvert_worker = ocfs2_data_convert_worker,
Mark Fashehb80fc012006-09-12 22:08:14 -0700229 .flags = LOCK_TYPE_REQUIRES_REFRESH|LOCK_TYPE_USES_LVB,
Mark Fashehccd979b2005-12-15 14:31:24 -0800230};
231
Mark Fashehccd979b2005-12-15 14:31:24 -0800232static struct ocfs2_lock_res_ops ocfs2_super_lops = {
Mark Fashehf625c972006-09-12 21:24:53 -0700233 .flags = LOCK_TYPE_REQUIRES_REFRESH,
Mark Fashehccd979b2005-12-15 14:31:24 -0800234};
235
236static struct ocfs2_lock_res_ops ocfs2_rename_lops = {
Mark Fashehf625c972006-09-12 21:24:53 -0700237 .flags = 0,
Mark Fashehccd979b2005-12-15 14:31:24 -0800238};
239
Mark Fashehd680efe2006-09-08 14:14:34 -0700240static struct ocfs2_lock_res_ops ocfs2_dentry_lops = {
Mark Fasheh54a7e752006-09-12 21:49:13 -0700241 .get_osb = ocfs2_get_dentry_osb,
Mark Fashehd680efe2006-09-08 14:14:34 -0700242 .post_unlock = ocfs2_dentry_post_unlock,
Mark Fashehcc567d82006-09-13 21:52:21 -0700243 .downconvert_worker = ocfs2_dentry_convert_worker,
Mark Fashehf625c972006-09-12 21:24:53 -0700244 .flags = 0,
Mark Fashehd680efe2006-09-08 14:14:34 -0700245};
246
Tiger Yang50008632007-03-20 16:01:38 -0700247static struct ocfs2_lock_res_ops ocfs2_inode_open_lops = {
248 .get_osb = ocfs2_get_inode_osb,
249 .flags = 0,
250};
251
Mark Fashehcf8e06f2007-12-20 16:43:10 -0800252static struct ocfs2_lock_res_ops ocfs2_flock_lops = {
253 .get_osb = ocfs2_get_file_osb,
254 .flags = 0,
255};
256
Mark Fashehccd979b2005-12-15 14:31:24 -0800257static inline int ocfs2_is_inode_lock(struct ocfs2_lock_res *lockres)
258{
259 return lockres->l_type == OCFS2_LOCK_TYPE_META ||
Tiger Yang50008632007-03-20 16:01:38 -0700260 lockres->l_type == OCFS2_LOCK_TYPE_RW ||
261 lockres->l_type == OCFS2_LOCK_TYPE_OPEN;
Mark Fashehccd979b2005-12-15 14:31:24 -0800262}
263
Mark Fashehccd979b2005-12-15 14:31:24 -0800264static inline struct inode *ocfs2_lock_res_inode(struct ocfs2_lock_res *lockres)
265{
266 BUG_ON(!ocfs2_is_inode_lock(lockres));
267
268 return (struct inode *) lockres->l_priv;
269}
270
Mark Fashehd680efe2006-09-08 14:14:34 -0700271static inline struct ocfs2_dentry_lock *ocfs2_lock_res_dl(struct ocfs2_lock_res *lockres)
272{
273 BUG_ON(lockres->l_type != OCFS2_LOCK_TYPE_DENTRY);
274
275 return (struct ocfs2_dentry_lock *)lockres->l_priv;
276}
277
Mark Fasheh54a7e752006-09-12 21:49:13 -0700278static inline struct ocfs2_super *ocfs2_get_lockres_osb(struct ocfs2_lock_res *lockres)
279{
280 if (lockres->l_ops->get_osb)
281 return lockres->l_ops->get_osb(lockres);
282
283 return (struct ocfs2_super *)lockres->l_priv;
284}
285
Mark Fashehccd979b2005-12-15 14:31:24 -0800286static int ocfs2_lock_create(struct ocfs2_super *osb,
287 struct ocfs2_lock_res *lockres,
288 int level,
Joel Beckerbd3e7612008-02-01 12:14:57 -0800289 u32 dlm_flags);
Mark Fashehccd979b2005-12-15 14:31:24 -0800290static inline int ocfs2_may_continue_on_blocked_lock(struct ocfs2_lock_res *lockres,
291 int wanted);
292static void ocfs2_cluster_unlock(struct ocfs2_super *osb,
293 struct ocfs2_lock_res *lockres,
294 int level);
295static inline void ocfs2_generic_handle_downconvert_action(struct ocfs2_lock_res *lockres);
296static inline void ocfs2_generic_handle_convert_action(struct ocfs2_lock_res *lockres);
297static inline void ocfs2_generic_handle_attach_action(struct ocfs2_lock_res *lockres);
298static int ocfs2_generic_handle_bast(struct ocfs2_lock_res *lockres, int level);
299static void ocfs2_schedule_blocked_lock(struct ocfs2_super *osb,
300 struct ocfs2_lock_res *lockres);
301static inline void ocfs2_recover_from_dlm_error(struct ocfs2_lock_res *lockres,
302 int convert);
Joel Becker7431cd72008-02-01 12:15:37 -0800303#define ocfs2_log_dlm_error(_func, _err, _lockres) do { \
304 mlog(ML_ERROR, "DLM error %d while calling %s on resource %s\n", \
305 _err, _func, _lockres->l_name); \
Mark Fashehccd979b2005-12-15 14:31:24 -0800306} while (0)
Mark Fasheh34d024f2007-09-24 15:56:19 -0700307static int ocfs2_downconvert_thread(void *arg);
308static void ocfs2_downconvert_on_unlock(struct ocfs2_super *osb,
309 struct ocfs2_lock_res *lockres);
Mark Fashehe63aecb62007-10-18 15:30:42 -0700310static int ocfs2_inode_lock_update(struct inode *inode,
Mark Fashehccd979b2005-12-15 14:31:24 -0800311 struct buffer_head **bh);
312static void ocfs2_drop_osb_locks(struct ocfs2_super *osb);
313static inline int ocfs2_highest_compat_lock_level(int level);
Joel Beckerde551242008-02-01 14:45:08 -0800314static unsigned int ocfs2_prepare_downconvert(struct ocfs2_lock_res *lockres,
315 int new_level);
Mark Fashehcf8e06f2007-12-20 16:43:10 -0800316static int ocfs2_downconvert_lock(struct ocfs2_super *osb,
317 struct ocfs2_lock_res *lockres,
318 int new_level,
Joel Beckerde551242008-02-01 14:45:08 -0800319 int lvb,
320 unsigned int generation);
Mark Fashehcf8e06f2007-12-20 16:43:10 -0800321static int ocfs2_prepare_cancel_convert(struct ocfs2_super *osb,
322 struct ocfs2_lock_res *lockres);
323static int ocfs2_cancel_convert(struct ocfs2_super *osb,
324 struct ocfs2_lock_res *lockres);
325
Mark Fashehccd979b2005-12-15 14:31:24 -0800326
Mark Fashehccd979b2005-12-15 14:31:24 -0800327static void ocfs2_build_lock_name(enum ocfs2_lock_type type,
328 u64 blkno,
329 u32 generation,
330 char *name)
331{
332 int len;
333
334 mlog_entry_void();
335
336 BUG_ON(type >= OCFS2_NUM_LOCK_TYPES);
337
Mark Fashehb06970532006-03-03 10:24:33 -0800338 len = snprintf(name, OCFS2_LOCK_ID_MAX_LEN, "%c%s%016llx%08x",
339 ocfs2_lock_type_char(type), OCFS2_LOCK_ID_PAD,
340 (long long)blkno, generation);
Mark Fashehccd979b2005-12-15 14:31:24 -0800341
342 BUG_ON(len != (OCFS2_LOCK_ID_MAX_LEN - 1));
343
344 mlog(0, "built lock resource with name: %s\n", name);
345
346 mlog_exit_void();
347}
348
Ingo Molnar34af9462006-06-27 02:53:55 -0700349static DEFINE_SPINLOCK(ocfs2_dlm_tracking_lock);
Mark Fashehccd979b2005-12-15 14:31:24 -0800350
351static void ocfs2_add_lockres_tracking(struct ocfs2_lock_res *res,
352 struct ocfs2_dlm_debug *dlm_debug)
353{
354 mlog(0, "Add tracking for lockres %s\n", res->l_name);
355
356 spin_lock(&ocfs2_dlm_tracking_lock);
357 list_add(&res->l_debug_list, &dlm_debug->d_lockres_tracking);
358 spin_unlock(&ocfs2_dlm_tracking_lock);
359}
360
361static void ocfs2_remove_lockres_tracking(struct ocfs2_lock_res *res)
362{
363 spin_lock(&ocfs2_dlm_tracking_lock);
364 if (!list_empty(&res->l_debug_list))
365 list_del_init(&res->l_debug_list);
366 spin_unlock(&ocfs2_dlm_tracking_lock);
367}
368
369static void ocfs2_lock_res_init_common(struct ocfs2_super *osb,
370 struct ocfs2_lock_res *res,
371 enum ocfs2_lock_type type,
Mark Fashehccd979b2005-12-15 14:31:24 -0800372 struct ocfs2_lock_res_ops *ops,
373 void *priv)
374{
Mark Fashehccd979b2005-12-15 14:31:24 -0800375 res->l_type = type;
376 res->l_ops = ops;
377 res->l_priv = priv;
378
Joel Beckerbd3e7612008-02-01 12:14:57 -0800379 res->l_level = DLM_LOCK_IV;
380 res->l_requested = DLM_LOCK_IV;
381 res->l_blocking = DLM_LOCK_IV;
Mark Fashehccd979b2005-12-15 14:31:24 -0800382 res->l_action = OCFS2_AST_INVALID;
383 res->l_unlock_action = OCFS2_UNLOCK_INVALID;
384
385 res->l_flags = OCFS2_LOCK_INITIALIZED;
386
387 ocfs2_add_lockres_tracking(res, osb->osb_dlm_debug);
388}
389
390void ocfs2_lock_res_init_once(struct ocfs2_lock_res *res)
391{
392 /* This also clears out the lock status block */
393 memset(res, 0, sizeof(struct ocfs2_lock_res));
394 spin_lock_init(&res->l_lock);
395 init_waitqueue_head(&res->l_event);
396 INIT_LIST_HEAD(&res->l_blocked_list);
397 INIT_LIST_HEAD(&res->l_mask_waiters);
398}
399
400void ocfs2_inode_lock_res_init(struct ocfs2_lock_res *res,
401 enum ocfs2_lock_type type,
Mark Fasheh24c19ef2006-09-22 17:28:19 -0700402 unsigned int generation,
Mark Fashehccd979b2005-12-15 14:31:24 -0800403 struct inode *inode)
404{
405 struct ocfs2_lock_res_ops *ops;
406
407 switch(type) {
408 case OCFS2_LOCK_TYPE_RW:
409 ops = &ocfs2_inode_rw_lops;
410 break;
411 case OCFS2_LOCK_TYPE_META:
Mark Fashehe63aecb62007-10-18 15:30:42 -0700412 ops = &ocfs2_inode_inode_lops;
Mark Fashehccd979b2005-12-15 14:31:24 -0800413 break;
Tiger Yang50008632007-03-20 16:01:38 -0700414 case OCFS2_LOCK_TYPE_OPEN:
415 ops = &ocfs2_inode_open_lops;
416 break;
Mark Fashehccd979b2005-12-15 14:31:24 -0800417 default:
418 mlog_bug_on_msg(1, "type: %d\n", type);
419 ops = NULL; /* thanks, gcc */
420 break;
421 };
422
Mark Fashehd680efe2006-09-08 14:14:34 -0700423 ocfs2_build_lock_name(type, OCFS2_I(inode)->ip_blkno,
Mark Fasheh24c19ef2006-09-22 17:28:19 -0700424 generation, res->l_name);
Mark Fashehd680efe2006-09-08 14:14:34 -0700425 ocfs2_lock_res_init_common(OCFS2_SB(inode->i_sb), res, type, ops, inode);
426}
427
Mark Fasheh54a7e752006-09-12 21:49:13 -0700428static struct ocfs2_super *ocfs2_get_inode_osb(struct ocfs2_lock_res *lockres)
429{
430 struct inode *inode = ocfs2_lock_res_inode(lockres);
431
432 return OCFS2_SB(inode->i_sb);
433}
434
Mark Fashehcf8e06f2007-12-20 16:43:10 -0800435static struct ocfs2_super *ocfs2_get_file_osb(struct ocfs2_lock_res *lockres)
436{
437 struct ocfs2_file_private *fp = lockres->l_priv;
438
439 return OCFS2_SB(fp->fp_file->f_mapping->host->i_sb);
440}
441
Mark Fashehd680efe2006-09-08 14:14:34 -0700442static __u64 ocfs2_get_dentry_lock_ino(struct ocfs2_lock_res *lockres)
443{
444 __be64 inode_blkno_be;
445
446 memcpy(&inode_blkno_be, &lockres->l_name[OCFS2_DENTRY_LOCK_INO_START],
447 sizeof(__be64));
448
449 return be64_to_cpu(inode_blkno_be);
450}
451
Mark Fasheh54a7e752006-09-12 21:49:13 -0700452static struct ocfs2_super *ocfs2_get_dentry_osb(struct ocfs2_lock_res *lockres)
453{
454 struct ocfs2_dentry_lock *dl = lockres->l_priv;
455
456 return OCFS2_SB(dl->dl_inode->i_sb);
457}
458
Mark Fashehd680efe2006-09-08 14:14:34 -0700459void ocfs2_dentry_lock_res_init(struct ocfs2_dentry_lock *dl,
460 u64 parent, struct inode *inode)
461{
462 int len;
463 u64 inode_blkno = OCFS2_I(inode)->ip_blkno;
464 __be64 inode_blkno_be = cpu_to_be64(inode_blkno);
465 struct ocfs2_lock_res *lockres = &dl->dl_lockres;
466
467 ocfs2_lock_res_init_once(lockres);
468
469 /*
470 * Unfortunately, the standard lock naming scheme won't work
471 * here because we have two 16 byte values to use. Instead,
472 * we'll stuff the inode number as a binary value. We still
473 * want error prints to show something without garbling the
474 * display, so drop a null byte in there before the inode
475 * number. A future version of OCFS2 will likely use all
476 * binary lock names. The stringified names have been a
477 * tremendous aid in debugging, but now that the debugfs
478 * interface exists, we can mangle things there if need be.
479 *
480 * NOTE: We also drop the standard "pad" value (the total lock
481 * name size stays the same though - the last part is all
482 * zeros due to the memset in ocfs2_lock_res_init_once()
483 */
484 len = snprintf(lockres->l_name, OCFS2_DENTRY_LOCK_INO_START,
485 "%c%016llx",
486 ocfs2_lock_type_char(OCFS2_LOCK_TYPE_DENTRY),
487 (long long)parent);
488
489 BUG_ON(len != (OCFS2_DENTRY_LOCK_INO_START - 1));
490
491 memcpy(&lockres->l_name[OCFS2_DENTRY_LOCK_INO_START], &inode_blkno_be,
492 sizeof(__be64));
493
494 ocfs2_lock_res_init_common(OCFS2_SB(inode->i_sb), lockres,
495 OCFS2_LOCK_TYPE_DENTRY, &ocfs2_dentry_lops,
496 dl);
Mark Fashehccd979b2005-12-15 14:31:24 -0800497}
498
499static void ocfs2_super_lock_res_init(struct ocfs2_lock_res *res,
500 struct ocfs2_super *osb)
501{
502 /* Superblock lockres doesn't come from a slab so we call init
503 * once on it manually. */
504 ocfs2_lock_res_init_once(res);
Mark Fashehd680efe2006-09-08 14:14:34 -0700505 ocfs2_build_lock_name(OCFS2_LOCK_TYPE_SUPER, OCFS2_SUPER_BLOCK_BLKNO,
506 0, res->l_name);
Mark Fashehccd979b2005-12-15 14:31:24 -0800507 ocfs2_lock_res_init_common(osb, res, OCFS2_LOCK_TYPE_SUPER,
Mark Fashehccd979b2005-12-15 14:31:24 -0800508 &ocfs2_super_lops, osb);
509}
510
511static void ocfs2_rename_lock_res_init(struct ocfs2_lock_res *res,
512 struct ocfs2_super *osb)
513{
514 /* Rename lockres doesn't come from a slab so we call init
515 * once on it manually. */
516 ocfs2_lock_res_init_once(res);
Mark Fashehd680efe2006-09-08 14:14:34 -0700517 ocfs2_build_lock_name(OCFS2_LOCK_TYPE_RENAME, 0, 0, res->l_name);
518 ocfs2_lock_res_init_common(osb, res, OCFS2_LOCK_TYPE_RENAME,
Mark Fashehccd979b2005-12-15 14:31:24 -0800519 &ocfs2_rename_lops, osb);
520}
521
Mark Fashehcf8e06f2007-12-20 16:43:10 -0800522void ocfs2_file_lock_res_init(struct ocfs2_lock_res *lockres,
523 struct ocfs2_file_private *fp)
524{
525 struct inode *inode = fp->fp_file->f_mapping->host;
526 struct ocfs2_inode_info *oi = OCFS2_I(inode);
527
528 ocfs2_lock_res_init_once(lockres);
529 ocfs2_build_lock_name(OCFS2_LOCK_TYPE_FLOCK, oi->ip_blkno,
530 inode->i_generation, lockres->l_name);
531 ocfs2_lock_res_init_common(OCFS2_SB(inode->i_sb), lockres,
532 OCFS2_LOCK_TYPE_FLOCK, &ocfs2_flock_lops,
533 fp);
534 lockres->l_flags |= OCFS2_LOCK_NOCACHE;
535}
536
Mark Fashehccd979b2005-12-15 14:31:24 -0800537void ocfs2_lock_res_free(struct ocfs2_lock_res *res)
538{
539 mlog_entry_void();
540
541 if (!(res->l_flags & OCFS2_LOCK_INITIALIZED))
542 return;
543
544 ocfs2_remove_lockres_tracking(res);
545
546 mlog_bug_on_msg(!list_empty(&res->l_blocked_list),
547 "Lockres %s is on the blocked list\n",
548 res->l_name);
549 mlog_bug_on_msg(!list_empty(&res->l_mask_waiters),
550 "Lockres %s has mask waiters pending\n",
551 res->l_name);
552 mlog_bug_on_msg(spin_is_locked(&res->l_lock),
553 "Lockres %s is locked\n",
554 res->l_name);
555 mlog_bug_on_msg(res->l_ro_holders,
556 "Lockres %s has %u ro holders\n",
557 res->l_name, res->l_ro_holders);
558 mlog_bug_on_msg(res->l_ex_holders,
559 "Lockres %s has %u ex holders\n",
560 res->l_name, res->l_ex_holders);
561
562 /* Need to clear out the lock status block for the dlm */
563 memset(&res->l_lksb, 0, sizeof(res->l_lksb));
564
565 res->l_flags = 0UL;
566 mlog_exit_void();
567}
568
569static inline void ocfs2_inc_holders(struct ocfs2_lock_res *lockres,
570 int level)
571{
572 mlog_entry_void();
573
574 BUG_ON(!lockres);
575
576 switch(level) {
Joel Beckerbd3e7612008-02-01 12:14:57 -0800577 case DLM_LOCK_EX:
Mark Fashehccd979b2005-12-15 14:31:24 -0800578 lockres->l_ex_holders++;
579 break;
Joel Beckerbd3e7612008-02-01 12:14:57 -0800580 case DLM_LOCK_PR:
Mark Fashehccd979b2005-12-15 14:31:24 -0800581 lockres->l_ro_holders++;
582 break;
583 default:
584 BUG();
585 }
586
587 mlog_exit_void();
588}
589
590static inline void ocfs2_dec_holders(struct ocfs2_lock_res *lockres,
591 int level)
592{
593 mlog_entry_void();
594
595 BUG_ON(!lockres);
596
597 switch(level) {
Joel Beckerbd3e7612008-02-01 12:14:57 -0800598 case DLM_LOCK_EX:
Mark Fashehccd979b2005-12-15 14:31:24 -0800599 BUG_ON(!lockres->l_ex_holders);
600 lockres->l_ex_holders--;
601 break;
Joel Beckerbd3e7612008-02-01 12:14:57 -0800602 case DLM_LOCK_PR:
Mark Fashehccd979b2005-12-15 14:31:24 -0800603 BUG_ON(!lockres->l_ro_holders);
604 lockres->l_ro_holders--;
605 break;
606 default:
607 BUG();
608 }
609 mlog_exit_void();
610}
611
612/* WARNING: This function lives in a world where the only three lock
613 * levels are EX, PR, and NL. It *will* have to be adjusted when more
614 * lock types are added. */
615static inline int ocfs2_highest_compat_lock_level(int level)
616{
Joel Beckerbd3e7612008-02-01 12:14:57 -0800617 int new_level = DLM_LOCK_EX;
Mark Fashehccd979b2005-12-15 14:31:24 -0800618
Joel Beckerbd3e7612008-02-01 12:14:57 -0800619 if (level == DLM_LOCK_EX)
620 new_level = DLM_LOCK_NL;
621 else if (level == DLM_LOCK_PR)
622 new_level = DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -0800623 return new_level;
624}
625
626static void lockres_set_flags(struct ocfs2_lock_res *lockres,
627 unsigned long newflags)
628{
Christoph Hellwig800deef2007-05-17 16:03:13 +0200629 struct ocfs2_mask_waiter *mw, *tmp;
Mark Fashehccd979b2005-12-15 14:31:24 -0800630
631 assert_spin_locked(&lockres->l_lock);
632
633 lockres->l_flags = newflags;
634
Christoph Hellwig800deef2007-05-17 16:03:13 +0200635 list_for_each_entry_safe(mw, tmp, &lockres->l_mask_waiters, mw_item) {
Mark Fashehccd979b2005-12-15 14:31:24 -0800636 if ((lockres->l_flags & mw->mw_mask) != mw->mw_goal)
637 continue;
638
639 list_del_init(&mw->mw_item);
640 mw->mw_status = 0;
641 complete(&mw->mw_complete);
642 }
643}
644static void lockres_or_flags(struct ocfs2_lock_res *lockres, unsigned long or)
645{
646 lockres_set_flags(lockres, lockres->l_flags | or);
647}
648static void lockres_clear_flags(struct ocfs2_lock_res *lockres,
649 unsigned long clear)
650{
651 lockres_set_flags(lockres, lockres->l_flags & ~clear);
652}
653
654static inline void ocfs2_generic_handle_downconvert_action(struct ocfs2_lock_res *lockres)
655{
656 mlog_entry_void();
657
658 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_BUSY));
659 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_ATTACHED));
660 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_BLOCKED));
Joel Beckerbd3e7612008-02-01 12:14:57 -0800661 BUG_ON(lockres->l_blocking <= DLM_LOCK_NL);
Mark Fashehccd979b2005-12-15 14:31:24 -0800662
663 lockres->l_level = lockres->l_requested;
664 if (lockres->l_level <=
665 ocfs2_highest_compat_lock_level(lockres->l_blocking)) {
Joel Beckerbd3e7612008-02-01 12:14:57 -0800666 lockres->l_blocking = DLM_LOCK_NL;
Mark Fashehccd979b2005-12-15 14:31:24 -0800667 lockres_clear_flags(lockres, OCFS2_LOCK_BLOCKED);
668 }
669 lockres_clear_flags(lockres, OCFS2_LOCK_BUSY);
670
671 mlog_exit_void();
672}
673
674static inline void ocfs2_generic_handle_convert_action(struct ocfs2_lock_res *lockres)
675{
676 mlog_entry_void();
677
678 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_BUSY));
679 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_ATTACHED));
680
681 /* Convert from RO to EX doesn't really need anything as our
682 * information is already up to data. Convert from NL to
683 * *anything* however should mark ourselves as needing an
684 * update */
Joel Beckerbd3e7612008-02-01 12:14:57 -0800685 if (lockres->l_level == DLM_LOCK_NL &&
Mark Fashehf625c972006-09-12 21:24:53 -0700686 lockres->l_ops->flags & LOCK_TYPE_REQUIRES_REFRESH)
Mark Fashehccd979b2005-12-15 14:31:24 -0800687 lockres_or_flags(lockres, OCFS2_LOCK_NEEDS_REFRESH);
688
689 lockres->l_level = lockres->l_requested;
690 lockres_clear_flags(lockres, OCFS2_LOCK_BUSY);
691
692 mlog_exit_void();
693}
694
695static inline void ocfs2_generic_handle_attach_action(struct ocfs2_lock_res *lockres)
696{
697 mlog_entry_void();
698
Roel Kluin3cf0c502007-10-27 00:20:36 +0200699 BUG_ON((!(lockres->l_flags & OCFS2_LOCK_BUSY)));
Mark Fashehccd979b2005-12-15 14:31:24 -0800700 BUG_ON(lockres->l_flags & OCFS2_LOCK_ATTACHED);
701
Joel Beckerbd3e7612008-02-01 12:14:57 -0800702 if (lockres->l_requested > DLM_LOCK_NL &&
Mark Fashehf625c972006-09-12 21:24:53 -0700703 !(lockres->l_flags & OCFS2_LOCK_LOCAL) &&
704 lockres->l_ops->flags & LOCK_TYPE_REQUIRES_REFRESH)
Mark Fashehccd979b2005-12-15 14:31:24 -0800705 lockres_or_flags(lockres, OCFS2_LOCK_NEEDS_REFRESH);
706
707 lockres->l_level = lockres->l_requested;
708 lockres_or_flags(lockres, OCFS2_LOCK_ATTACHED);
709 lockres_clear_flags(lockres, OCFS2_LOCK_BUSY);
710
711 mlog_exit_void();
712}
713
Mark Fashehccd979b2005-12-15 14:31:24 -0800714static int ocfs2_generic_handle_bast(struct ocfs2_lock_res *lockres,
715 int level)
716{
717 int needs_downconvert = 0;
718 mlog_entry_void();
719
720 assert_spin_locked(&lockres->l_lock);
721
722 lockres_or_flags(lockres, OCFS2_LOCK_BLOCKED);
723
724 if (level > lockres->l_blocking) {
725 /* only schedule a downconvert if we haven't already scheduled
726 * one that goes low enough to satisfy the level we're
727 * blocking. this also catches the case where we get
728 * duplicate BASTs */
729 if (ocfs2_highest_compat_lock_level(level) <
730 ocfs2_highest_compat_lock_level(lockres->l_blocking))
731 needs_downconvert = 1;
732
733 lockres->l_blocking = level;
734 }
735
736 mlog_exit(needs_downconvert);
737 return needs_downconvert;
738}
739
Joel Beckerde551242008-02-01 14:45:08 -0800740/*
741 * OCFS2_LOCK_PENDING and l_pending_gen.
742 *
743 * Why does OCFS2_LOCK_PENDING exist? To close a race between setting
744 * OCFS2_LOCK_BUSY and calling ocfs2_dlm_lock(). See ocfs2_unblock_lock()
745 * for more details on the race.
746 *
747 * OCFS2_LOCK_PENDING closes the race quite nicely. However, it introduces
748 * a race on itself. In o2dlm, we can get the ast before ocfs2_dlm_lock()
749 * returns. The ast clears OCFS2_LOCK_BUSY, and must therefore clear
750 * OCFS2_LOCK_PENDING at the same time. When ocfs2_dlm_lock() returns,
751 * the caller is going to try to clear PENDING again. If nothing else is
752 * happening, __lockres_clear_pending() sees PENDING is unset and does
753 * nothing.
754 *
755 * But what if another path (eg downconvert thread) has just started a
756 * new locking action? The other path has re-set PENDING. Our path
757 * cannot clear PENDING, because that will re-open the original race
758 * window.
759 *
760 * [Example]
761 *
762 * ocfs2_meta_lock()
763 * ocfs2_cluster_lock()
764 * set BUSY
765 * set PENDING
766 * drop l_lock
767 * ocfs2_dlm_lock()
768 * ocfs2_locking_ast() ocfs2_downconvert_thread()
769 * clear PENDING ocfs2_unblock_lock()
770 * take_l_lock
771 * !BUSY
772 * ocfs2_prepare_downconvert()
773 * set BUSY
774 * set PENDING
775 * drop l_lock
776 * take l_lock
777 * clear PENDING
778 * drop l_lock
779 * <window>
780 * ocfs2_dlm_lock()
781 *
782 * So as you can see, we now have a window where l_lock is not held,
783 * PENDING is not set, and ocfs2_dlm_lock() has not been called.
784 *
785 * The core problem is that ocfs2_cluster_lock() has cleared the PENDING
786 * set by ocfs2_prepare_downconvert(). That wasn't nice.
787 *
788 * To solve this we introduce l_pending_gen. A call to
789 * lockres_clear_pending() will only do so when it is passed a generation
790 * number that matches the lockres. lockres_set_pending() will return the
791 * current generation number. When ocfs2_cluster_lock() goes to clear
792 * PENDING, it passes the generation it got from set_pending(). In our
793 * example above, the generation numbers will *not* match. Thus,
794 * ocfs2_cluster_lock() will not clear the PENDING set by
795 * ocfs2_prepare_downconvert().
796 */
797
798/* Unlocked version for ocfs2_locking_ast() */
799static void __lockres_clear_pending(struct ocfs2_lock_res *lockres,
800 unsigned int generation,
801 struct ocfs2_super *osb)
802{
803 assert_spin_locked(&lockres->l_lock);
804
805 /*
806 * The ast and locking functions can race us here. The winner
807 * will clear pending, the loser will not.
808 */
809 if (!(lockres->l_flags & OCFS2_LOCK_PENDING) ||
810 (lockres->l_pending_gen != generation))
811 return;
812
813 lockres_clear_flags(lockres, OCFS2_LOCK_PENDING);
814 lockres->l_pending_gen++;
815
816 /*
817 * The downconvert thread may have skipped us because we
818 * were PENDING. Wake it up.
819 */
820 if (lockres->l_flags & OCFS2_LOCK_BLOCKED)
821 ocfs2_wake_downconvert_thread(osb);
822}
823
824/* Locked version for callers of ocfs2_dlm_lock() */
825static void lockres_clear_pending(struct ocfs2_lock_res *lockres,
826 unsigned int generation,
827 struct ocfs2_super *osb)
828{
829 unsigned long flags;
830
831 spin_lock_irqsave(&lockres->l_lock, flags);
832 __lockres_clear_pending(lockres, generation, osb);
833 spin_unlock_irqrestore(&lockres->l_lock, flags);
834}
835
836static unsigned int lockres_set_pending(struct ocfs2_lock_res *lockres)
837{
838 assert_spin_locked(&lockres->l_lock);
839 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_BUSY));
840
841 lockres_or_flags(lockres, OCFS2_LOCK_PENDING);
842
843 return lockres->l_pending_gen;
844}
845
846
Mark Fashehaa2623a2006-09-12 21:58:23 -0700847static void ocfs2_blocking_ast(void *opaque, int level)
Mark Fashehccd979b2005-12-15 14:31:24 -0800848{
Mark Fashehaa2623a2006-09-12 21:58:23 -0700849 struct ocfs2_lock_res *lockres = opaque;
850 struct ocfs2_super *osb = ocfs2_get_lockres_osb(lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -0800851 int needs_downconvert;
852 unsigned long flags;
853
Joel Beckerbd3e7612008-02-01 12:14:57 -0800854 BUG_ON(level <= DLM_LOCK_NL);
Mark Fashehccd979b2005-12-15 14:31:24 -0800855
Mark Fashehaa2623a2006-09-12 21:58:23 -0700856 mlog(0, "BAST fired for lockres %s, blocking %d, level %d type %s\n",
857 lockres->l_name, level, lockres->l_level,
858 ocfs2_lock_type_string(lockres->l_type));
859
Mark Fashehcf8e06f2007-12-20 16:43:10 -0800860 /*
861 * We can skip the bast for locks which don't enable caching -
862 * they'll be dropped at the earliest possible time anyway.
863 */
864 if (lockres->l_flags & OCFS2_LOCK_NOCACHE)
865 return;
866
Mark Fashehccd979b2005-12-15 14:31:24 -0800867 spin_lock_irqsave(&lockres->l_lock, flags);
868 needs_downconvert = ocfs2_generic_handle_bast(lockres, level);
869 if (needs_downconvert)
870 ocfs2_schedule_blocked_lock(osb, lockres);
871 spin_unlock_irqrestore(&lockres->l_lock, flags);
872
Mark Fashehd680efe2006-09-08 14:14:34 -0700873 wake_up(&lockres->l_event);
874
Mark Fasheh34d024f2007-09-24 15:56:19 -0700875 ocfs2_wake_downconvert_thread(osb);
Mark Fashehccd979b2005-12-15 14:31:24 -0800876}
877
Mark Fashehe92d57d2006-09-12 21:34:35 -0700878static void ocfs2_locking_ast(void *opaque)
Mark Fashehccd979b2005-12-15 14:31:24 -0800879{
Mark Fashehe92d57d2006-09-12 21:34:35 -0700880 struct ocfs2_lock_res *lockres = opaque;
Joel Beckerde551242008-02-01 14:45:08 -0800881 struct ocfs2_super *osb = ocfs2_get_lockres_osb(lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -0800882 unsigned long flags;
883
884 spin_lock_irqsave(&lockres->l_lock, flags);
885
Joel Becker8f2c9c12008-02-01 12:16:57 -0800886 if (ocfs2_dlm_lock_status(&lockres->l_lksb)) {
887 mlog(ML_ERROR, "lockres %s: lksb status value of %d!\n",
888 lockres->l_name,
889 ocfs2_dlm_lock_status(&lockres->l_lksb));
Mark Fashehccd979b2005-12-15 14:31:24 -0800890 spin_unlock_irqrestore(&lockres->l_lock, flags);
891 return;
892 }
893
894 switch(lockres->l_action) {
895 case OCFS2_AST_ATTACH:
896 ocfs2_generic_handle_attach_action(lockres);
Mark Fashehe92d57d2006-09-12 21:34:35 -0700897 lockres_clear_flags(lockres, OCFS2_LOCK_LOCAL);
Mark Fashehccd979b2005-12-15 14:31:24 -0800898 break;
899 case OCFS2_AST_CONVERT:
900 ocfs2_generic_handle_convert_action(lockres);
901 break;
902 case OCFS2_AST_DOWNCONVERT:
903 ocfs2_generic_handle_downconvert_action(lockres);
904 break;
905 default:
Mark Fashehe92d57d2006-09-12 21:34:35 -0700906 mlog(ML_ERROR, "lockres %s: ast fired with invalid action: %u "
907 "lockres flags = 0x%lx, unlock action: %u\n",
908 lockres->l_name, lockres->l_action, lockres->l_flags,
909 lockres->l_unlock_action);
Mark Fashehccd979b2005-12-15 14:31:24 -0800910 BUG();
911 }
912
Mark Fashehccd979b2005-12-15 14:31:24 -0800913 /* set it to something invalid so if we get called again we
914 * can catch it. */
915 lockres->l_action = OCFS2_AST_INVALID;
Mark Fashehccd979b2005-12-15 14:31:24 -0800916
Joel Beckerde551242008-02-01 14:45:08 -0800917 /* Did we try to cancel this lock? Clear that state */
918 if (lockres->l_unlock_action == OCFS2_UNLOCK_CANCEL_CONVERT)
919 lockres->l_unlock_action = OCFS2_UNLOCK_INVALID;
920
921 /*
922 * We may have beaten the locking functions here. We certainly
923 * know that dlm_lock() has been called :-)
924 * Because we can't have two lock calls in flight at once, we
925 * can use lockres->l_pending_gen.
926 */
927 __lockres_clear_pending(lockres, lockres->l_pending_gen, osb);
928
Mark Fashehccd979b2005-12-15 14:31:24 -0800929 wake_up(&lockres->l_event);
Mark Fashehd680efe2006-09-08 14:14:34 -0700930 spin_unlock_irqrestore(&lockres->l_lock, flags);
Mark Fashehccd979b2005-12-15 14:31:24 -0800931}
932
Mark Fashehccd979b2005-12-15 14:31:24 -0800933static inline void ocfs2_recover_from_dlm_error(struct ocfs2_lock_res *lockres,
934 int convert)
935{
936 unsigned long flags;
937
938 mlog_entry_void();
939 spin_lock_irqsave(&lockres->l_lock, flags);
940 lockres_clear_flags(lockres, OCFS2_LOCK_BUSY);
941 if (convert)
942 lockres->l_action = OCFS2_AST_INVALID;
943 else
944 lockres->l_unlock_action = OCFS2_UNLOCK_INVALID;
945 spin_unlock_irqrestore(&lockres->l_lock, flags);
946
947 wake_up(&lockres->l_event);
948 mlog_exit_void();
949}
950
951/* Note: If we detect another process working on the lock (i.e.,
952 * OCFS2_LOCK_BUSY), we'll bail out returning 0. It's up to the caller
953 * to do the right thing in that case.
954 */
955static int ocfs2_lock_create(struct ocfs2_super *osb,
956 struct ocfs2_lock_res *lockres,
957 int level,
Joel Beckerbd3e7612008-02-01 12:14:57 -0800958 u32 dlm_flags)
Mark Fashehccd979b2005-12-15 14:31:24 -0800959{
960 int ret = 0;
Mark Fashehccd979b2005-12-15 14:31:24 -0800961 unsigned long flags;
Joel Beckerde551242008-02-01 14:45:08 -0800962 unsigned int gen;
Mark Fashehccd979b2005-12-15 14:31:24 -0800963
964 mlog_entry_void();
965
Joel Beckerbd3e7612008-02-01 12:14:57 -0800966 mlog(0, "lock %s, level = %d, flags = %u\n", lockres->l_name, level,
Mark Fashehccd979b2005-12-15 14:31:24 -0800967 dlm_flags);
968
969 spin_lock_irqsave(&lockres->l_lock, flags);
970 if ((lockres->l_flags & OCFS2_LOCK_ATTACHED) ||
971 (lockres->l_flags & OCFS2_LOCK_BUSY)) {
972 spin_unlock_irqrestore(&lockres->l_lock, flags);
973 goto bail;
974 }
975
976 lockres->l_action = OCFS2_AST_ATTACH;
977 lockres->l_requested = level;
978 lockres_or_flags(lockres, OCFS2_LOCK_BUSY);
Joel Beckerde551242008-02-01 14:45:08 -0800979 gen = lockres_set_pending(lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -0800980 spin_unlock_irqrestore(&lockres->l_lock, flags);
981
Joel Becker4670c462008-02-01 14:39:35 -0800982 ret = ocfs2_dlm_lock(osb->cconn,
Joel Becker7431cd72008-02-01 12:15:37 -0800983 level,
984 &lockres->l_lksb,
985 dlm_flags,
986 lockres->l_name,
987 OCFS2_LOCK_ID_MAX_LEN - 1,
988 lockres);
Joel Beckerde551242008-02-01 14:45:08 -0800989 lockres_clear_pending(lockres, gen, osb);
Joel Becker7431cd72008-02-01 12:15:37 -0800990 if (ret) {
991 ocfs2_log_dlm_error("ocfs2_dlm_lock", ret, lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -0800992 ocfs2_recover_from_dlm_error(lockres, 1);
993 }
994
Joel Becker7431cd72008-02-01 12:15:37 -0800995 mlog(0, "lock %s, return from ocfs2_dlm_lock\n", lockres->l_name);
Mark Fashehccd979b2005-12-15 14:31:24 -0800996
997bail:
998 mlog_exit(ret);
999 return ret;
1000}
1001
1002static inline int ocfs2_check_wait_flag(struct ocfs2_lock_res *lockres,
1003 int flag)
1004{
1005 unsigned long flags;
1006 int ret;
1007
1008 spin_lock_irqsave(&lockres->l_lock, flags);
1009 ret = lockres->l_flags & flag;
1010 spin_unlock_irqrestore(&lockres->l_lock, flags);
1011
1012 return ret;
1013}
1014
1015static inline void ocfs2_wait_on_busy_lock(struct ocfs2_lock_res *lockres)
1016
1017{
1018 wait_event(lockres->l_event,
1019 !ocfs2_check_wait_flag(lockres, OCFS2_LOCK_BUSY));
1020}
1021
1022static inline void ocfs2_wait_on_refreshing_lock(struct ocfs2_lock_res *lockres)
1023
1024{
1025 wait_event(lockres->l_event,
1026 !ocfs2_check_wait_flag(lockres, OCFS2_LOCK_REFRESHING));
1027}
1028
1029/* predict what lock level we'll be dropping down to on behalf
1030 * of another node, and return true if the currently wanted
1031 * level will be compatible with it. */
1032static inline int ocfs2_may_continue_on_blocked_lock(struct ocfs2_lock_res *lockres,
1033 int wanted)
1034{
1035 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_BLOCKED));
1036
1037 return wanted <= ocfs2_highest_compat_lock_level(lockres->l_blocking);
1038}
1039
1040static void ocfs2_init_mask_waiter(struct ocfs2_mask_waiter *mw)
1041{
1042 INIT_LIST_HEAD(&mw->mw_item);
1043 init_completion(&mw->mw_complete);
1044}
1045
1046static int ocfs2_wait_for_mask(struct ocfs2_mask_waiter *mw)
1047{
1048 wait_for_completion(&mw->mw_complete);
1049 /* Re-arm the completion in case we want to wait on it again */
1050 INIT_COMPLETION(mw->mw_complete);
1051 return mw->mw_status;
1052}
1053
1054static void lockres_add_mask_waiter(struct ocfs2_lock_res *lockres,
1055 struct ocfs2_mask_waiter *mw,
1056 unsigned long mask,
1057 unsigned long goal)
1058{
1059 BUG_ON(!list_empty(&mw->mw_item));
1060
1061 assert_spin_locked(&lockres->l_lock);
1062
1063 list_add_tail(&mw->mw_item, &lockres->l_mask_waiters);
1064 mw->mw_mask = mask;
1065 mw->mw_goal = goal;
1066}
1067
1068/* returns 0 if the mw that was removed was already satisfied, -EBUSY
1069 * if the mask still hadn't reached its goal */
1070static int lockres_remove_mask_waiter(struct ocfs2_lock_res *lockres,
1071 struct ocfs2_mask_waiter *mw)
1072{
1073 unsigned long flags;
1074 int ret = 0;
1075
1076 spin_lock_irqsave(&lockres->l_lock, flags);
1077 if (!list_empty(&mw->mw_item)) {
1078 if ((lockres->l_flags & mw->mw_mask) != mw->mw_goal)
1079 ret = -EBUSY;
1080
1081 list_del_init(&mw->mw_item);
1082 init_completion(&mw->mw_complete);
1083 }
1084 spin_unlock_irqrestore(&lockres->l_lock, flags);
1085
1086 return ret;
1087
1088}
1089
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001090static int ocfs2_wait_for_mask_interruptible(struct ocfs2_mask_waiter *mw,
1091 struct ocfs2_lock_res *lockres)
1092{
1093 int ret;
1094
1095 ret = wait_for_completion_interruptible(&mw->mw_complete);
1096 if (ret)
1097 lockres_remove_mask_waiter(lockres, mw);
1098 else
1099 ret = mw->mw_status;
1100 /* Re-arm the completion in case we want to wait on it again */
1101 INIT_COMPLETION(mw->mw_complete);
1102 return ret;
1103}
1104
Mark Fashehccd979b2005-12-15 14:31:24 -08001105static int ocfs2_cluster_lock(struct ocfs2_super *osb,
1106 struct ocfs2_lock_res *lockres,
1107 int level,
Joel Beckerbd3e7612008-02-01 12:14:57 -08001108 u32 lkm_flags,
Mark Fashehccd979b2005-12-15 14:31:24 -08001109 int arg_flags)
1110{
1111 struct ocfs2_mask_waiter mw;
Mark Fashehccd979b2005-12-15 14:31:24 -08001112 int wait, catch_signals = !(osb->s_mount_opt & OCFS2_MOUNT_NOINTR);
1113 int ret = 0; /* gcc doesn't realize wait = 1 guarantees ret is set */
1114 unsigned long flags;
Joel Beckerde551242008-02-01 14:45:08 -08001115 unsigned int gen;
Mark Fashehccd979b2005-12-15 14:31:24 -08001116
1117 mlog_entry_void();
1118
1119 ocfs2_init_mask_waiter(&mw);
1120
Mark Fashehb80fc012006-09-12 22:08:14 -07001121 if (lockres->l_ops->flags & LOCK_TYPE_USES_LVB)
Joel Beckerbd3e7612008-02-01 12:14:57 -08001122 lkm_flags |= DLM_LKF_VALBLK;
Mark Fashehb80fc012006-09-12 22:08:14 -07001123
Mark Fashehccd979b2005-12-15 14:31:24 -08001124again:
1125 wait = 0;
1126
1127 if (catch_signals && signal_pending(current)) {
1128 ret = -ERESTARTSYS;
1129 goto out;
1130 }
1131
1132 spin_lock_irqsave(&lockres->l_lock, flags);
1133
1134 mlog_bug_on_msg(lockres->l_flags & OCFS2_LOCK_FREEING,
1135 "Cluster lock called on freeing lockres %s! flags "
1136 "0x%lx\n", lockres->l_name, lockres->l_flags);
1137
1138 /* We only compare against the currently granted level
1139 * here. If the lock is blocked waiting on a downconvert,
1140 * we'll get caught below. */
1141 if (lockres->l_flags & OCFS2_LOCK_BUSY &&
1142 level > lockres->l_level) {
1143 /* is someone sitting in dlm_lock? If so, wait on
1144 * them. */
1145 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_BUSY, 0);
1146 wait = 1;
1147 goto unlock;
1148 }
1149
Mark Fashehccd979b2005-12-15 14:31:24 -08001150 if (lockres->l_flags & OCFS2_LOCK_BLOCKED &&
1151 !ocfs2_may_continue_on_blocked_lock(lockres, level)) {
1152 /* is the lock is currently blocked on behalf of
1153 * another node */
1154 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_BLOCKED, 0);
1155 wait = 1;
1156 goto unlock;
1157 }
1158
1159 if (level > lockres->l_level) {
1160 if (lockres->l_action != OCFS2_AST_INVALID)
1161 mlog(ML_ERROR, "lockres %s has action %u pending\n",
1162 lockres->l_name, lockres->l_action);
1163
Mark Fasheh019d1b22007-10-05 12:09:05 -07001164 if (!(lockres->l_flags & OCFS2_LOCK_ATTACHED)) {
1165 lockres->l_action = OCFS2_AST_ATTACH;
Joel Beckerbd3e7612008-02-01 12:14:57 -08001166 lkm_flags &= ~DLM_LKF_CONVERT;
Mark Fasheh019d1b22007-10-05 12:09:05 -07001167 } else {
1168 lockres->l_action = OCFS2_AST_CONVERT;
Joel Beckerbd3e7612008-02-01 12:14:57 -08001169 lkm_flags |= DLM_LKF_CONVERT;
Mark Fasheh019d1b22007-10-05 12:09:05 -07001170 }
1171
Mark Fashehccd979b2005-12-15 14:31:24 -08001172 lockres->l_requested = level;
1173 lockres_or_flags(lockres, OCFS2_LOCK_BUSY);
Joel Beckerde551242008-02-01 14:45:08 -08001174 gen = lockres_set_pending(lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08001175 spin_unlock_irqrestore(&lockres->l_lock, flags);
1176
Joel Beckerbd3e7612008-02-01 12:14:57 -08001177 BUG_ON(level == DLM_LOCK_IV);
1178 BUG_ON(level == DLM_LOCK_NL);
Mark Fashehccd979b2005-12-15 14:31:24 -08001179
1180 mlog(0, "lock %s, convert from %d to level = %d\n",
1181 lockres->l_name, lockres->l_level, level);
1182
1183 /* call dlm_lock to upgrade lock now */
Joel Becker4670c462008-02-01 14:39:35 -08001184 ret = ocfs2_dlm_lock(osb->cconn,
Joel Becker7431cd72008-02-01 12:15:37 -08001185 level,
1186 &lockres->l_lksb,
1187 lkm_flags,
1188 lockres->l_name,
1189 OCFS2_LOCK_ID_MAX_LEN - 1,
1190 lockres);
Joel Beckerde551242008-02-01 14:45:08 -08001191 lockres_clear_pending(lockres, gen, osb);
Joel Becker7431cd72008-02-01 12:15:37 -08001192 if (ret) {
1193 if (!(lkm_flags & DLM_LKF_NOQUEUE) ||
1194 (ret != -EAGAIN)) {
Joel Becker24ef1812008-01-29 17:37:32 -08001195 ocfs2_log_dlm_error("ocfs2_dlm_lock",
Joel Becker7431cd72008-02-01 12:15:37 -08001196 ret, lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08001197 }
1198 ocfs2_recover_from_dlm_error(lockres, 1);
1199 goto out;
1200 }
1201
Joel Becker24ef1812008-01-29 17:37:32 -08001202 mlog(0, "lock %s, successfull return from ocfs2_dlm_lock\n",
Mark Fashehccd979b2005-12-15 14:31:24 -08001203 lockres->l_name);
1204
1205 /* At this point we've gone inside the dlm and need to
1206 * complete our work regardless. */
1207 catch_signals = 0;
1208
1209 /* wait for busy to clear and carry on */
1210 goto again;
1211 }
1212
1213 /* Ok, if we get here then we're good to go. */
1214 ocfs2_inc_holders(lockres, level);
1215
1216 ret = 0;
1217unlock:
1218 spin_unlock_irqrestore(&lockres->l_lock, flags);
1219out:
1220 /*
1221 * This is helping work around a lock inversion between the page lock
1222 * and dlm locks. One path holds the page lock while calling aops
1223 * which block acquiring dlm locks. The voting thread holds dlm
1224 * locks while acquiring page locks while down converting data locks.
1225 * This block is helping an aop path notice the inversion and back
1226 * off to unlock its page lock before trying the dlm lock again.
1227 */
1228 if (wait && arg_flags & OCFS2_LOCK_NONBLOCK &&
1229 mw.mw_mask & (OCFS2_LOCK_BUSY|OCFS2_LOCK_BLOCKED)) {
1230 wait = 0;
1231 if (lockres_remove_mask_waiter(lockres, &mw))
1232 ret = -EAGAIN;
1233 else
1234 goto again;
1235 }
1236 if (wait) {
1237 ret = ocfs2_wait_for_mask(&mw);
1238 if (ret == 0)
1239 goto again;
1240 mlog_errno(ret);
1241 }
1242
1243 mlog_exit(ret);
1244 return ret;
1245}
1246
1247static void ocfs2_cluster_unlock(struct ocfs2_super *osb,
1248 struct ocfs2_lock_res *lockres,
1249 int level)
1250{
1251 unsigned long flags;
1252
1253 mlog_entry_void();
1254 spin_lock_irqsave(&lockres->l_lock, flags);
1255 ocfs2_dec_holders(lockres, level);
Mark Fasheh34d024f2007-09-24 15:56:19 -07001256 ocfs2_downconvert_on_unlock(osb, lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08001257 spin_unlock_irqrestore(&lockres->l_lock, flags);
1258 mlog_exit_void();
1259}
1260
Adrian Bunkda661162006-11-20 03:24:28 +01001261static int ocfs2_create_new_lock(struct ocfs2_super *osb,
1262 struct ocfs2_lock_res *lockres,
1263 int ex,
1264 int local)
Mark Fashehccd979b2005-12-15 14:31:24 -08001265{
Joel Beckerbd3e7612008-02-01 12:14:57 -08001266 int level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -08001267 unsigned long flags;
Joel Beckerbd3e7612008-02-01 12:14:57 -08001268 u32 lkm_flags = local ? DLM_LKF_LOCAL : 0;
Mark Fashehccd979b2005-12-15 14:31:24 -08001269
1270 spin_lock_irqsave(&lockres->l_lock, flags);
1271 BUG_ON(lockres->l_flags & OCFS2_LOCK_ATTACHED);
1272 lockres_or_flags(lockres, OCFS2_LOCK_LOCAL);
1273 spin_unlock_irqrestore(&lockres->l_lock, flags);
1274
Mark Fasheh24c19ef2006-09-22 17:28:19 -07001275 return ocfs2_lock_create(osb, lockres, level, lkm_flags);
Mark Fashehccd979b2005-12-15 14:31:24 -08001276}
1277
1278/* Grants us an EX lock on the data and metadata resources, skipping
1279 * the normal cluster directory lookup. Use this ONLY on newly created
1280 * inodes which other nodes can't possibly see, and which haven't been
1281 * hashed in the inode hash yet. This can give us a good performance
1282 * increase as it'll skip the network broadcast normally associated
1283 * with creating a new lock resource. */
1284int ocfs2_create_new_inode_locks(struct inode *inode)
1285{
1286 int ret;
Mark Fashehd680efe2006-09-08 14:14:34 -07001287 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001288
1289 BUG_ON(!inode);
1290 BUG_ON(!ocfs2_inode_is_new(inode));
1291
1292 mlog_entry_void();
1293
Mark Fashehb06970532006-03-03 10:24:33 -08001294 mlog(0, "Inode %llu\n", (unsigned long long)OCFS2_I(inode)->ip_blkno);
Mark Fashehccd979b2005-12-15 14:31:24 -08001295
1296 /* NOTE: That we don't increment any of the holder counts, nor
1297 * do we add anything to a journal handle. Since this is
1298 * supposed to be a new inode which the cluster doesn't know
1299 * about yet, there is no need to. As far as the LVB handling
1300 * is concerned, this is basically like acquiring an EX lock
1301 * on a resource which has an invalid one -- we'll set it
1302 * valid when we release the EX. */
1303
Mark Fasheh24c19ef2006-09-22 17:28:19 -07001304 ret = ocfs2_create_new_lock(osb, &OCFS2_I(inode)->ip_rw_lockres, 1, 1);
Mark Fashehccd979b2005-12-15 14:31:24 -08001305 if (ret) {
1306 mlog_errno(ret);
1307 goto bail;
1308 }
1309
Mark Fasheh24c19ef2006-09-22 17:28:19 -07001310 /*
Joel Beckerbd3e7612008-02-01 12:14:57 -08001311 * We don't want to use DLM_LKF_LOCAL on a meta data lock as they
Mark Fasheh24c19ef2006-09-22 17:28:19 -07001312 * don't use a generation in their lock names.
1313 */
Mark Fashehe63aecb62007-10-18 15:30:42 -07001314 ret = ocfs2_create_new_lock(osb, &OCFS2_I(inode)->ip_inode_lockres, 1, 0);
Mark Fashehccd979b2005-12-15 14:31:24 -08001315 if (ret) {
1316 mlog_errno(ret);
1317 goto bail;
1318 }
1319
Tiger Yang50008632007-03-20 16:01:38 -07001320 ret = ocfs2_create_new_lock(osb, &OCFS2_I(inode)->ip_open_lockres, 0, 0);
1321 if (ret) {
1322 mlog_errno(ret);
1323 goto bail;
1324 }
1325
Mark Fashehccd979b2005-12-15 14:31:24 -08001326bail:
1327 mlog_exit(ret);
1328 return ret;
1329}
1330
1331int ocfs2_rw_lock(struct inode *inode, int write)
1332{
1333 int status, level;
1334 struct ocfs2_lock_res *lockres;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08001335 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001336
1337 BUG_ON(!inode);
1338
1339 mlog_entry_void();
1340
Mark Fashehb06970532006-03-03 10:24:33 -08001341 mlog(0, "inode %llu take %s RW lock\n",
1342 (unsigned long long)OCFS2_I(inode)->ip_blkno,
Mark Fashehccd979b2005-12-15 14:31:24 -08001343 write ? "EXMODE" : "PRMODE");
1344
Sunil Mushranc271c5c2006-12-05 17:56:35 -08001345 if (ocfs2_mount_local(osb))
1346 return 0;
1347
Mark Fashehccd979b2005-12-15 14:31:24 -08001348 lockres = &OCFS2_I(inode)->ip_rw_lockres;
1349
Joel Beckerbd3e7612008-02-01 12:14:57 -08001350 level = write ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -08001351
1352 status = ocfs2_cluster_lock(OCFS2_SB(inode->i_sb), lockres, level, 0,
1353 0);
1354 if (status < 0)
1355 mlog_errno(status);
1356
1357 mlog_exit(status);
1358 return status;
1359}
1360
1361void ocfs2_rw_unlock(struct inode *inode, int write)
1362{
Joel Beckerbd3e7612008-02-01 12:14:57 -08001363 int level = write ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -08001364 struct ocfs2_lock_res *lockres = &OCFS2_I(inode)->ip_rw_lockres;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08001365 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001366
1367 mlog_entry_void();
1368
Mark Fashehb06970532006-03-03 10:24:33 -08001369 mlog(0, "inode %llu drop %s RW lock\n",
1370 (unsigned long long)OCFS2_I(inode)->ip_blkno,
Mark Fashehccd979b2005-12-15 14:31:24 -08001371 write ? "EXMODE" : "PRMODE");
1372
Sunil Mushranc271c5c2006-12-05 17:56:35 -08001373 if (!ocfs2_mount_local(osb))
1374 ocfs2_cluster_unlock(OCFS2_SB(inode->i_sb), lockres, level);
Mark Fashehccd979b2005-12-15 14:31:24 -08001375
1376 mlog_exit_void();
1377}
1378
Tiger Yang50008632007-03-20 16:01:38 -07001379/*
1380 * ocfs2_open_lock always get PR mode lock.
1381 */
1382int ocfs2_open_lock(struct inode *inode)
1383{
1384 int status = 0;
1385 struct ocfs2_lock_res *lockres;
1386 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
1387
1388 BUG_ON(!inode);
1389
1390 mlog_entry_void();
1391
1392 mlog(0, "inode %llu take PRMODE open lock\n",
1393 (unsigned long long)OCFS2_I(inode)->ip_blkno);
1394
1395 if (ocfs2_mount_local(osb))
1396 goto out;
1397
1398 lockres = &OCFS2_I(inode)->ip_open_lockres;
1399
1400 status = ocfs2_cluster_lock(OCFS2_SB(inode->i_sb), lockres,
Joel Beckerbd3e7612008-02-01 12:14:57 -08001401 DLM_LOCK_PR, 0, 0);
Tiger Yang50008632007-03-20 16:01:38 -07001402 if (status < 0)
1403 mlog_errno(status);
1404
1405out:
1406 mlog_exit(status);
1407 return status;
1408}
1409
1410int ocfs2_try_open_lock(struct inode *inode, int write)
1411{
1412 int status = 0, level;
1413 struct ocfs2_lock_res *lockres;
1414 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
1415
1416 BUG_ON(!inode);
1417
1418 mlog_entry_void();
1419
1420 mlog(0, "inode %llu try to take %s open lock\n",
1421 (unsigned long long)OCFS2_I(inode)->ip_blkno,
1422 write ? "EXMODE" : "PRMODE");
1423
1424 if (ocfs2_mount_local(osb))
1425 goto out;
1426
1427 lockres = &OCFS2_I(inode)->ip_open_lockres;
1428
Joel Beckerbd3e7612008-02-01 12:14:57 -08001429 level = write ? DLM_LOCK_EX : DLM_LOCK_PR;
Tiger Yang50008632007-03-20 16:01:38 -07001430
1431 /*
1432 * The file system may already holding a PRMODE/EXMODE open lock.
Joel Beckerbd3e7612008-02-01 12:14:57 -08001433 * Since we pass DLM_LKF_NOQUEUE, the request won't block waiting on
Tiger Yang50008632007-03-20 16:01:38 -07001434 * other nodes and the -EAGAIN will indicate to the caller that
1435 * this inode is still in use.
1436 */
1437 status = ocfs2_cluster_lock(OCFS2_SB(inode->i_sb), lockres,
Joel Beckerbd3e7612008-02-01 12:14:57 -08001438 level, DLM_LKF_NOQUEUE, 0);
Tiger Yang50008632007-03-20 16:01:38 -07001439
1440out:
1441 mlog_exit(status);
1442 return status;
1443}
1444
1445/*
1446 * ocfs2_open_unlock unlock PR and EX mode open locks.
1447 */
1448void ocfs2_open_unlock(struct inode *inode)
1449{
1450 struct ocfs2_lock_res *lockres = &OCFS2_I(inode)->ip_open_lockres;
1451 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
1452
1453 mlog_entry_void();
1454
1455 mlog(0, "inode %llu drop open lock\n",
1456 (unsigned long long)OCFS2_I(inode)->ip_blkno);
1457
1458 if (ocfs2_mount_local(osb))
1459 goto out;
1460
1461 if(lockres->l_ro_holders)
1462 ocfs2_cluster_unlock(OCFS2_SB(inode->i_sb), lockres,
Joel Beckerbd3e7612008-02-01 12:14:57 -08001463 DLM_LOCK_PR);
Tiger Yang50008632007-03-20 16:01:38 -07001464 if(lockres->l_ex_holders)
1465 ocfs2_cluster_unlock(OCFS2_SB(inode->i_sb), lockres,
Joel Beckerbd3e7612008-02-01 12:14:57 -08001466 DLM_LOCK_EX);
Tiger Yang50008632007-03-20 16:01:38 -07001467
1468out:
1469 mlog_exit_void();
1470}
1471
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001472static int ocfs2_flock_handle_signal(struct ocfs2_lock_res *lockres,
1473 int level)
1474{
1475 int ret;
1476 struct ocfs2_super *osb = ocfs2_get_lockres_osb(lockres);
1477 unsigned long flags;
1478 struct ocfs2_mask_waiter mw;
1479
1480 ocfs2_init_mask_waiter(&mw);
1481
1482retry_cancel:
1483 spin_lock_irqsave(&lockres->l_lock, flags);
1484 if (lockres->l_flags & OCFS2_LOCK_BUSY) {
1485 ret = ocfs2_prepare_cancel_convert(osb, lockres);
1486 if (ret) {
1487 spin_unlock_irqrestore(&lockres->l_lock, flags);
1488 ret = ocfs2_cancel_convert(osb, lockres);
1489 if (ret < 0) {
1490 mlog_errno(ret);
1491 goto out;
1492 }
1493 goto retry_cancel;
1494 }
1495 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_BUSY, 0);
1496 spin_unlock_irqrestore(&lockres->l_lock, flags);
1497
1498 ocfs2_wait_for_mask(&mw);
1499 goto retry_cancel;
1500 }
1501
1502 ret = -ERESTARTSYS;
1503 /*
1504 * We may still have gotten the lock, in which case there's no
1505 * point to restarting the syscall.
1506 */
1507 if (lockres->l_level == level)
1508 ret = 0;
1509
1510 mlog(0, "Cancel returning %d. flags: 0x%lx, level: %d, act: %d\n", ret,
1511 lockres->l_flags, lockres->l_level, lockres->l_action);
1512
1513 spin_unlock_irqrestore(&lockres->l_lock, flags);
1514
1515out:
1516 return ret;
1517}
1518
1519/*
1520 * ocfs2_file_lock() and ocfs2_file_unlock() map to a single pair of
1521 * flock() calls. The locking approach this requires is sufficiently
1522 * different from all other cluster lock types that we implement a
1523 * seperate path to the "low-level" dlm calls. In particular:
1524 *
1525 * - No optimization of lock levels is done - we take at exactly
1526 * what's been requested.
1527 *
1528 * - No lock caching is employed. We immediately downconvert to
1529 * no-lock at unlock time. This also means flock locks never go on
1530 * the blocking list).
1531 *
1532 * - Since userspace can trivially deadlock itself with flock, we make
1533 * sure to allow cancellation of a misbehaving applications flock()
1534 * request.
1535 *
1536 * - Access to any flock lockres doesn't require concurrency, so we
1537 * can simplify the code by requiring the caller to guarantee
1538 * serialization of dlmglue flock calls.
1539 */
1540int ocfs2_file_lock(struct file *file, int ex, int trylock)
1541{
1542 int ret, level = ex ? LKM_EXMODE : LKM_PRMODE;
1543 unsigned int lkm_flags = trylock ? LKM_NOQUEUE : 0;
1544 unsigned long flags;
1545 struct ocfs2_file_private *fp = file->private_data;
1546 struct ocfs2_lock_res *lockres = &fp->fp_flock;
1547 struct ocfs2_super *osb = OCFS2_SB(file->f_mapping->host->i_sb);
1548 struct ocfs2_mask_waiter mw;
1549
1550 ocfs2_init_mask_waiter(&mw);
1551
1552 if ((lockres->l_flags & OCFS2_LOCK_BUSY) ||
Joel Beckerbd3e7612008-02-01 12:14:57 -08001553 (lockres->l_level > DLM_LOCK_NL)) {
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001554 mlog(ML_ERROR,
1555 "File lock \"%s\" has busy or locked state: flags: 0x%lx, "
1556 "level: %u\n", lockres->l_name, lockres->l_flags,
1557 lockres->l_level);
1558 return -EINVAL;
1559 }
1560
1561 spin_lock_irqsave(&lockres->l_lock, flags);
1562 if (!(lockres->l_flags & OCFS2_LOCK_ATTACHED)) {
1563 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_BUSY, 0);
1564 spin_unlock_irqrestore(&lockres->l_lock, flags);
1565
1566 /*
1567 * Get the lock at NLMODE to start - that way we
1568 * can cancel the upconvert request if need be.
1569 */
1570 ret = ocfs2_lock_create(osb, lockres, LKM_NLMODE, 0);
1571 if (ret < 0) {
1572 mlog_errno(ret);
1573 goto out;
1574 }
1575
1576 ret = ocfs2_wait_for_mask(&mw);
1577 if (ret) {
1578 mlog_errno(ret);
1579 goto out;
1580 }
1581 spin_lock_irqsave(&lockres->l_lock, flags);
1582 }
1583
1584 lockres->l_action = OCFS2_AST_CONVERT;
1585 lkm_flags |= LKM_CONVERT;
1586 lockres->l_requested = level;
1587 lockres_or_flags(lockres, OCFS2_LOCK_BUSY);
1588
1589 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_BUSY, 0);
1590 spin_unlock_irqrestore(&lockres->l_lock, flags);
1591
Joel Becker4670c462008-02-01 14:39:35 -08001592 ret = ocfs2_dlm_lock(osb->cconn, level, &lockres->l_lksb, lkm_flags,
Joel Becker24ef1812008-01-29 17:37:32 -08001593 lockres->l_name, OCFS2_LOCK_ID_MAX_LEN - 1,
1594 lockres);
Joel Becker7431cd72008-02-01 12:15:37 -08001595 if (ret) {
1596 if (!trylock || (ret != -EAGAIN)) {
Joel Becker24ef1812008-01-29 17:37:32 -08001597 ocfs2_log_dlm_error("ocfs2_dlm_lock", ret, lockres);
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001598 ret = -EINVAL;
1599 }
1600
1601 ocfs2_recover_from_dlm_error(lockres, 1);
1602 lockres_remove_mask_waiter(lockres, &mw);
1603 goto out;
1604 }
1605
1606 ret = ocfs2_wait_for_mask_interruptible(&mw, lockres);
1607 if (ret == -ERESTARTSYS) {
1608 /*
1609 * Userspace can cause deadlock itself with
1610 * flock(). Current behavior locally is to allow the
1611 * deadlock, but abort the system call if a signal is
1612 * received. We follow this example, otherwise a
1613 * poorly written program could sit in kernel until
1614 * reboot.
1615 *
1616 * Handling this is a bit more complicated for Ocfs2
1617 * though. We can't exit this function with an
1618 * outstanding lock request, so a cancel convert is
1619 * required. We intentionally overwrite 'ret' - if the
1620 * cancel fails and the lock was granted, it's easier
1621 * to just bubble sucess back up to the user.
1622 */
1623 ret = ocfs2_flock_handle_signal(lockres, level);
1624 }
1625
1626out:
1627
1628 mlog(0, "Lock: \"%s\" ex: %d, trylock: %d, returns: %d\n",
1629 lockres->l_name, ex, trylock, ret);
1630 return ret;
1631}
1632
1633void ocfs2_file_unlock(struct file *file)
1634{
1635 int ret;
Joel Beckerde551242008-02-01 14:45:08 -08001636 unsigned int gen;
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001637 unsigned long flags;
1638 struct ocfs2_file_private *fp = file->private_data;
1639 struct ocfs2_lock_res *lockres = &fp->fp_flock;
1640 struct ocfs2_super *osb = OCFS2_SB(file->f_mapping->host->i_sb);
1641 struct ocfs2_mask_waiter mw;
1642
1643 ocfs2_init_mask_waiter(&mw);
1644
1645 if (!(lockres->l_flags & OCFS2_LOCK_ATTACHED))
1646 return;
1647
1648 if (lockres->l_level == LKM_NLMODE)
1649 return;
1650
1651 mlog(0, "Unlock: \"%s\" flags: 0x%lx, level: %d, act: %d\n",
1652 lockres->l_name, lockres->l_flags, lockres->l_level,
1653 lockres->l_action);
1654
1655 spin_lock_irqsave(&lockres->l_lock, flags);
1656 /*
1657 * Fake a blocking ast for the downconvert code.
1658 */
1659 lockres_or_flags(lockres, OCFS2_LOCK_BLOCKED);
Joel Beckerbd3e7612008-02-01 12:14:57 -08001660 lockres->l_blocking = DLM_LOCK_EX;
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001661
Joel Beckerde551242008-02-01 14:45:08 -08001662 gen = ocfs2_prepare_downconvert(lockres, LKM_NLMODE);
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001663 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_BUSY, 0);
1664 spin_unlock_irqrestore(&lockres->l_lock, flags);
1665
Joel Beckerde551242008-02-01 14:45:08 -08001666 ret = ocfs2_downconvert_lock(osb, lockres, LKM_NLMODE, 0, gen);
Mark Fashehcf8e06f2007-12-20 16:43:10 -08001667 if (ret) {
1668 mlog_errno(ret);
1669 return;
1670 }
1671
1672 ret = ocfs2_wait_for_mask(&mw);
1673 if (ret)
1674 mlog_errno(ret);
1675}
1676
Mark Fasheh34d024f2007-09-24 15:56:19 -07001677static void ocfs2_downconvert_on_unlock(struct ocfs2_super *osb,
1678 struct ocfs2_lock_res *lockres)
Mark Fashehccd979b2005-12-15 14:31:24 -08001679{
1680 int kick = 0;
1681
1682 mlog_entry_void();
1683
1684 /* If we know that another node is waiting on our lock, kick
Mark Fasheh34d024f2007-09-24 15:56:19 -07001685 * the downconvert thread * pre-emptively when we reach a release
Mark Fashehccd979b2005-12-15 14:31:24 -08001686 * condition. */
1687 if (lockres->l_flags & OCFS2_LOCK_BLOCKED) {
1688 switch(lockres->l_blocking) {
Joel Beckerbd3e7612008-02-01 12:14:57 -08001689 case DLM_LOCK_EX:
Mark Fashehccd979b2005-12-15 14:31:24 -08001690 if (!lockres->l_ex_holders && !lockres->l_ro_holders)
1691 kick = 1;
1692 break;
Joel Beckerbd3e7612008-02-01 12:14:57 -08001693 case DLM_LOCK_PR:
Mark Fashehccd979b2005-12-15 14:31:24 -08001694 if (!lockres->l_ex_holders)
1695 kick = 1;
1696 break;
1697 default:
1698 BUG();
1699 }
1700 }
1701
1702 if (kick)
Mark Fasheh34d024f2007-09-24 15:56:19 -07001703 ocfs2_wake_downconvert_thread(osb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001704
1705 mlog_exit_void();
1706}
1707
Mark Fashehccd979b2005-12-15 14:31:24 -08001708#define OCFS2_SEC_BITS 34
1709#define OCFS2_SEC_SHIFT (64 - 34)
1710#define OCFS2_NSEC_MASK ((1ULL << OCFS2_SEC_SHIFT) - 1)
1711
1712/* LVB only has room for 64 bits of time here so we pack it for
1713 * now. */
1714static u64 ocfs2_pack_timespec(struct timespec *spec)
1715{
1716 u64 res;
1717 u64 sec = spec->tv_sec;
1718 u32 nsec = spec->tv_nsec;
1719
1720 res = (sec << OCFS2_SEC_SHIFT) | (nsec & OCFS2_NSEC_MASK);
1721
1722 return res;
1723}
1724
1725/* Call this with the lockres locked. I am reasonably sure we don't
1726 * need ip_lock in this function as anyone who would be changing those
Mark Fashehe63aecb62007-10-18 15:30:42 -07001727 * values is supposed to be blocked in ocfs2_inode_lock right now. */
Mark Fashehccd979b2005-12-15 14:31:24 -08001728static void __ocfs2_stuff_meta_lvb(struct inode *inode)
1729{
1730 struct ocfs2_inode_info *oi = OCFS2_I(inode);
Mark Fashehe63aecb62007-10-18 15:30:42 -07001731 struct ocfs2_lock_res *lockres = &oi->ip_inode_lockres;
Mark Fashehccd979b2005-12-15 14:31:24 -08001732 struct ocfs2_meta_lvb *lvb;
1733
1734 mlog_entry_void();
1735
Joel Becker8f2c9c12008-02-01 12:16:57 -08001736 lvb = (struct ocfs2_meta_lvb *)ocfs2_dlm_lvb(&lockres->l_lksb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001737
Mark Fasheh24c19ef2006-09-22 17:28:19 -07001738 /*
1739 * Invalidate the LVB of a deleted inode - this way other
1740 * nodes are forced to go to disk and discover the new inode
1741 * status.
1742 */
1743 if (oi->ip_flags & OCFS2_INODE_DELETED) {
1744 lvb->lvb_version = 0;
1745 goto out;
1746 }
1747
Mark Fasheh4d3b83f2006-09-12 15:22:18 -07001748 lvb->lvb_version = OCFS2_LVB_VERSION;
Mark Fashehccd979b2005-12-15 14:31:24 -08001749 lvb->lvb_isize = cpu_to_be64(i_size_read(inode));
1750 lvb->lvb_iclusters = cpu_to_be32(oi->ip_clusters);
1751 lvb->lvb_iuid = cpu_to_be32(inode->i_uid);
1752 lvb->lvb_igid = cpu_to_be32(inode->i_gid);
1753 lvb->lvb_imode = cpu_to_be16(inode->i_mode);
1754 lvb->lvb_inlink = cpu_to_be16(inode->i_nlink);
1755 lvb->lvb_iatime_packed =
1756 cpu_to_be64(ocfs2_pack_timespec(&inode->i_atime));
1757 lvb->lvb_ictime_packed =
1758 cpu_to_be64(ocfs2_pack_timespec(&inode->i_ctime));
1759 lvb->lvb_imtime_packed =
1760 cpu_to_be64(ocfs2_pack_timespec(&inode->i_mtime));
Herbert Poetzlca4d1472006-07-03 17:27:12 -07001761 lvb->lvb_iattr = cpu_to_be32(oi->ip_attr);
Mark Fasheh15b1e362007-09-07 13:58:15 -07001762 lvb->lvb_idynfeatures = cpu_to_be16(oi->ip_dyn_features);
Mark Fashehf9e2d822006-09-12 15:35:49 -07001763 lvb->lvb_igeneration = cpu_to_be32(inode->i_generation);
Mark Fashehccd979b2005-12-15 14:31:24 -08001764
Mark Fasheh24c19ef2006-09-22 17:28:19 -07001765out:
Mark Fashehccd979b2005-12-15 14:31:24 -08001766 mlog_meta_lvb(0, lockres);
1767
1768 mlog_exit_void();
1769}
1770
1771static void ocfs2_unpack_timespec(struct timespec *spec,
1772 u64 packed_time)
1773{
1774 spec->tv_sec = packed_time >> OCFS2_SEC_SHIFT;
1775 spec->tv_nsec = packed_time & OCFS2_NSEC_MASK;
1776}
1777
1778static void ocfs2_refresh_inode_from_lvb(struct inode *inode)
1779{
1780 struct ocfs2_inode_info *oi = OCFS2_I(inode);
Mark Fashehe63aecb62007-10-18 15:30:42 -07001781 struct ocfs2_lock_res *lockres = &oi->ip_inode_lockres;
Mark Fashehccd979b2005-12-15 14:31:24 -08001782 struct ocfs2_meta_lvb *lvb;
1783
1784 mlog_entry_void();
1785
1786 mlog_meta_lvb(0, lockres);
1787
Joel Becker8f2c9c12008-02-01 12:16:57 -08001788 lvb = (struct ocfs2_meta_lvb *)ocfs2_dlm_lvb(&lockres->l_lksb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001789
1790 /* We're safe here without the lockres lock... */
1791 spin_lock(&oi->ip_lock);
1792 oi->ip_clusters = be32_to_cpu(lvb->lvb_iclusters);
1793 i_size_write(inode, be64_to_cpu(lvb->lvb_isize));
1794
Herbert Poetzlca4d1472006-07-03 17:27:12 -07001795 oi->ip_attr = be32_to_cpu(lvb->lvb_iattr);
Mark Fasheh15b1e362007-09-07 13:58:15 -07001796 oi->ip_dyn_features = be16_to_cpu(lvb->lvb_idynfeatures);
Herbert Poetzlca4d1472006-07-03 17:27:12 -07001797 ocfs2_set_inode_flags(inode);
1798
Mark Fashehccd979b2005-12-15 14:31:24 -08001799 /* fast-symlinks are a special case */
1800 if (S_ISLNK(inode->i_mode) && !oi->ip_clusters)
1801 inode->i_blocks = 0;
1802 else
Mark Fasheh8110b072007-03-22 16:53:23 -07001803 inode->i_blocks = ocfs2_inode_sector_count(inode);
Mark Fashehccd979b2005-12-15 14:31:24 -08001804
1805 inode->i_uid = be32_to_cpu(lvb->lvb_iuid);
1806 inode->i_gid = be32_to_cpu(lvb->lvb_igid);
1807 inode->i_mode = be16_to_cpu(lvb->lvb_imode);
1808 inode->i_nlink = be16_to_cpu(lvb->lvb_inlink);
1809 ocfs2_unpack_timespec(&inode->i_atime,
1810 be64_to_cpu(lvb->lvb_iatime_packed));
1811 ocfs2_unpack_timespec(&inode->i_mtime,
1812 be64_to_cpu(lvb->lvb_imtime_packed));
1813 ocfs2_unpack_timespec(&inode->i_ctime,
1814 be64_to_cpu(lvb->lvb_ictime_packed));
1815 spin_unlock(&oi->ip_lock);
1816
1817 mlog_exit_void();
1818}
1819
Mark Fashehf9e2d822006-09-12 15:35:49 -07001820static inline int ocfs2_meta_lvb_is_trustable(struct inode *inode,
1821 struct ocfs2_lock_res *lockres)
Mark Fashehccd979b2005-12-15 14:31:24 -08001822{
Joel Becker8f2c9c12008-02-01 12:16:57 -08001823 struct ocfs2_meta_lvb *lvb =
1824 (struct ocfs2_meta_lvb *)ocfs2_dlm_lvb(&lockres->l_lksb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001825
Mark Fashehf9e2d822006-09-12 15:35:49 -07001826 if (lvb->lvb_version == OCFS2_LVB_VERSION
1827 && be32_to_cpu(lvb->lvb_igeneration) == inode->i_generation)
Mark Fashehccd979b2005-12-15 14:31:24 -08001828 return 1;
1829 return 0;
1830}
1831
1832/* Determine whether a lock resource needs to be refreshed, and
1833 * arbitrate who gets to refresh it.
1834 *
1835 * 0 means no refresh needed.
1836 *
1837 * > 0 means you need to refresh this and you MUST call
1838 * ocfs2_complete_lock_res_refresh afterwards. */
1839static int ocfs2_should_refresh_lock_res(struct ocfs2_lock_res *lockres)
1840{
1841 unsigned long flags;
1842 int status = 0;
1843
1844 mlog_entry_void();
1845
1846refresh_check:
1847 spin_lock_irqsave(&lockres->l_lock, flags);
1848 if (!(lockres->l_flags & OCFS2_LOCK_NEEDS_REFRESH)) {
1849 spin_unlock_irqrestore(&lockres->l_lock, flags);
1850 goto bail;
1851 }
1852
1853 if (lockres->l_flags & OCFS2_LOCK_REFRESHING) {
1854 spin_unlock_irqrestore(&lockres->l_lock, flags);
1855
1856 ocfs2_wait_on_refreshing_lock(lockres);
1857 goto refresh_check;
1858 }
1859
1860 /* Ok, I'll be the one to refresh this lock. */
1861 lockres_or_flags(lockres, OCFS2_LOCK_REFRESHING);
1862 spin_unlock_irqrestore(&lockres->l_lock, flags);
1863
1864 status = 1;
1865bail:
1866 mlog_exit(status);
1867 return status;
1868}
1869
1870/* If status is non zero, I'll mark it as not being in refresh
1871 * anymroe, but i won't clear the needs refresh flag. */
1872static inline void ocfs2_complete_lock_res_refresh(struct ocfs2_lock_res *lockres,
1873 int status)
1874{
1875 unsigned long flags;
1876 mlog_entry_void();
1877
1878 spin_lock_irqsave(&lockres->l_lock, flags);
1879 lockres_clear_flags(lockres, OCFS2_LOCK_REFRESHING);
1880 if (!status)
1881 lockres_clear_flags(lockres, OCFS2_LOCK_NEEDS_REFRESH);
1882 spin_unlock_irqrestore(&lockres->l_lock, flags);
1883
1884 wake_up(&lockres->l_event);
1885
1886 mlog_exit_void();
1887}
1888
1889/* may or may not return a bh if it went to disk. */
Mark Fashehe63aecb62007-10-18 15:30:42 -07001890static int ocfs2_inode_lock_update(struct inode *inode,
Mark Fashehccd979b2005-12-15 14:31:24 -08001891 struct buffer_head **bh)
1892{
1893 int status = 0;
1894 struct ocfs2_inode_info *oi = OCFS2_I(inode);
Mark Fashehe63aecb62007-10-18 15:30:42 -07001895 struct ocfs2_lock_res *lockres = &oi->ip_inode_lockres;
Mark Fashehccd979b2005-12-15 14:31:24 -08001896 struct ocfs2_dinode *fe;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08001897 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
Mark Fashehccd979b2005-12-15 14:31:24 -08001898
1899 mlog_entry_void();
1900
Mark Fashehbe9e9862007-04-18 15:22:08 -07001901 if (ocfs2_mount_local(osb))
1902 goto bail;
1903
Mark Fashehccd979b2005-12-15 14:31:24 -08001904 spin_lock(&oi->ip_lock);
1905 if (oi->ip_flags & OCFS2_INODE_DELETED) {
Mark Fashehb06970532006-03-03 10:24:33 -08001906 mlog(0, "Orphaned inode %llu was deleted while we "
Mark Fashehccd979b2005-12-15 14:31:24 -08001907 "were waiting on a lock. ip_flags = 0x%x\n",
Mark Fashehb06970532006-03-03 10:24:33 -08001908 (unsigned long long)oi->ip_blkno, oi->ip_flags);
Mark Fashehccd979b2005-12-15 14:31:24 -08001909 spin_unlock(&oi->ip_lock);
1910 status = -ENOENT;
1911 goto bail;
1912 }
1913 spin_unlock(&oi->ip_lock);
1914
Mark Fashehbe9e9862007-04-18 15:22:08 -07001915 if (!ocfs2_should_refresh_lock_res(lockres))
1916 goto bail;
Mark Fashehccd979b2005-12-15 14:31:24 -08001917
1918 /* This will discard any caching information we might have had
1919 * for the inode metadata. */
1920 ocfs2_metadata_cache_purge(inode);
1921
Mark Fasheh83418972007-04-23 18:53:12 -07001922 ocfs2_extent_map_trunc(inode, 0);
1923
Mark Fashehbe9e9862007-04-18 15:22:08 -07001924 if (ocfs2_meta_lvb_is_trustable(inode, lockres)) {
Mark Fashehb06970532006-03-03 10:24:33 -08001925 mlog(0, "Trusting LVB on inode %llu\n",
1926 (unsigned long long)oi->ip_blkno);
Mark Fashehccd979b2005-12-15 14:31:24 -08001927 ocfs2_refresh_inode_from_lvb(inode);
1928 } else {
1929 /* Boo, we have to go to disk. */
1930 /* read bh, cast, ocfs2_refresh_inode */
1931 status = ocfs2_read_block(OCFS2_SB(inode->i_sb), oi->ip_blkno,
1932 bh, OCFS2_BH_CACHED, inode);
1933 if (status < 0) {
1934 mlog_errno(status);
1935 goto bail_refresh;
1936 }
1937 fe = (struct ocfs2_dinode *) (*bh)->b_data;
1938
1939 /* This is a good chance to make sure we're not
1940 * locking an invalid object.
1941 *
1942 * We bug on a stale inode here because we checked
1943 * above whether it was wiped from disk. The wiping
1944 * node provides a guarantee that we receive that
1945 * message and can mark the inode before dropping any
1946 * locks associated with it. */
1947 if (!OCFS2_IS_VALID_DINODE(fe)) {
1948 OCFS2_RO_ON_INVALID_DINODE(inode->i_sb, fe);
1949 status = -EIO;
1950 goto bail_refresh;
1951 }
1952 mlog_bug_on_msg(inode->i_generation !=
1953 le32_to_cpu(fe->i_generation),
Mark Fashehb06970532006-03-03 10:24:33 -08001954 "Invalid dinode %llu disk generation: %u "
Mark Fashehccd979b2005-12-15 14:31:24 -08001955 "inode->i_generation: %u\n",
Mark Fashehb06970532006-03-03 10:24:33 -08001956 (unsigned long long)oi->ip_blkno,
1957 le32_to_cpu(fe->i_generation),
Mark Fashehccd979b2005-12-15 14:31:24 -08001958 inode->i_generation);
1959 mlog_bug_on_msg(le64_to_cpu(fe->i_dtime) ||
1960 !(fe->i_flags & cpu_to_le32(OCFS2_VALID_FL)),
Mark Fashehb06970532006-03-03 10:24:33 -08001961 "Stale dinode %llu dtime: %llu flags: 0x%x\n",
1962 (unsigned long long)oi->ip_blkno,
1963 (unsigned long long)le64_to_cpu(fe->i_dtime),
Mark Fashehccd979b2005-12-15 14:31:24 -08001964 le32_to_cpu(fe->i_flags));
1965
1966 ocfs2_refresh_inode(inode, fe);
1967 }
1968
1969 status = 0;
1970bail_refresh:
Mark Fashehbe9e9862007-04-18 15:22:08 -07001971 ocfs2_complete_lock_res_refresh(lockres, status);
Mark Fashehccd979b2005-12-15 14:31:24 -08001972bail:
1973 mlog_exit(status);
1974 return status;
1975}
1976
1977static int ocfs2_assign_bh(struct inode *inode,
1978 struct buffer_head **ret_bh,
1979 struct buffer_head *passed_bh)
1980{
1981 int status;
1982
1983 if (passed_bh) {
1984 /* Ok, the update went to disk for us, use the
1985 * returned bh. */
1986 *ret_bh = passed_bh;
1987 get_bh(*ret_bh);
1988
1989 return 0;
1990 }
1991
1992 status = ocfs2_read_block(OCFS2_SB(inode->i_sb),
1993 OCFS2_I(inode)->ip_blkno,
1994 ret_bh,
1995 OCFS2_BH_CACHED,
1996 inode);
1997 if (status < 0)
1998 mlog_errno(status);
1999
2000 return status;
2001}
2002
2003/*
2004 * returns < 0 error if the callback will never be called, otherwise
2005 * the result of the lock will be communicated via the callback.
2006 */
Mark Fashehe63aecb62007-10-18 15:30:42 -07002007int ocfs2_inode_lock_full(struct inode *inode,
Mark Fashehccd979b2005-12-15 14:31:24 -08002008 struct buffer_head **ret_bh,
2009 int ex,
2010 int arg_flags)
2011{
Joel Beckerbd3e7612008-02-01 12:14:57 -08002012 int status, level, acquired;
2013 u32 dlm_flags;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002014 struct ocfs2_lock_res *lockres = NULL;
Mark Fashehccd979b2005-12-15 14:31:24 -08002015 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
2016 struct buffer_head *local_bh = NULL;
2017
2018 BUG_ON(!inode);
2019
2020 mlog_entry_void();
2021
Mark Fashehb06970532006-03-03 10:24:33 -08002022 mlog(0, "inode %llu, take %s META lock\n",
2023 (unsigned long long)OCFS2_I(inode)->ip_blkno,
Mark Fashehccd979b2005-12-15 14:31:24 -08002024 ex ? "EXMODE" : "PRMODE");
2025
2026 status = 0;
2027 acquired = 0;
2028 /* We'll allow faking a readonly metadata lock for
2029 * rodevices. */
2030 if (ocfs2_is_hard_readonly(osb)) {
2031 if (ex)
2032 status = -EROFS;
2033 goto bail;
2034 }
2035
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002036 if (ocfs2_mount_local(osb))
2037 goto local;
2038
Mark Fashehccd979b2005-12-15 14:31:24 -08002039 if (!(arg_flags & OCFS2_META_LOCK_RECOVERY))
Joel Becker553abd02008-02-01 12:03:57 -08002040 ocfs2_wait_for_recovery(osb);
Mark Fashehccd979b2005-12-15 14:31:24 -08002041
Mark Fashehe63aecb62007-10-18 15:30:42 -07002042 lockres = &OCFS2_I(inode)->ip_inode_lockres;
Joel Beckerbd3e7612008-02-01 12:14:57 -08002043 level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -08002044 dlm_flags = 0;
2045 if (arg_flags & OCFS2_META_LOCK_NOQUEUE)
Joel Beckerbd3e7612008-02-01 12:14:57 -08002046 dlm_flags |= DLM_LKF_NOQUEUE;
Mark Fashehccd979b2005-12-15 14:31:24 -08002047
2048 status = ocfs2_cluster_lock(osb, lockres, level, dlm_flags, arg_flags);
2049 if (status < 0) {
2050 if (status != -EAGAIN && status != -EIOCBRETRY)
2051 mlog_errno(status);
2052 goto bail;
2053 }
2054
2055 /* Notify the error cleanup path to drop the cluster lock. */
2056 acquired = 1;
2057
2058 /* We wait twice because a node may have died while we were in
2059 * the lower dlm layers. The second time though, we've
2060 * committed to owning this lock so we don't allow signals to
2061 * abort the operation. */
2062 if (!(arg_flags & OCFS2_META_LOCK_RECOVERY))
Joel Becker553abd02008-02-01 12:03:57 -08002063 ocfs2_wait_for_recovery(osb);
Mark Fashehccd979b2005-12-15 14:31:24 -08002064
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002065local:
Mark Fasheh24c19ef2006-09-22 17:28:19 -07002066 /*
2067 * We only see this flag if we're being called from
2068 * ocfs2_read_locked_inode(). It means we're locking an inode
2069 * which hasn't been populated yet, so clear the refresh flag
2070 * and let the caller handle it.
2071 */
2072 if (inode->i_state & I_NEW) {
2073 status = 0;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002074 if (lockres)
2075 ocfs2_complete_lock_res_refresh(lockres, 0);
Mark Fasheh24c19ef2006-09-22 17:28:19 -07002076 goto bail;
2077 }
2078
Mark Fashehccd979b2005-12-15 14:31:24 -08002079 /* This is fun. The caller may want a bh back, or it may
Mark Fashehe63aecb62007-10-18 15:30:42 -07002080 * not. ocfs2_inode_lock_update definitely wants one in, but
Mark Fashehccd979b2005-12-15 14:31:24 -08002081 * may or may not read one, depending on what's in the
2082 * LVB. The result of all of this is that we've *only* gone to
2083 * disk if we have to, so the complexity is worthwhile. */
Mark Fashehe63aecb62007-10-18 15:30:42 -07002084 status = ocfs2_inode_lock_update(inode, &local_bh);
Mark Fashehccd979b2005-12-15 14:31:24 -08002085 if (status < 0) {
2086 if (status != -ENOENT)
2087 mlog_errno(status);
2088 goto bail;
2089 }
2090
2091 if (ret_bh) {
2092 status = ocfs2_assign_bh(inode, ret_bh, local_bh);
2093 if (status < 0) {
2094 mlog_errno(status);
2095 goto bail;
2096 }
2097 }
2098
Mark Fashehccd979b2005-12-15 14:31:24 -08002099bail:
2100 if (status < 0) {
2101 if (ret_bh && (*ret_bh)) {
2102 brelse(*ret_bh);
2103 *ret_bh = NULL;
2104 }
2105 if (acquired)
Mark Fashehe63aecb62007-10-18 15:30:42 -07002106 ocfs2_inode_unlock(inode, ex);
Mark Fashehccd979b2005-12-15 14:31:24 -08002107 }
2108
2109 if (local_bh)
2110 brelse(local_bh);
2111
2112 mlog_exit(status);
2113 return status;
2114}
2115
2116/*
Mark Fasheh34d024f2007-09-24 15:56:19 -07002117 * This is working around a lock inversion between tasks acquiring DLM
2118 * locks while holding a page lock and the downconvert thread which
2119 * blocks dlm lock acquiry while acquiring page locks.
Mark Fashehccd979b2005-12-15 14:31:24 -08002120 *
2121 * ** These _with_page variantes are only intended to be called from aop
2122 * methods that hold page locks and return a very specific *positive* error
2123 * code that aop methods pass up to the VFS -- test for errors with != 0. **
2124 *
Mark Fasheh34d024f2007-09-24 15:56:19 -07002125 * The DLM is called such that it returns -EAGAIN if it would have
2126 * blocked waiting for the downconvert thread. In that case we unlock
2127 * our page so the downconvert thread can make progress. Once we've
2128 * done this we have to return AOP_TRUNCATED_PAGE so the aop method
2129 * that called us can bubble that back up into the VFS who will then
2130 * immediately retry the aop call.
Mark Fashehccd979b2005-12-15 14:31:24 -08002131 *
2132 * We do a blocking lock and immediate unlock before returning, though, so that
2133 * the lock has a great chance of being cached on this node by the time the VFS
2134 * calls back to retry the aop. This has a potential to livelock as nodes
2135 * ping locks back and forth, but that's a risk we're willing to take to avoid
2136 * the lock inversion simply.
2137 */
Mark Fashehe63aecb62007-10-18 15:30:42 -07002138int ocfs2_inode_lock_with_page(struct inode *inode,
Mark Fashehccd979b2005-12-15 14:31:24 -08002139 struct buffer_head **ret_bh,
2140 int ex,
2141 struct page *page)
2142{
2143 int ret;
2144
Mark Fashehe63aecb62007-10-18 15:30:42 -07002145 ret = ocfs2_inode_lock_full(inode, ret_bh, ex, OCFS2_LOCK_NONBLOCK);
Mark Fashehccd979b2005-12-15 14:31:24 -08002146 if (ret == -EAGAIN) {
2147 unlock_page(page);
Mark Fashehe63aecb62007-10-18 15:30:42 -07002148 if (ocfs2_inode_lock(inode, ret_bh, ex) == 0)
2149 ocfs2_inode_unlock(inode, ex);
Mark Fashehccd979b2005-12-15 14:31:24 -08002150 ret = AOP_TRUNCATED_PAGE;
2151 }
2152
2153 return ret;
2154}
2155
Mark Fashehe63aecb62007-10-18 15:30:42 -07002156int ocfs2_inode_lock_atime(struct inode *inode,
Tiger Yang7f1a37e2006-11-15 15:48:42 +08002157 struct vfsmount *vfsmnt,
2158 int *level)
2159{
2160 int ret;
2161
2162 mlog_entry_void();
Mark Fashehe63aecb62007-10-18 15:30:42 -07002163 ret = ocfs2_inode_lock(inode, NULL, 0);
Tiger Yang7f1a37e2006-11-15 15:48:42 +08002164 if (ret < 0) {
2165 mlog_errno(ret);
2166 return ret;
2167 }
2168
2169 /*
2170 * If we should update atime, we will get EX lock,
2171 * otherwise we just get PR lock.
2172 */
2173 if (ocfs2_should_update_atime(inode, vfsmnt)) {
2174 struct buffer_head *bh = NULL;
2175
Mark Fashehe63aecb62007-10-18 15:30:42 -07002176 ocfs2_inode_unlock(inode, 0);
2177 ret = ocfs2_inode_lock(inode, &bh, 1);
Tiger Yang7f1a37e2006-11-15 15:48:42 +08002178 if (ret < 0) {
2179 mlog_errno(ret);
2180 return ret;
2181 }
2182 *level = 1;
2183 if (ocfs2_should_update_atime(inode, vfsmnt))
2184 ocfs2_update_inode_atime(inode, bh);
2185 if (bh)
2186 brelse(bh);
2187 } else
2188 *level = 0;
2189
2190 mlog_exit(ret);
2191 return ret;
2192}
2193
Mark Fashehe63aecb62007-10-18 15:30:42 -07002194void ocfs2_inode_unlock(struct inode *inode,
Mark Fashehccd979b2005-12-15 14:31:24 -08002195 int ex)
2196{
Joel Beckerbd3e7612008-02-01 12:14:57 -08002197 int level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehe63aecb62007-10-18 15:30:42 -07002198 struct ocfs2_lock_res *lockres = &OCFS2_I(inode)->ip_inode_lockres;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002199 struct ocfs2_super *osb = OCFS2_SB(inode->i_sb);
Mark Fashehccd979b2005-12-15 14:31:24 -08002200
2201 mlog_entry_void();
2202
Mark Fashehb06970532006-03-03 10:24:33 -08002203 mlog(0, "inode %llu drop %s META lock\n",
2204 (unsigned long long)OCFS2_I(inode)->ip_blkno,
Mark Fashehccd979b2005-12-15 14:31:24 -08002205 ex ? "EXMODE" : "PRMODE");
2206
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002207 if (!ocfs2_is_hard_readonly(OCFS2_SB(inode->i_sb)) &&
2208 !ocfs2_mount_local(osb))
Mark Fashehccd979b2005-12-15 14:31:24 -08002209 ocfs2_cluster_unlock(OCFS2_SB(inode->i_sb), lockres, level);
2210
2211 mlog_exit_void();
2212}
2213
2214int ocfs2_super_lock(struct ocfs2_super *osb,
2215 int ex)
2216{
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002217 int status = 0;
Joel Beckerbd3e7612008-02-01 12:14:57 -08002218 int level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -08002219 struct ocfs2_lock_res *lockres = &osb->osb_super_lockres;
Mark Fashehccd979b2005-12-15 14:31:24 -08002220
2221 mlog_entry_void();
2222
2223 if (ocfs2_is_hard_readonly(osb))
2224 return -EROFS;
2225
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002226 if (ocfs2_mount_local(osb))
2227 goto bail;
2228
Mark Fashehccd979b2005-12-15 14:31:24 -08002229 status = ocfs2_cluster_lock(osb, lockres, level, 0, 0);
2230 if (status < 0) {
2231 mlog_errno(status);
2232 goto bail;
2233 }
2234
2235 /* The super block lock path is really in the best position to
2236 * know when resources covered by the lock need to be
2237 * refreshed, so we do it here. Of course, making sense of
2238 * everything is up to the caller :) */
2239 status = ocfs2_should_refresh_lock_res(lockres);
2240 if (status < 0) {
2241 mlog_errno(status);
2242 goto bail;
2243 }
2244 if (status) {
Mark Fasheh8e8a4602008-02-01 11:59:09 -08002245 status = ocfs2_refresh_slot_info(osb);
Mark Fashehccd979b2005-12-15 14:31:24 -08002246
2247 ocfs2_complete_lock_res_refresh(lockres, status);
2248
2249 if (status < 0)
2250 mlog_errno(status);
2251 }
2252bail:
2253 mlog_exit(status);
2254 return status;
2255}
2256
2257void ocfs2_super_unlock(struct ocfs2_super *osb,
2258 int ex)
2259{
Joel Beckerbd3e7612008-02-01 12:14:57 -08002260 int level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehccd979b2005-12-15 14:31:24 -08002261 struct ocfs2_lock_res *lockres = &osb->osb_super_lockres;
2262
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002263 if (!ocfs2_mount_local(osb))
2264 ocfs2_cluster_unlock(osb, lockres, level);
Mark Fashehccd979b2005-12-15 14:31:24 -08002265}
2266
2267int ocfs2_rename_lock(struct ocfs2_super *osb)
2268{
2269 int status;
2270 struct ocfs2_lock_res *lockres = &osb->osb_rename_lockres;
2271
2272 if (ocfs2_is_hard_readonly(osb))
2273 return -EROFS;
2274
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002275 if (ocfs2_mount_local(osb))
2276 return 0;
2277
Joel Beckerbd3e7612008-02-01 12:14:57 -08002278 status = ocfs2_cluster_lock(osb, lockres, DLM_LOCK_EX, 0, 0);
Mark Fashehccd979b2005-12-15 14:31:24 -08002279 if (status < 0)
2280 mlog_errno(status);
2281
2282 return status;
2283}
2284
2285void ocfs2_rename_unlock(struct ocfs2_super *osb)
2286{
2287 struct ocfs2_lock_res *lockres = &osb->osb_rename_lockres;
2288
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002289 if (!ocfs2_mount_local(osb))
Joel Beckerbd3e7612008-02-01 12:14:57 -08002290 ocfs2_cluster_unlock(osb, lockres, DLM_LOCK_EX);
Mark Fashehccd979b2005-12-15 14:31:24 -08002291}
2292
Mark Fashehd680efe2006-09-08 14:14:34 -07002293int ocfs2_dentry_lock(struct dentry *dentry, int ex)
2294{
2295 int ret;
Joel Beckerbd3e7612008-02-01 12:14:57 -08002296 int level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehd680efe2006-09-08 14:14:34 -07002297 struct ocfs2_dentry_lock *dl = dentry->d_fsdata;
2298 struct ocfs2_super *osb = OCFS2_SB(dentry->d_sb);
2299
2300 BUG_ON(!dl);
2301
2302 if (ocfs2_is_hard_readonly(osb))
2303 return -EROFS;
2304
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002305 if (ocfs2_mount_local(osb))
2306 return 0;
2307
Mark Fashehd680efe2006-09-08 14:14:34 -07002308 ret = ocfs2_cluster_lock(osb, &dl->dl_lockres, level, 0, 0);
2309 if (ret < 0)
2310 mlog_errno(ret);
2311
2312 return ret;
2313}
2314
2315void ocfs2_dentry_unlock(struct dentry *dentry, int ex)
2316{
Joel Beckerbd3e7612008-02-01 12:14:57 -08002317 int level = ex ? DLM_LOCK_EX : DLM_LOCK_PR;
Mark Fashehd680efe2006-09-08 14:14:34 -07002318 struct ocfs2_dentry_lock *dl = dentry->d_fsdata;
2319 struct ocfs2_super *osb = OCFS2_SB(dentry->d_sb);
2320
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002321 if (!ocfs2_mount_local(osb))
2322 ocfs2_cluster_unlock(osb, &dl->dl_lockres, level);
Mark Fashehd680efe2006-09-08 14:14:34 -07002323}
2324
Mark Fashehccd979b2005-12-15 14:31:24 -08002325/* Reference counting of the dlm debug structure. We want this because
2326 * open references on the debug inodes can live on after a mount, so
2327 * we can't rely on the ocfs2_super to always exist. */
2328static void ocfs2_dlm_debug_free(struct kref *kref)
2329{
2330 struct ocfs2_dlm_debug *dlm_debug;
2331
2332 dlm_debug = container_of(kref, struct ocfs2_dlm_debug, d_refcnt);
2333
2334 kfree(dlm_debug);
2335}
2336
2337void ocfs2_put_dlm_debug(struct ocfs2_dlm_debug *dlm_debug)
2338{
2339 if (dlm_debug)
2340 kref_put(&dlm_debug->d_refcnt, ocfs2_dlm_debug_free);
2341}
2342
2343static void ocfs2_get_dlm_debug(struct ocfs2_dlm_debug *debug)
2344{
2345 kref_get(&debug->d_refcnt);
2346}
2347
2348struct ocfs2_dlm_debug *ocfs2_new_dlm_debug(void)
2349{
2350 struct ocfs2_dlm_debug *dlm_debug;
2351
2352 dlm_debug = kmalloc(sizeof(struct ocfs2_dlm_debug), GFP_KERNEL);
2353 if (!dlm_debug) {
2354 mlog_errno(-ENOMEM);
2355 goto out;
2356 }
2357
2358 kref_init(&dlm_debug->d_refcnt);
2359 INIT_LIST_HEAD(&dlm_debug->d_lockres_tracking);
2360 dlm_debug->d_locking_state = NULL;
2361out:
2362 return dlm_debug;
2363}
2364
2365/* Access to this is arbitrated for us via seq_file->sem. */
2366struct ocfs2_dlm_seq_priv {
2367 struct ocfs2_dlm_debug *p_dlm_debug;
2368 struct ocfs2_lock_res p_iter_res;
2369 struct ocfs2_lock_res p_tmp_res;
2370};
2371
2372static struct ocfs2_lock_res *ocfs2_dlm_next_res(struct ocfs2_lock_res *start,
2373 struct ocfs2_dlm_seq_priv *priv)
2374{
2375 struct ocfs2_lock_res *iter, *ret = NULL;
2376 struct ocfs2_dlm_debug *dlm_debug = priv->p_dlm_debug;
2377
2378 assert_spin_locked(&ocfs2_dlm_tracking_lock);
2379
2380 list_for_each_entry(iter, &start->l_debug_list, l_debug_list) {
2381 /* discover the head of the list */
2382 if (&iter->l_debug_list == &dlm_debug->d_lockres_tracking) {
2383 mlog(0, "End of list found, %p\n", ret);
2384 break;
2385 }
2386
2387 /* We track our "dummy" iteration lockres' by a NULL
2388 * l_ops field. */
2389 if (iter->l_ops != NULL) {
2390 ret = iter;
2391 break;
2392 }
2393 }
2394
2395 return ret;
2396}
2397
2398static void *ocfs2_dlm_seq_start(struct seq_file *m, loff_t *pos)
2399{
2400 struct ocfs2_dlm_seq_priv *priv = m->private;
2401 struct ocfs2_lock_res *iter;
2402
2403 spin_lock(&ocfs2_dlm_tracking_lock);
2404 iter = ocfs2_dlm_next_res(&priv->p_iter_res, priv);
2405 if (iter) {
2406 /* Since lockres' have the lifetime of their container
2407 * (which can be inodes, ocfs2_supers, etc) we want to
2408 * copy this out to a temporary lockres while still
2409 * under the spinlock. Obviously after this we can't
2410 * trust any pointers on the copy returned, but that's
2411 * ok as the information we want isn't typically held
2412 * in them. */
2413 priv->p_tmp_res = *iter;
2414 iter = &priv->p_tmp_res;
2415 }
2416 spin_unlock(&ocfs2_dlm_tracking_lock);
2417
2418 return iter;
2419}
2420
2421static void ocfs2_dlm_seq_stop(struct seq_file *m, void *v)
2422{
2423}
2424
2425static void *ocfs2_dlm_seq_next(struct seq_file *m, void *v, loff_t *pos)
2426{
2427 struct ocfs2_dlm_seq_priv *priv = m->private;
2428 struct ocfs2_lock_res *iter = v;
2429 struct ocfs2_lock_res *dummy = &priv->p_iter_res;
2430
2431 spin_lock(&ocfs2_dlm_tracking_lock);
2432 iter = ocfs2_dlm_next_res(iter, priv);
2433 list_del_init(&dummy->l_debug_list);
2434 if (iter) {
2435 list_add(&dummy->l_debug_list, &iter->l_debug_list);
2436 priv->p_tmp_res = *iter;
2437 iter = &priv->p_tmp_res;
2438 }
2439 spin_unlock(&ocfs2_dlm_tracking_lock);
2440
2441 return iter;
2442}
2443
2444/* So that debugfs.ocfs2 can determine which format is being used */
2445#define OCFS2_DLM_DEBUG_STR_VERSION 1
2446static int ocfs2_dlm_seq_show(struct seq_file *m, void *v)
2447{
2448 int i;
2449 char *lvb;
2450 struct ocfs2_lock_res *lockres = v;
2451
2452 if (!lockres)
2453 return -EINVAL;
2454
Mark Fashehd680efe2006-09-08 14:14:34 -07002455 seq_printf(m, "0x%x\t", OCFS2_DLM_DEBUG_STR_VERSION);
2456
2457 if (lockres->l_type == OCFS2_LOCK_TYPE_DENTRY)
2458 seq_printf(m, "%.*s%08x\t", OCFS2_DENTRY_LOCK_INO_START - 1,
2459 lockres->l_name,
2460 (unsigned int)ocfs2_get_dentry_lock_ino(lockres));
2461 else
2462 seq_printf(m, "%.*s\t", OCFS2_LOCK_ID_MAX_LEN, lockres->l_name);
2463
2464 seq_printf(m, "%d\t"
Mark Fashehccd979b2005-12-15 14:31:24 -08002465 "0x%lx\t"
2466 "0x%x\t"
2467 "0x%x\t"
2468 "%u\t"
2469 "%u\t"
2470 "%d\t"
2471 "%d\t",
Mark Fashehccd979b2005-12-15 14:31:24 -08002472 lockres->l_level,
2473 lockres->l_flags,
2474 lockres->l_action,
2475 lockres->l_unlock_action,
2476 lockres->l_ro_holders,
2477 lockres->l_ex_holders,
2478 lockres->l_requested,
2479 lockres->l_blocking);
2480
2481 /* Dump the raw LVB */
Joel Becker8f2c9c12008-02-01 12:16:57 -08002482 lvb = ocfs2_dlm_lvb(&lockres->l_lksb);
Mark Fashehccd979b2005-12-15 14:31:24 -08002483 for(i = 0; i < DLM_LVB_LEN; i++)
2484 seq_printf(m, "0x%x\t", lvb[i]);
2485
2486 /* End the line */
2487 seq_printf(m, "\n");
2488 return 0;
2489}
2490
Jan Engelhardt90d99772008-01-22 20:52:20 +01002491static const struct seq_operations ocfs2_dlm_seq_ops = {
Mark Fashehccd979b2005-12-15 14:31:24 -08002492 .start = ocfs2_dlm_seq_start,
2493 .stop = ocfs2_dlm_seq_stop,
2494 .next = ocfs2_dlm_seq_next,
2495 .show = ocfs2_dlm_seq_show,
2496};
2497
2498static int ocfs2_dlm_debug_release(struct inode *inode, struct file *file)
2499{
2500 struct seq_file *seq = (struct seq_file *) file->private_data;
2501 struct ocfs2_dlm_seq_priv *priv = seq->private;
2502 struct ocfs2_lock_res *res = &priv->p_iter_res;
2503
2504 ocfs2_remove_lockres_tracking(res);
2505 ocfs2_put_dlm_debug(priv->p_dlm_debug);
2506 return seq_release_private(inode, file);
2507}
2508
2509static int ocfs2_dlm_debug_open(struct inode *inode, struct file *file)
2510{
2511 int ret;
2512 struct ocfs2_dlm_seq_priv *priv;
2513 struct seq_file *seq;
2514 struct ocfs2_super *osb;
2515
2516 priv = kzalloc(sizeof(struct ocfs2_dlm_seq_priv), GFP_KERNEL);
2517 if (!priv) {
2518 ret = -ENOMEM;
2519 mlog_errno(ret);
2520 goto out;
2521 }
Theodore Ts'o8e18e292006-09-27 01:50:46 -07002522 osb = inode->i_private;
Mark Fashehccd979b2005-12-15 14:31:24 -08002523 ocfs2_get_dlm_debug(osb->osb_dlm_debug);
2524 priv->p_dlm_debug = osb->osb_dlm_debug;
2525 INIT_LIST_HEAD(&priv->p_iter_res.l_debug_list);
2526
2527 ret = seq_open(file, &ocfs2_dlm_seq_ops);
2528 if (ret) {
2529 kfree(priv);
2530 mlog_errno(ret);
2531 goto out;
2532 }
2533
2534 seq = (struct seq_file *) file->private_data;
2535 seq->private = priv;
2536
2537 ocfs2_add_lockres_tracking(&priv->p_iter_res,
2538 priv->p_dlm_debug);
2539
2540out:
2541 return ret;
2542}
2543
Arjan van de Ven4b6f5d22006-03-28 01:56:42 -08002544static const struct file_operations ocfs2_dlm_debug_fops = {
Mark Fashehccd979b2005-12-15 14:31:24 -08002545 .open = ocfs2_dlm_debug_open,
2546 .release = ocfs2_dlm_debug_release,
2547 .read = seq_read,
2548 .llseek = seq_lseek,
2549};
2550
2551static int ocfs2_dlm_init_debug(struct ocfs2_super *osb)
2552{
2553 int ret = 0;
2554 struct ocfs2_dlm_debug *dlm_debug = osb->osb_dlm_debug;
2555
2556 dlm_debug->d_locking_state = debugfs_create_file("locking_state",
2557 S_IFREG|S_IRUSR,
2558 osb->osb_debug_root,
2559 osb,
2560 &ocfs2_dlm_debug_fops);
2561 if (!dlm_debug->d_locking_state) {
2562 ret = -EINVAL;
2563 mlog(ML_ERROR,
2564 "Unable to create locking state debugfs file.\n");
2565 goto out;
2566 }
2567
2568 ocfs2_get_dlm_debug(dlm_debug);
2569out:
2570 return ret;
2571}
2572
2573static void ocfs2_dlm_shutdown_debug(struct ocfs2_super *osb)
2574{
2575 struct ocfs2_dlm_debug *dlm_debug = osb->osb_dlm_debug;
2576
2577 if (dlm_debug) {
2578 debugfs_remove(dlm_debug->d_locking_state);
2579 ocfs2_put_dlm_debug(dlm_debug);
2580 }
2581}
2582
2583int ocfs2_dlm_init(struct ocfs2_super *osb)
2584{
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002585 int status = 0;
Joel Becker4670c462008-02-01 14:39:35 -08002586 struct ocfs2_cluster_connection *conn = NULL;
Mark Fashehccd979b2005-12-15 14:31:24 -08002587
2588 mlog_entry_void();
2589
Mark Fasheh0abd6d12008-01-29 16:59:56 -08002590 if (ocfs2_mount_local(osb)) {
2591 osb->node_num = 0;
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002592 goto local;
Mark Fasheh0abd6d12008-01-29 16:59:56 -08002593 }
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002594
Mark Fashehccd979b2005-12-15 14:31:24 -08002595 status = ocfs2_dlm_init_debug(osb);
2596 if (status < 0) {
2597 mlog_errno(status);
2598 goto bail;
2599 }
2600
Mark Fasheh34d024f2007-09-24 15:56:19 -07002601 /* launch downconvert thread */
2602 osb->dc_task = kthread_run(ocfs2_downconvert_thread, osb, "ocfs2dc");
2603 if (IS_ERR(osb->dc_task)) {
2604 status = PTR_ERR(osb->dc_task);
2605 osb->dc_task = NULL;
Mark Fashehccd979b2005-12-15 14:31:24 -08002606 mlog_errno(status);
2607 goto bail;
2608 }
2609
Mark Fashehccd979b2005-12-15 14:31:24 -08002610 /* for now, uuid == domain */
Joel Becker4670c462008-02-01 14:39:35 -08002611 status = ocfs2_cluster_connect(osb->uuid_str,
2612 strlen(osb->uuid_str),
2613 ocfs2_do_node_down, osb,
2614 &conn);
2615 if (status) {
Mark Fashehccd979b2005-12-15 14:31:24 -08002616 mlog_errno(status);
2617 goto bail;
2618 }
2619
Mark Fasheh0abd6d12008-01-29 16:59:56 -08002620 status = ocfs2_cluster_this_node(&osb->node_num);
2621 if (status < 0) {
2622 mlog_errno(status);
2623 mlog(ML_ERROR,
2624 "could not find this host's node number\n");
2625 ocfs2_cluster_disconnect(conn);
2626 goto bail;
2627 }
2628
Sunil Mushranc271c5c2006-12-05 17:56:35 -08002629local:
Mark Fashehccd979b2005-12-15 14:31:24 -08002630 ocfs2_super_lock_res_init(&osb->osb_super_lockres, osb);
2631 ocfs2_rename_lock_res_init(&osb->osb_rename_lockres, osb);
2632
Joel Becker4670c462008-02-01 14:39:35 -08002633 osb->cconn = conn;
Mark Fashehccd979b2005-12-15 14:31:24 -08002634
2635 status = 0;
2636bail:
2637 if (status < 0) {
2638 ocfs2_dlm_shutdown_debug(osb);
Mark Fasheh34d024f2007-09-24 15:56:19 -07002639 if (osb->dc_task)
2640 kthread_stop(osb->dc_task);
Mark Fashehccd979b2005-12-15 14:31:24 -08002641 }
2642
2643 mlog_exit(status);
2644 return status;
2645}
2646
2647void ocfs2_dlm_shutdown(struct ocfs2_super *osb)
2648{
2649 mlog_entry_void();
2650
Mark Fashehccd979b2005-12-15 14:31:24 -08002651 ocfs2_drop_osb_locks(osb);
2652
Joel Becker4670c462008-02-01 14:39:35 -08002653 /*
2654 * Now that we have dropped all locks and ocfs2_dismount_volume()
2655 * has disabled recovery, the DLM won't be talking to us. It's
2656 * safe to tear things down before disconnecting the cluster.
2657 */
2658
Mark Fasheh34d024f2007-09-24 15:56:19 -07002659 if (osb->dc_task) {
2660 kthread_stop(osb->dc_task);
2661 osb->dc_task = NULL;
Mark Fashehccd979b2005-12-15 14:31:24 -08002662 }
2663
2664 ocfs2_lock_res_free(&osb->osb_super_lockres);
2665 ocfs2_lock_res_free(&osb->osb_rename_lockres);
2666
Joel Becker4670c462008-02-01 14:39:35 -08002667 ocfs2_cluster_disconnect(osb->cconn);
2668 osb->cconn = NULL;
Mark Fashehccd979b2005-12-15 14:31:24 -08002669
2670 ocfs2_dlm_shutdown_debug(osb);
2671
2672 mlog_exit_void();
2673}
2674
Joel Becker7431cd72008-02-01 12:15:37 -08002675static void ocfs2_unlock_ast(void *opaque, int error)
Mark Fashehccd979b2005-12-15 14:31:24 -08002676{
2677 struct ocfs2_lock_res *lockres = opaque;
2678 unsigned long flags;
2679
2680 mlog_entry_void();
2681
2682 mlog(0, "UNLOCK AST called on lock %s, action = %d\n", lockres->l_name,
2683 lockres->l_unlock_action);
2684
2685 spin_lock_irqsave(&lockres->l_lock, flags);
Joel Beckerde551242008-02-01 14:45:08 -08002686 if (error) {
Joel Becker7431cd72008-02-01 12:15:37 -08002687 mlog(ML_ERROR, "Dlm passes error %d for lock %s, "
2688 "unlock_action %d\n", error, lockres->l_name,
Mark Fashehccd979b2005-12-15 14:31:24 -08002689 lockres->l_unlock_action);
2690 spin_unlock_irqrestore(&lockres->l_lock, flags);
2691 return;
2692 }
2693
2694 switch(lockres->l_unlock_action) {
2695 case OCFS2_UNLOCK_CANCEL_CONVERT:
2696 mlog(0, "Cancel convert success for %s\n", lockres->l_name);
2697 lockres->l_action = OCFS2_AST_INVALID;
2698 break;
2699 case OCFS2_UNLOCK_DROP_LOCK:
Joel Beckerbd3e7612008-02-01 12:14:57 -08002700 lockres->l_level = DLM_LOCK_IV;
Mark Fashehccd979b2005-12-15 14:31:24 -08002701 break;
2702 default:
2703 BUG();
2704 }
2705
2706 lockres_clear_flags(lockres, OCFS2_LOCK_BUSY);
Mark Fashehccd979b2005-12-15 14:31:24 -08002707 lockres->l_unlock_action = OCFS2_UNLOCK_INVALID;
2708 spin_unlock_irqrestore(&lockres->l_lock, flags);
2709
2710 wake_up(&lockres->l_event);
2711
2712 mlog_exit_void();
2713}
2714
Mark Fashehccd979b2005-12-15 14:31:24 -08002715static int ocfs2_drop_lock(struct ocfs2_super *osb,
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -07002716 struct ocfs2_lock_res *lockres)
Mark Fashehccd979b2005-12-15 14:31:24 -08002717{
Joel Becker7431cd72008-02-01 12:15:37 -08002718 int ret;
Mark Fashehccd979b2005-12-15 14:31:24 -08002719 unsigned long flags;
Joel Beckerbd3e7612008-02-01 12:14:57 -08002720 u32 lkm_flags = 0;
Mark Fashehccd979b2005-12-15 14:31:24 -08002721
2722 /* We didn't get anywhere near actually using this lockres. */
2723 if (!(lockres->l_flags & OCFS2_LOCK_INITIALIZED))
2724 goto out;
2725
Mark Fashehb80fc012006-09-12 22:08:14 -07002726 if (lockres->l_ops->flags & LOCK_TYPE_USES_LVB)
Joel Beckerbd3e7612008-02-01 12:14:57 -08002727 lkm_flags |= DLM_LKF_VALBLK;
Mark Fashehb80fc012006-09-12 22:08:14 -07002728
Mark Fashehccd979b2005-12-15 14:31:24 -08002729 spin_lock_irqsave(&lockres->l_lock, flags);
2730
2731 mlog_bug_on_msg(!(lockres->l_flags & OCFS2_LOCK_FREEING),
2732 "lockres %s, flags 0x%lx\n",
2733 lockres->l_name, lockres->l_flags);
2734
2735 while (lockres->l_flags & OCFS2_LOCK_BUSY) {
2736 mlog(0, "waiting on busy lock \"%s\": flags = %lx, action = "
2737 "%u, unlock_action = %u\n",
2738 lockres->l_name, lockres->l_flags, lockres->l_action,
2739 lockres->l_unlock_action);
2740
2741 spin_unlock_irqrestore(&lockres->l_lock, flags);
2742
2743 /* XXX: Today we just wait on any busy
2744 * locks... Perhaps we need to cancel converts in the
2745 * future? */
2746 ocfs2_wait_on_busy_lock(lockres);
2747
2748 spin_lock_irqsave(&lockres->l_lock, flags);
2749 }
2750
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -07002751 if (lockres->l_ops->flags & LOCK_TYPE_USES_LVB) {
2752 if (lockres->l_flags & OCFS2_LOCK_ATTACHED &&
Joel Beckerbd3e7612008-02-01 12:14:57 -08002753 lockres->l_level == DLM_LOCK_EX &&
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -07002754 !(lockres->l_flags & OCFS2_LOCK_NEEDS_REFRESH))
2755 lockres->l_ops->set_lvb(lockres);
2756 }
Mark Fashehccd979b2005-12-15 14:31:24 -08002757
2758 if (lockres->l_flags & OCFS2_LOCK_BUSY)
2759 mlog(ML_ERROR, "destroying busy lock: \"%s\"\n",
2760 lockres->l_name);
2761 if (lockres->l_flags & OCFS2_LOCK_BLOCKED)
2762 mlog(0, "destroying blocked lock: \"%s\"\n", lockres->l_name);
2763
2764 if (!(lockres->l_flags & OCFS2_LOCK_ATTACHED)) {
2765 spin_unlock_irqrestore(&lockres->l_lock, flags);
2766 goto out;
2767 }
2768
2769 lockres_clear_flags(lockres, OCFS2_LOCK_ATTACHED);
2770
2771 /* make sure we never get here while waiting for an ast to
2772 * fire. */
2773 BUG_ON(lockres->l_action != OCFS2_AST_INVALID);
2774
2775 /* is this necessary? */
2776 lockres_or_flags(lockres, OCFS2_LOCK_BUSY);
2777 lockres->l_unlock_action = OCFS2_UNLOCK_DROP_LOCK;
2778 spin_unlock_irqrestore(&lockres->l_lock, flags);
2779
2780 mlog(0, "lock %s\n", lockres->l_name);
2781
Joel Becker4670c462008-02-01 14:39:35 -08002782 ret = ocfs2_dlm_unlock(osb->cconn, &lockres->l_lksb, lkm_flags,
Joel Becker7431cd72008-02-01 12:15:37 -08002783 lockres);
2784 if (ret) {
2785 ocfs2_log_dlm_error("ocfs2_dlm_unlock", ret, lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002786 mlog(ML_ERROR, "lockres flags: %lu\n", lockres->l_flags);
Joel Becker8f2c9c12008-02-01 12:16:57 -08002787 /* XXX Need to abstract this */
2788 dlm_print_one_lock(lockres->l_lksb.lksb_o2dlm.lockid);
Mark Fashehccd979b2005-12-15 14:31:24 -08002789 BUG();
2790 }
Joel Becker24ef1812008-01-29 17:37:32 -08002791 mlog(0, "lock %s, successfull return from ocfs2_dlm_unlock\n",
Mark Fashehccd979b2005-12-15 14:31:24 -08002792 lockres->l_name);
2793
2794 ocfs2_wait_on_busy_lock(lockres);
2795out:
2796 mlog_exit(0);
2797 return 0;
2798}
2799
2800/* Mark the lockres as being dropped. It will no longer be
2801 * queued if blocking, but we still may have to wait on it
Mark Fasheh34d024f2007-09-24 15:56:19 -07002802 * being dequeued from the downconvert thread before we can consider
Mark Fashehccd979b2005-12-15 14:31:24 -08002803 * it safe to drop.
2804 *
2805 * You can *not* attempt to call cluster_lock on this lockres anymore. */
2806void ocfs2_mark_lockres_freeing(struct ocfs2_lock_res *lockres)
2807{
2808 int status;
2809 struct ocfs2_mask_waiter mw;
2810 unsigned long flags;
2811
2812 ocfs2_init_mask_waiter(&mw);
2813
2814 spin_lock_irqsave(&lockres->l_lock, flags);
2815 lockres->l_flags |= OCFS2_LOCK_FREEING;
2816 while (lockres->l_flags & OCFS2_LOCK_QUEUED) {
2817 lockres_add_mask_waiter(lockres, &mw, OCFS2_LOCK_QUEUED, 0);
2818 spin_unlock_irqrestore(&lockres->l_lock, flags);
2819
2820 mlog(0, "Waiting on lockres %s\n", lockres->l_name);
2821
2822 status = ocfs2_wait_for_mask(&mw);
2823 if (status)
2824 mlog_errno(status);
2825
2826 spin_lock_irqsave(&lockres->l_lock, flags);
2827 }
2828 spin_unlock_irqrestore(&lockres->l_lock, flags);
2829}
2830
Mark Fashehd680efe2006-09-08 14:14:34 -07002831void ocfs2_simple_drop_lockres(struct ocfs2_super *osb,
2832 struct ocfs2_lock_res *lockres)
2833{
2834 int ret;
2835
2836 ocfs2_mark_lockres_freeing(lockres);
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -07002837 ret = ocfs2_drop_lock(osb, lockres);
Mark Fashehd680efe2006-09-08 14:14:34 -07002838 if (ret)
2839 mlog_errno(ret);
2840}
2841
Mark Fashehccd979b2005-12-15 14:31:24 -08002842static void ocfs2_drop_osb_locks(struct ocfs2_super *osb)
2843{
Mark Fashehd680efe2006-09-08 14:14:34 -07002844 ocfs2_simple_drop_lockres(osb, &osb->osb_super_lockres);
2845 ocfs2_simple_drop_lockres(osb, &osb->osb_rename_lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002846}
2847
Mark Fashehccd979b2005-12-15 14:31:24 -08002848int ocfs2_drop_inode_locks(struct inode *inode)
2849{
2850 int status, err;
Mark Fashehccd979b2005-12-15 14:31:24 -08002851
2852 mlog_entry_void();
2853
2854 /* No need to call ocfs2_mark_lockres_freeing here -
2855 * ocfs2_clear_inode has done it for us. */
2856
2857 err = ocfs2_drop_lock(OCFS2_SB(inode->i_sb),
Tiger Yang50008632007-03-20 16:01:38 -07002858 &OCFS2_I(inode)->ip_open_lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002859 if (err < 0)
2860 mlog_errno(err);
2861
2862 status = err;
2863
2864 err = ocfs2_drop_lock(OCFS2_SB(inode->i_sb),
Mark Fashehe63aecb62007-10-18 15:30:42 -07002865 &OCFS2_I(inode)->ip_inode_lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002866 if (err < 0)
2867 mlog_errno(err);
2868 if (err < 0 && !status)
2869 status = err;
2870
2871 err = ocfs2_drop_lock(OCFS2_SB(inode->i_sb),
Mark Fasheh0d5dc6c2006-09-14 14:44:51 -07002872 &OCFS2_I(inode)->ip_rw_lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002873 if (err < 0)
2874 mlog_errno(err);
2875 if (err < 0 && !status)
2876 status = err;
2877
2878 mlog_exit(status);
2879 return status;
2880}
2881
Joel Beckerde551242008-02-01 14:45:08 -08002882static unsigned int ocfs2_prepare_downconvert(struct ocfs2_lock_res *lockres,
2883 int new_level)
Mark Fashehccd979b2005-12-15 14:31:24 -08002884{
2885 assert_spin_locked(&lockres->l_lock);
2886
Joel Beckerbd3e7612008-02-01 12:14:57 -08002887 BUG_ON(lockres->l_blocking <= DLM_LOCK_NL);
Mark Fashehccd979b2005-12-15 14:31:24 -08002888
2889 if (lockres->l_level <= new_level) {
Joel Beckerbd3e7612008-02-01 12:14:57 -08002890 mlog(ML_ERROR, "lockres->l_level (%d) <= new_level (%d)\n",
Mark Fashehccd979b2005-12-15 14:31:24 -08002891 lockres->l_level, new_level);
2892 BUG();
2893 }
2894
2895 mlog(0, "lock %s, new_level = %d, l_blocking = %d\n",
2896 lockres->l_name, new_level, lockres->l_blocking);
2897
2898 lockres->l_action = OCFS2_AST_DOWNCONVERT;
2899 lockres->l_requested = new_level;
2900 lockres_or_flags(lockres, OCFS2_LOCK_BUSY);
Joel Beckerde551242008-02-01 14:45:08 -08002901 return lockres_set_pending(lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002902}
2903
2904static int ocfs2_downconvert_lock(struct ocfs2_super *osb,
2905 struct ocfs2_lock_res *lockres,
2906 int new_level,
Joel Beckerde551242008-02-01 14:45:08 -08002907 int lvb,
2908 unsigned int generation)
Mark Fashehccd979b2005-12-15 14:31:24 -08002909{
Joel Beckerbd3e7612008-02-01 12:14:57 -08002910 int ret;
2911 u32 dlm_flags = DLM_LKF_CONVERT;
Mark Fashehccd979b2005-12-15 14:31:24 -08002912
2913 mlog_entry_void();
2914
2915 if (lvb)
Joel Beckerbd3e7612008-02-01 12:14:57 -08002916 dlm_flags |= DLM_LKF_VALBLK;
Mark Fashehccd979b2005-12-15 14:31:24 -08002917
Joel Becker4670c462008-02-01 14:39:35 -08002918 ret = ocfs2_dlm_lock(osb->cconn,
Joel Becker7431cd72008-02-01 12:15:37 -08002919 new_level,
2920 &lockres->l_lksb,
2921 dlm_flags,
2922 lockres->l_name,
2923 OCFS2_LOCK_ID_MAX_LEN - 1,
2924 lockres);
Joel Beckerde551242008-02-01 14:45:08 -08002925 lockres_clear_pending(lockres, generation, osb);
Joel Becker7431cd72008-02-01 12:15:37 -08002926 if (ret) {
2927 ocfs2_log_dlm_error("ocfs2_dlm_lock", ret, lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002928 ocfs2_recover_from_dlm_error(lockres, 1);
2929 goto bail;
2930 }
2931
2932 ret = 0;
2933bail:
2934 mlog_exit(ret);
2935 return ret;
2936}
2937
Joel Becker24ef1812008-01-29 17:37:32 -08002938/* returns 1 when the caller should unlock and call ocfs2_dlm_unlock */
Mark Fashehccd979b2005-12-15 14:31:24 -08002939static int ocfs2_prepare_cancel_convert(struct ocfs2_super *osb,
2940 struct ocfs2_lock_res *lockres)
2941{
2942 assert_spin_locked(&lockres->l_lock);
2943
2944 mlog_entry_void();
2945 mlog(0, "lock %s\n", lockres->l_name);
2946
2947 if (lockres->l_unlock_action == OCFS2_UNLOCK_CANCEL_CONVERT) {
2948 /* If we're already trying to cancel a lock conversion
2949 * then just drop the spinlock and allow the caller to
2950 * requeue this lock. */
2951
2952 mlog(0, "Lockres %s, skip convert\n", lockres->l_name);
2953 return 0;
2954 }
2955
2956 /* were we in a convert when we got the bast fire? */
2957 BUG_ON(lockres->l_action != OCFS2_AST_CONVERT &&
2958 lockres->l_action != OCFS2_AST_DOWNCONVERT);
2959 /* set things up for the unlockast to know to just
2960 * clear out the ast_action and unset busy, etc. */
2961 lockres->l_unlock_action = OCFS2_UNLOCK_CANCEL_CONVERT;
2962
2963 mlog_bug_on_msg(!(lockres->l_flags & OCFS2_LOCK_BUSY),
2964 "lock %s, invalid flags: 0x%lx\n",
2965 lockres->l_name, lockres->l_flags);
2966
2967 return 1;
2968}
2969
2970static int ocfs2_cancel_convert(struct ocfs2_super *osb,
2971 struct ocfs2_lock_res *lockres)
2972{
2973 int ret;
Mark Fashehccd979b2005-12-15 14:31:24 -08002974
2975 mlog_entry_void();
2976 mlog(0, "lock %s\n", lockres->l_name);
2977
Joel Becker4670c462008-02-01 14:39:35 -08002978 ret = ocfs2_dlm_unlock(osb->cconn, &lockres->l_lksb,
Joel Becker7431cd72008-02-01 12:15:37 -08002979 DLM_LKF_CANCEL, lockres);
2980 if (ret) {
2981 ocfs2_log_dlm_error("ocfs2_dlm_unlock", ret, lockres);
Mark Fashehccd979b2005-12-15 14:31:24 -08002982 ocfs2_recover_from_dlm_error(lockres, 0);
2983 }
2984
Joel Becker24ef1812008-01-29 17:37:32 -08002985 mlog(0, "lock %s return from ocfs2_dlm_unlock\n", lockres->l_name);
Mark Fashehccd979b2005-12-15 14:31:24 -08002986
2987 mlog_exit(ret);
2988 return ret;
2989}
2990
Mark Fashehb5e500e2006-09-13 22:01:16 -07002991static int ocfs2_unblock_lock(struct ocfs2_super *osb,
2992 struct ocfs2_lock_res *lockres,
2993 struct ocfs2_unblock_ctl *ctl)
Mark Fashehccd979b2005-12-15 14:31:24 -08002994{
2995 unsigned long flags;
2996 int blocking;
2997 int new_level;
2998 int ret = 0;
Mark Fasheh5ef0d4e2006-09-13 21:21:52 -07002999 int set_lvb = 0;
Joel Beckerde551242008-02-01 14:45:08 -08003000 unsigned int gen;
Mark Fashehccd979b2005-12-15 14:31:24 -08003001
3002 mlog_entry_void();
3003
3004 spin_lock_irqsave(&lockres->l_lock, flags);
3005
3006 BUG_ON(!(lockres->l_flags & OCFS2_LOCK_BLOCKED));
3007
3008recheck:
3009 if (lockres->l_flags & OCFS2_LOCK_BUSY) {
Joel Beckerde551242008-02-01 14:45:08 -08003010 /* XXX
3011 * This is a *big* race. The OCFS2_LOCK_PENDING flag
3012 * exists entirely for one reason - another thread has set
3013 * OCFS2_LOCK_BUSY, but has *NOT* yet called dlm_lock().
3014 *
3015 * If we do ocfs2_cancel_convert() before the other thread
3016 * calls dlm_lock(), our cancel will do nothing. We will
3017 * get no ast, and we will have no way of knowing the
3018 * cancel failed. Meanwhile, the other thread will call
3019 * into dlm_lock() and wait...forever.
3020 *
3021 * Why forever? Because another node has asked for the
3022 * lock first; that's why we're here in unblock_lock().
3023 *
3024 * The solution is OCFS2_LOCK_PENDING. When PENDING is
3025 * set, we just requeue the unblock. Only when the other
3026 * thread has called dlm_lock() and cleared PENDING will
3027 * we then cancel their request.
3028 *
3029 * All callers of dlm_lock() must set OCFS2_DLM_PENDING
3030 * at the same time they set OCFS2_DLM_BUSY. They must
3031 * clear OCFS2_DLM_PENDING after dlm_lock() returns.
3032 */
3033 if (lockres->l_flags & OCFS2_LOCK_PENDING)
3034 goto leave_requeue;
3035
Mark Fashehd680efe2006-09-08 14:14:34 -07003036 ctl->requeue = 1;
Mark Fashehccd979b2005-12-15 14:31:24 -08003037 ret = ocfs2_prepare_cancel_convert(osb, lockres);
3038 spin_unlock_irqrestore(&lockres->l_lock, flags);
3039 if (ret) {
3040 ret = ocfs2_cancel_convert(osb, lockres);
3041 if (ret < 0)
3042 mlog_errno(ret);
3043 }
3044 goto leave;
3045 }
3046
3047 /* if we're blocking an exclusive and we have *any* holders,
3048 * then requeue. */
Joel Beckerbd3e7612008-02-01 12:14:57 -08003049 if ((lockres->l_blocking == DLM_LOCK_EX)
Mark Fashehf7fbfdd2006-09-13 21:02:29 -07003050 && (lockres->l_ex_holders || lockres->l_ro_holders))
3051 goto leave_requeue;
Mark Fashehccd979b2005-12-15 14:31:24 -08003052
3053 /* If it's a PR we're blocking, then only
3054 * requeue if we've got any EX holders */
Joel Beckerbd3e7612008-02-01 12:14:57 -08003055 if (lockres->l_blocking == DLM_LOCK_PR &&
Mark Fashehf7fbfdd2006-09-13 21:02:29 -07003056 lockres->l_ex_holders)
3057 goto leave_requeue;
3058
3059 /*
3060 * Can we get a lock in this state if the holder counts are
3061 * zero? The meta data unblock code used to check this.
3062 */
3063 if ((lockres->l_ops->flags & LOCK_TYPE_REQUIRES_REFRESH)
3064 && (lockres->l_flags & OCFS2_LOCK_REFRESHING))
3065 goto leave_requeue;
Mark Fashehccd979b2005-12-15 14:31:24 -08003066
Mark Fasheh16d5b952006-09-13 21:10:12 -07003067 new_level = ocfs2_highest_compat_lock_level(lockres->l_blocking);
3068
3069 if (lockres->l_ops->check_downconvert
3070 && !lockres->l_ops->check_downconvert(lockres, new_level))
3071 goto leave_requeue;
3072
Mark Fashehccd979b2005-12-15 14:31:24 -08003073 /* If we get here, then we know that there are no more
3074 * incompatible holders (and anyone asking for an incompatible
3075 * lock is blocked). We can now downconvert the lock */
Mark Fashehcc567d82006-09-13 21:52:21 -07003076 if (!lockres->l_ops->downconvert_worker)
Mark Fashehccd979b2005-12-15 14:31:24 -08003077 goto downconvert;
3078
3079 /* Some lockres types want to do a bit of work before
3080 * downconverting a lock. Allow that here. The worker function
3081 * may sleep, so we save off a copy of what we're blocking as
3082 * it may change while we're not holding the spin lock. */
3083 blocking = lockres->l_blocking;
3084 spin_unlock_irqrestore(&lockres->l_lock, flags);
3085
Mark Fashehcc567d82006-09-13 21:52:21 -07003086 ctl->unblock_action = lockres->l_ops->downconvert_worker(lockres, blocking);
Mark Fashehd680efe2006-09-08 14:14:34 -07003087
3088 if (ctl->unblock_action == UNBLOCK_STOP_POST)
3089 goto leave;
Mark Fashehccd979b2005-12-15 14:31:24 -08003090
3091 spin_lock_irqsave(&lockres->l_lock, flags);
3092 if (blocking != lockres->l_blocking) {
3093 /* If this changed underneath us, then we can't drop
3094 * it just yet. */
3095 goto recheck;
3096 }
3097
3098downconvert:
Mark Fashehd680efe2006-09-08 14:14:34 -07003099 ctl->requeue = 0;
Mark Fashehccd979b2005-12-15 14:31:24 -08003100
Mark Fasheh5ef0d4e2006-09-13 21:21:52 -07003101 if (lockres->l_ops->flags & LOCK_TYPE_USES_LVB) {
Joel Beckerbd3e7612008-02-01 12:14:57 -08003102 if (lockres->l_level == DLM_LOCK_EX)
Mark Fasheh5ef0d4e2006-09-13 21:21:52 -07003103 set_lvb = 1;
3104
3105 /*
3106 * We only set the lvb if the lock has been fully
3107 * refreshed - otherwise we risk setting stale
3108 * data. Otherwise, there's no need to actually clear
3109 * out the lvb here as it's value is still valid.
3110 */
3111 if (set_lvb && !(lockres->l_flags & OCFS2_LOCK_NEEDS_REFRESH))
3112 lockres->l_ops->set_lvb(lockres);
3113 }
3114
Joel Beckerde551242008-02-01 14:45:08 -08003115 gen = ocfs2_prepare_downconvert(lockres, new_level);
Mark Fashehccd979b2005-12-15 14:31:24 -08003116 spin_unlock_irqrestore(&lockres->l_lock, flags);
Joel Beckerde551242008-02-01 14:45:08 -08003117 ret = ocfs2_downconvert_lock(osb, lockres, new_level, set_lvb,
3118 gen);
3119
Mark Fashehccd979b2005-12-15 14:31:24 -08003120leave:
3121 mlog_exit(ret);
3122 return ret;
Mark Fashehf7fbfdd2006-09-13 21:02:29 -07003123
3124leave_requeue:
3125 spin_unlock_irqrestore(&lockres->l_lock, flags);
3126 ctl->requeue = 1;
3127
3128 mlog_exit(0);
3129 return 0;
Mark Fashehccd979b2005-12-15 14:31:24 -08003130}
3131
Mark Fashehd680efe2006-09-08 14:14:34 -07003132static int ocfs2_data_convert_worker(struct ocfs2_lock_res *lockres,
3133 int blocking)
Mark Fashehccd979b2005-12-15 14:31:24 -08003134{
3135 struct inode *inode;
3136 struct address_space *mapping;
3137
Mark Fashehccd979b2005-12-15 14:31:24 -08003138 inode = ocfs2_lock_res_inode(lockres);
3139 mapping = inode->i_mapping;
3140
Mark Fasheh1044e402008-02-28 17:16:03 -08003141 if (!S_ISREG(inode->i_mode))
Mark Fashehf1f54062007-10-18 15:13:59 -07003142 goto out;
3143
Mark Fasheh7f4a2a92006-12-11 11:06:36 -08003144 /*
3145 * We need this before the filemap_fdatawrite() so that it can
3146 * transfer the dirty bit from the PTE to the
3147 * page. Unfortunately this means that even for EX->PR
3148 * downconverts, we'll lose our mappings and have to build
3149 * them up again.
3150 */
3151 unmap_mapping_range(mapping, 0, 0, 0);
3152
Mark Fashehccd979b2005-12-15 14:31:24 -08003153 if (filemap_fdatawrite(mapping)) {
Mark Fashehb06970532006-03-03 10:24:33 -08003154 mlog(ML_ERROR, "Could not sync inode %llu for downconvert!",
3155 (unsigned long long)OCFS2_I(inode)->ip_blkno);
Mark Fashehccd979b2005-12-15 14:31:24 -08003156 }
3157 sync_mapping_buffers(mapping);
Joel Beckerbd3e7612008-02-01 12:14:57 -08003158 if (blocking == DLM_LOCK_EX) {
Mark Fashehccd979b2005-12-15 14:31:24 -08003159 truncate_inode_pages(mapping, 0);
Mark Fashehccd979b2005-12-15 14:31:24 -08003160 } else {
3161 /* We only need to wait on the I/O if we're not also
3162 * truncating pages because truncate_inode_pages waits
3163 * for us above. We don't truncate pages if we're
3164 * blocking anything < EXMODE because we want to keep
3165 * them around in that case. */
3166 filemap_fdatawait(mapping);
3167 }
3168
Mark Fashehf1f54062007-10-18 15:13:59 -07003169out:
Mark Fashehd680efe2006-09-08 14:14:34 -07003170 return UNBLOCK_CONTINUE;
Mark Fashehccd979b2005-12-15 14:31:24 -08003171}
3172
Mark Fasheh810d5ae2006-09-13 21:39:52 -07003173static int ocfs2_check_meta_downconvert(struct ocfs2_lock_res *lockres,
3174 int new_level)
3175{
3176 struct inode *inode = ocfs2_lock_res_inode(lockres);
3177 int checkpointed = ocfs2_inode_fully_checkpointed(inode);
3178
Joel Beckerbd3e7612008-02-01 12:14:57 -08003179 BUG_ON(new_level != DLM_LOCK_NL && new_level != DLM_LOCK_PR);
3180 BUG_ON(lockres->l_level != DLM_LOCK_EX && !checkpointed);
Mark Fasheh810d5ae2006-09-13 21:39:52 -07003181
3182 if (checkpointed)
3183 return 1;
3184
3185 ocfs2_start_checkpoint(OCFS2_SB(inode->i_sb));
3186 return 0;
3187}
3188
3189static void ocfs2_set_meta_lvb(struct ocfs2_lock_res *lockres)
3190{
3191 struct inode *inode = ocfs2_lock_res_inode(lockres);
3192
3193 __ocfs2_stuff_meta_lvb(inode);
3194}
3195
Mark Fashehd680efe2006-09-08 14:14:34 -07003196/*
3197 * Does the final reference drop on our dentry lock. Right now this
Mark Fasheh34d024f2007-09-24 15:56:19 -07003198 * happens in the downconvert thread, but we could choose to simplify the
Mark Fashehd680efe2006-09-08 14:14:34 -07003199 * dlmglue API and push these off to the ocfs2_wq in the future.
3200 */
3201static void ocfs2_dentry_post_unlock(struct ocfs2_super *osb,
3202 struct ocfs2_lock_res *lockres)
3203{
3204 struct ocfs2_dentry_lock *dl = ocfs2_lock_res_dl(lockres);
3205 ocfs2_dentry_lock_put(osb, dl);
3206}
3207
3208/*
3209 * d_delete() matching dentries before the lock downconvert.
3210 *
3211 * At this point, any process waiting to destroy the
3212 * dentry_lock due to last ref count is stopped by the
3213 * OCFS2_LOCK_QUEUED flag.
3214 *
3215 * We have two potential problems
3216 *
3217 * 1) If we do the last reference drop on our dentry_lock (via dput)
3218 * we'll wind up in ocfs2_release_dentry_lock(), waiting on
3219 * the downconvert to finish. Instead we take an elevated
3220 * reference and push the drop until after we've completed our
3221 * unblock processing.
3222 *
3223 * 2) There might be another process with a final reference,
3224 * waiting on us to finish processing. If this is the case, we
3225 * detect it and exit out - there's no more dentries anyway.
3226 */
3227static int ocfs2_dentry_convert_worker(struct ocfs2_lock_res *lockres,
3228 int blocking)
3229{
3230 struct ocfs2_dentry_lock *dl = ocfs2_lock_res_dl(lockres);
3231 struct ocfs2_inode_info *oi = OCFS2_I(dl->dl_inode);
3232 struct dentry *dentry;
3233 unsigned long flags;
3234 int extra_ref = 0;
3235
3236 /*
3237 * This node is blocking another node from getting a read
3238 * lock. This happens when we've renamed within a
3239 * directory. We've forced the other nodes to d_delete(), but
3240 * we never actually dropped our lock because it's still
3241 * valid. The downconvert code will retain a PR for this node,
3242 * so there's no further work to do.
3243 */
Joel Beckerbd3e7612008-02-01 12:14:57 -08003244 if (blocking == DLM_LOCK_PR)
Mark Fashehd680efe2006-09-08 14:14:34 -07003245 return UNBLOCK_CONTINUE;
3246
3247 /*
3248 * Mark this inode as potentially orphaned. The code in
3249 * ocfs2_delete_inode() will figure out whether it actually
3250 * needs to be freed or not.
3251 */
3252 spin_lock(&oi->ip_lock);
3253 oi->ip_flags |= OCFS2_INODE_MAYBE_ORPHANED;
3254 spin_unlock(&oi->ip_lock);
3255
3256 /*
3257 * Yuck. We need to make sure however that the check of
3258 * OCFS2_LOCK_FREEING and the extra reference are atomic with
3259 * respect to a reference decrement or the setting of that
3260 * flag.
3261 */
3262 spin_lock_irqsave(&lockres->l_lock, flags);
3263 spin_lock(&dentry_attach_lock);
3264 if (!(lockres->l_flags & OCFS2_LOCK_FREEING)
3265 && dl->dl_count) {
3266 dl->dl_count++;
3267 extra_ref = 1;
3268 }
3269 spin_unlock(&dentry_attach_lock);
3270 spin_unlock_irqrestore(&lockres->l_lock, flags);
3271
3272 mlog(0, "extra_ref = %d\n", extra_ref);
3273
3274 /*
3275 * We have a process waiting on us in ocfs2_dentry_iput(),
3276 * which means we can't have any more outstanding
3277 * aliases. There's no need to do any more work.
3278 */
3279 if (!extra_ref)
3280 return UNBLOCK_CONTINUE;
3281
3282 spin_lock(&dentry_attach_lock);
3283 while (1) {
3284 dentry = ocfs2_find_local_alias(dl->dl_inode,
3285 dl->dl_parent_blkno, 1);
3286 if (!dentry)
3287 break;
3288 spin_unlock(&dentry_attach_lock);
3289
3290 mlog(0, "d_delete(%.*s);\n", dentry->d_name.len,
3291 dentry->d_name.name);
3292
3293 /*
3294 * The following dcache calls may do an
3295 * iput(). Normally we don't want that from the
3296 * downconverting thread, but in this case it's ok
3297 * because the requesting node already has an
3298 * exclusive lock on the inode, so it can't be queued
3299 * for a downconvert.
3300 */
3301 d_delete(dentry);
3302 dput(dentry);
3303
3304 spin_lock(&dentry_attach_lock);
3305 }
3306 spin_unlock(&dentry_attach_lock);
3307
3308 /*
3309 * If we are the last holder of this dentry lock, there is no
3310 * reason to downconvert so skip straight to the unlock.
3311 */
3312 if (dl->dl_count == 1)
3313 return UNBLOCK_STOP_POST;
3314
3315 return UNBLOCK_CONTINUE_POST;
3316}
3317
Joel Becker4670c462008-02-01 14:39:35 -08003318/*
3319 * This is the filesystem locking protocol. It provides the lock handling
3320 * hooks for the underlying DLM. It has a maximum version number.
3321 * The version number allows interoperability with systems running at
3322 * the same major number and an equal or smaller minor number.
3323 *
3324 * Whenever the filesystem does new things with locks (adds or removes a
3325 * lock, orders them differently, does different things underneath a lock),
3326 * the version must be changed. The protocol is negotiated when joining
3327 * the dlm domain. A node may join the domain if its major version is
3328 * identical to all other nodes and its minor version is greater than
3329 * or equal to all other nodes. When its minor version is greater than
3330 * the other nodes, it will run at the minor version specified by the
3331 * other nodes.
3332 *
3333 * If a locking change is made that will not be compatible with older
3334 * versions, the major number must be increased and the minor version set
3335 * to zero. If a change merely adds a behavior that can be disabled when
3336 * speaking to older versions, the minor version must be increased. If a
3337 * change adds a fully backwards compatible change (eg, LVB changes that
3338 * are just ignored by older versions), the version does not need to be
3339 * updated.
3340 */
Joel Becker24ef1812008-01-29 17:37:32 -08003341static struct ocfs2_locking_protocol lproto = {
Joel Becker4670c462008-02-01 14:39:35 -08003342 .lp_max_version = {
3343 .pv_major = OCFS2_LOCKING_PROTOCOL_MAJOR,
3344 .pv_minor = OCFS2_LOCKING_PROTOCOL_MINOR,
3345 },
Joel Becker24ef1812008-01-29 17:37:32 -08003346 .lp_lock_ast = ocfs2_locking_ast,
3347 .lp_blocking_ast = ocfs2_blocking_ast,
3348 .lp_unlock_ast = ocfs2_unlock_ast,
3349};
3350
3351/* This interface isn't the final one, hence the less-than-perfect names */
3352void dlmglue_init_stack(void)
3353{
3354 o2cb_get_stack(&lproto);
3355}
3356
3357void dlmglue_exit_stack(void)
3358{
3359 o2cb_put_stack();
3360}
3361
Adrian Bunk00600052008-01-29 00:11:41 +02003362static void ocfs2_process_blocked_lock(struct ocfs2_super *osb,
3363 struct ocfs2_lock_res *lockres)
Mark Fashehccd979b2005-12-15 14:31:24 -08003364{
3365 int status;
Mark Fashehd680efe2006-09-08 14:14:34 -07003366 struct ocfs2_unblock_ctl ctl = {0, 0,};
Mark Fashehccd979b2005-12-15 14:31:24 -08003367 unsigned long flags;
3368
3369 /* Our reference to the lockres in this function can be
3370 * considered valid until we remove the OCFS2_LOCK_QUEUED
3371 * flag. */
3372
3373 mlog_entry_void();
3374
3375 BUG_ON(!lockres);
3376 BUG_ON(!lockres->l_ops);
Mark Fashehccd979b2005-12-15 14:31:24 -08003377
3378 mlog(0, "lockres %s blocked.\n", lockres->l_name);
3379
3380 /* Detect whether a lock has been marked as going away while
Mark Fasheh34d024f2007-09-24 15:56:19 -07003381 * the downconvert thread was processing other things. A lock can
Mark Fashehccd979b2005-12-15 14:31:24 -08003382 * still be marked with OCFS2_LOCK_FREEING after this check,
3383 * but short circuiting here will still save us some
3384 * performance. */
3385 spin_lock_irqsave(&lockres->l_lock, flags);
3386 if (lockres->l_flags & OCFS2_LOCK_FREEING)
3387 goto unqueue;
3388 spin_unlock_irqrestore(&lockres->l_lock, flags);
3389
Mark Fashehb5e500e2006-09-13 22:01:16 -07003390 status = ocfs2_unblock_lock(osb, lockres, &ctl);
Mark Fashehccd979b2005-12-15 14:31:24 -08003391 if (status < 0)
3392 mlog_errno(status);
3393
3394 spin_lock_irqsave(&lockres->l_lock, flags);
3395unqueue:
Mark Fashehd680efe2006-09-08 14:14:34 -07003396 if (lockres->l_flags & OCFS2_LOCK_FREEING || !ctl.requeue) {
Mark Fashehccd979b2005-12-15 14:31:24 -08003397 lockres_clear_flags(lockres, OCFS2_LOCK_QUEUED);
3398 } else
3399 ocfs2_schedule_blocked_lock(osb, lockres);
3400
3401 mlog(0, "lockres %s, requeue = %s.\n", lockres->l_name,
Mark Fashehd680efe2006-09-08 14:14:34 -07003402 ctl.requeue ? "yes" : "no");
Mark Fashehccd979b2005-12-15 14:31:24 -08003403 spin_unlock_irqrestore(&lockres->l_lock, flags);
3404
Mark Fashehd680efe2006-09-08 14:14:34 -07003405 if (ctl.unblock_action != UNBLOCK_CONTINUE
3406 && lockres->l_ops->post_unlock)
3407 lockres->l_ops->post_unlock(osb, lockres);
3408
Mark Fashehccd979b2005-12-15 14:31:24 -08003409 mlog_exit_void();
3410}
3411
3412static void ocfs2_schedule_blocked_lock(struct ocfs2_super *osb,
3413 struct ocfs2_lock_res *lockres)
3414{
3415 mlog_entry_void();
3416
3417 assert_spin_locked(&lockres->l_lock);
3418
3419 if (lockres->l_flags & OCFS2_LOCK_FREEING) {
3420 /* Do not schedule a lock for downconvert when it's on
3421 * the way to destruction - any nodes wanting access
3422 * to the resource will get it soon. */
3423 mlog(0, "Lockres %s won't be scheduled: flags 0x%lx\n",
3424 lockres->l_name, lockres->l_flags);
3425 return;
3426 }
3427
3428 lockres_or_flags(lockres, OCFS2_LOCK_QUEUED);
3429
Mark Fasheh34d024f2007-09-24 15:56:19 -07003430 spin_lock(&osb->dc_task_lock);
Mark Fashehccd979b2005-12-15 14:31:24 -08003431 if (list_empty(&lockres->l_blocked_list)) {
3432 list_add_tail(&lockres->l_blocked_list,
3433 &osb->blocked_lock_list);
3434 osb->blocked_lock_count++;
3435 }
Mark Fasheh34d024f2007-09-24 15:56:19 -07003436 spin_unlock(&osb->dc_task_lock);
Mark Fashehccd979b2005-12-15 14:31:24 -08003437
3438 mlog_exit_void();
3439}
Mark Fasheh34d024f2007-09-24 15:56:19 -07003440
3441static void ocfs2_downconvert_thread_do_work(struct ocfs2_super *osb)
3442{
3443 unsigned long processed;
3444 struct ocfs2_lock_res *lockres;
3445
3446 mlog_entry_void();
3447
3448 spin_lock(&osb->dc_task_lock);
3449 /* grab this early so we know to try again if a state change and
3450 * wake happens part-way through our work */
3451 osb->dc_work_sequence = osb->dc_wake_sequence;
3452
3453 processed = osb->blocked_lock_count;
3454 while (processed) {
3455 BUG_ON(list_empty(&osb->blocked_lock_list));
3456
3457 lockres = list_entry(osb->blocked_lock_list.next,
3458 struct ocfs2_lock_res, l_blocked_list);
3459 list_del_init(&lockres->l_blocked_list);
3460 osb->blocked_lock_count--;
3461 spin_unlock(&osb->dc_task_lock);
3462
3463 BUG_ON(!processed);
3464 processed--;
3465
3466 ocfs2_process_blocked_lock(osb, lockres);
3467
3468 spin_lock(&osb->dc_task_lock);
3469 }
3470 spin_unlock(&osb->dc_task_lock);
3471
3472 mlog_exit_void();
3473}
3474
3475static int ocfs2_downconvert_thread_lists_empty(struct ocfs2_super *osb)
3476{
3477 int empty = 0;
3478
3479 spin_lock(&osb->dc_task_lock);
3480 if (list_empty(&osb->blocked_lock_list))
3481 empty = 1;
3482
3483 spin_unlock(&osb->dc_task_lock);
3484 return empty;
3485}
3486
3487static int ocfs2_downconvert_thread_should_wake(struct ocfs2_super *osb)
3488{
3489 int should_wake = 0;
3490
3491 spin_lock(&osb->dc_task_lock);
3492 if (osb->dc_work_sequence != osb->dc_wake_sequence)
3493 should_wake = 1;
3494 spin_unlock(&osb->dc_task_lock);
3495
3496 return should_wake;
3497}
3498
Adrian Bunk200bfae2008-02-17 10:20:38 +02003499static int ocfs2_downconvert_thread(void *arg)
Mark Fasheh34d024f2007-09-24 15:56:19 -07003500{
3501 int status = 0;
3502 struct ocfs2_super *osb = arg;
3503
3504 /* only quit once we've been asked to stop and there is no more
3505 * work available */
3506 while (!(kthread_should_stop() &&
3507 ocfs2_downconvert_thread_lists_empty(osb))) {
3508
3509 wait_event_interruptible(osb->dc_event,
3510 ocfs2_downconvert_thread_should_wake(osb) ||
3511 kthread_should_stop());
3512
3513 mlog(0, "downconvert_thread: awoken\n");
3514
3515 ocfs2_downconvert_thread_do_work(osb);
3516 }
3517
3518 osb->dc_task = NULL;
3519 return status;
3520}
3521
3522void ocfs2_wake_downconvert_thread(struct ocfs2_super *osb)
3523{
3524 spin_lock(&osb->dc_task_lock);
3525 /* make sure the voting thread gets a swipe at whatever changes
3526 * the caller may have made to the voting state */
3527 osb->dc_wake_sequence++;
3528 spin_unlock(&osb->dc_task_lock);
3529 wake_up(&osb->dc_event);
3530}