Whamcloud - gitweb
b=16098
[fs/lustre-release.git] / lustre / ldlm / l_lock.c
1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2  * vim:expandtab:shiftwidth=8:tabstop=8:
3  *
4  * GPL HEADER START
5  *
6  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License version 2 only,
10  * as published by the Free Software Foundation.
11  *
12  * This program is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * General Public License version 2 for more details (a copy is included
16  * in the LICENSE file that accompanied this code).
17  *
18  * You should have received a copy of the GNU General Public License
19  * version 2 along with this program; If not, see
20  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
21  *
22  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
23  * CA 95054 USA or visit www.sun.com if you need additional information or
24  * have any questions.
25  *
26  * GPL HEADER END
27  */
28 /*
29  * Copyright  2008 Sun Microsystems, Inc. All rights reserved
30  * Use is subject to license terms.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  */
36
37 #define DEBUG_SUBSYSTEM S_LDLM
38 #ifdef __KERNEL__
39 #include <libcfs/libcfs.h>
40 #else 
41 #include <liblustre.h>
42 #endif
43
44 #include <lustre_dlm.h>
45 #include <lustre_lib.h>
46
47 /*
48  * ldlm locking uses resource to serialize access to locks
49  * but there is a case when we change resource of lock upon
50  * enqueue reply. we rely on that lock->l_resource = new_res
51  * is atomic
52  */
53 struct ldlm_resource * lock_res_and_lock(struct ldlm_lock *lock)
54 {
55         struct ldlm_resource *res = lock->l_resource;
56
57         if (ns_is_server(res->lr_namespace)) {
58                 /* on server-side resource of lock doesn't change */
59                 lock_res(res);
60                 return res;
61         } 
62
63         spin_lock(&lock->l_lock);
64         res = lock->l_resource;
65         lock_res(res);
66         return res;
67 }
68
69 void unlock_res_and_lock(struct ldlm_lock *lock)
70 {
71         struct ldlm_resource *res = lock->l_resource;
72
73         if (ns_is_server(res->lr_namespace)) {
74                 /* on server-side resource of lock doesn't change */
75                 unlock_res(res);
76                 return;
77         }
78
79         unlock_res(res);
80         spin_unlock(&lock->l_lock);
81 }