GNU Linux-libre 4.14.251-gnu1
[releases.git] / drivers / staging / lustre / lustre / include / lustre_dlm_flags.h
1 /*  -*- buffer-read-only: t -*- vi: set ro:
2  *
3  * This program is free software; you can redistribute it and/or modify
4  * it under the terms of the GNU General Public License version 2 only,
5  * as published by the Free Software Foundation.
6  *
7  * Lustre is distributed in the hope that it will be useful, but
8  * WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
10  * See the GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License along
13  * with this program.  If not, see <http://www.gnu.org/licenses/>.
14  */
15 /**
16  * \file lustre_dlm_flags.h
17  * The flags and collections of flags (masks) for \see struct ldlm_lock.
18  *
19  * \addtogroup LDLM Lustre Distributed Lock Manager
20  * @{
21  *
22  * \name flags
23  * The flags and collections of flags (masks) for \see struct ldlm_lock.
24  * @{
25  */
26 #ifndef LDLM_ALL_FLAGS_MASK
27
28 /** l_flags bits marked as "all_flags" bits */
29 #define LDLM_FL_ALL_FLAGS_MASK          0x00FFFFFFC08F932FULL
30
31 /** extent, mode, or resource changed */
32 #define LDLM_FL_LOCK_CHANGED            0x0000000000000001ULL /* bit 0 */
33 #define ldlm_is_lock_changed(_l)        LDLM_TEST_FLAG((_l), 1ULL <<  0)
34 #define ldlm_set_lock_changed(_l)       LDLM_SET_FLAG((_l), 1ULL <<  0)
35 #define ldlm_clear_lock_changed(_l)     LDLM_CLEAR_FLAG((_l), 1ULL <<  0)
36
37 /**
38  * Server placed lock on granted list, or a recovering client wants the
39  * lock added to the granted list, no questions asked.
40  */
41 #define LDLM_FL_BLOCK_GRANTED           0x0000000000000002ULL /* bit 1 */
42 #define ldlm_is_block_granted(_l)       LDLM_TEST_FLAG((_l), 1ULL <<  1)
43 #define ldlm_set_block_granted(_l)      LDLM_SET_FLAG((_l), 1ULL <<  1)
44 #define ldlm_clear_block_granted(_l)    LDLM_CLEAR_FLAG((_l), 1ULL <<  1)
45
46 /**
47  * Server placed lock on conv list, or a recovering client wants the lock
48  * added to the conv list, no questions asked.
49  */
50 #define LDLM_FL_BLOCK_CONV              0x0000000000000004ULL /* bit 2 */
51 #define ldlm_is_block_conv(_l)          LDLM_TEST_FLAG((_l), 1ULL <<  2)
52 #define ldlm_set_block_conv(_l)         LDLM_SET_FLAG((_l), 1ULL <<  2)
53 #define ldlm_clear_block_conv(_l)       LDLM_CLEAR_FLAG((_l), 1ULL <<  2)
54
55 /**
56  * Server placed lock on wait list, or a recovering client wants the lock
57  * added to the wait list, no questions asked.
58  */
59 #define LDLM_FL_BLOCK_WAIT              0x0000000000000008ULL /* bit 3 */
60 #define ldlm_is_block_wait(_l)          LDLM_TEST_FLAG((_l), 1ULL <<  3)
61 #define ldlm_set_block_wait(_l)         LDLM_SET_FLAG((_l), 1ULL <<  3)
62 #define ldlm_clear_block_wait(_l)       LDLM_CLEAR_FLAG((_l), 1ULL <<  3)
63
64 /** blocking or cancel packet was queued for sending. */
65 #define LDLM_FL_AST_SENT                0x0000000000000020ULL /* bit 5 */
66 #define ldlm_is_ast_sent(_l)            LDLM_TEST_FLAG((_l), 1ULL <<  5)
67 #define ldlm_set_ast_sent(_l)           LDLM_SET_FLAG((_l), 1ULL <<  5)
68 #define ldlm_clear_ast_sent(_l)         LDLM_CLEAR_FLAG((_l), 1ULL <<  5)
69
70 /**
71  * Lock is being replayed.  This could probably be implied by the fact that
72  * one of BLOCK_{GRANTED,CONV,WAIT} is set, but that is pretty dangerous.
73  */
74 #define LDLM_FL_REPLAY                  0x0000000000000100ULL /* bit 8 */
75 #define ldlm_is_replay(_l)              LDLM_TEST_FLAG((_l), 1ULL <<  8)
76 #define ldlm_set_replay(_l)             LDLM_SET_FLAG((_l), 1ULL <<  8)
77 #define ldlm_clear_replay(_l)           LDLM_CLEAR_FLAG((_l), 1ULL <<  8)
78
79 /** Don't grant lock, just do intent. */
80 #define LDLM_FL_INTENT_ONLY             0x0000000000000200ULL /* bit 9 */
81 #define ldlm_is_intent_only(_l)         LDLM_TEST_FLAG((_l), 1ULL <<  9)
82 #define ldlm_set_intent_only(_l)        LDLM_SET_FLAG((_l), 1ULL <<  9)
83 #define ldlm_clear_intent_only(_l)      LDLM_CLEAR_FLAG((_l), 1ULL <<  9)
84
85 /** lock request has intent */
86 #define LDLM_FL_HAS_INTENT              0x0000000000001000ULL /* bit 12 */
87 #define ldlm_is_has_intent(_l)          LDLM_TEST_FLAG((_l), 1ULL << 12)
88 #define ldlm_set_has_intent(_l)         LDLM_SET_FLAG((_l), 1ULL << 12)
89 #define ldlm_clear_has_intent(_l)       LDLM_CLEAR_FLAG((_l), 1ULL << 12)
90
91 /** flock deadlock detected */
92 #define LDLM_FL_FLOCK_DEADLOCK          0x0000000000008000ULL /* bit  15 */
93 #define ldlm_is_flock_deadlock(_l)      LDLM_TEST_FLAG((_l), 1ULL << 15)
94 #define ldlm_set_flock_deadlock(_l)     LDLM_SET_FLAG((_l), 1ULL << 15)
95 #define ldlm_clear_flock_deadlock(_l)   LDLM_CLEAR_FLAG((_l), 1ULL << 15)
96
97 /** discard (no writeback) on cancel */
98 #define LDLM_FL_DISCARD_DATA            0x0000000000010000ULL /* bit 16 */
99 #define ldlm_is_discard_data(_l)        LDLM_TEST_FLAG((_l), 1ULL << 16)
100 #define ldlm_set_discard_data(_l)       LDLM_SET_FLAG((_l), 1ULL << 16)
101 #define ldlm_clear_discard_data(_l)     LDLM_CLEAR_FLAG((_l), 1ULL << 16)
102
103 /** Blocked by group lock - wait indefinitely */
104 #define LDLM_FL_NO_TIMEOUT              0x0000000000020000ULL /* bit 17 */
105 #define ldlm_is_no_timeout(_l)          LDLM_TEST_FLAG((_l), 1ULL << 17)
106 #define ldlm_set_no_timeout(_l)         LDLM_SET_FLAG((_l), 1ULL << 17)
107 #define ldlm_clear_no_timeout(_l)       LDLM_CLEAR_FLAG((_l), 1ULL << 17)
108
109 /**
110  * Server told not to wait if blocked. For AGL, OST will not send glimpse
111  * callback.
112  */
113 #define LDLM_FL_BLOCK_NOWAIT            0x0000000000040000ULL /* bit 18 */
114 #define ldlm_is_block_nowait(_l)        LDLM_TEST_FLAG((_l), 1ULL << 18)
115 #define ldlm_set_block_nowait(_l)       LDLM_SET_FLAG((_l), 1ULL << 18)
116 #define ldlm_clear_block_nowait(_l)     LDLM_CLEAR_FLAG((_l), 1ULL << 18)
117
118 /** return blocking lock */
119 #define LDLM_FL_TEST_LOCK               0x0000000000080000ULL /* bit 19 */
120 #define ldlm_is_test_lock(_l)           LDLM_TEST_FLAG((_l), 1ULL << 19)
121 #define ldlm_set_test_lock(_l)          LDLM_SET_FLAG((_l), 1ULL << 19)
122 #define ldlm_clear_test_lock(_l)        LDLM_CLEAR_FLAG((_l), 1ULL << 19)
123
124 /** match lock only */
125 #define LDLM_FL_MATCH_LOCK              0x0000000000100000ULL /* bit  20 */
126
127 /**
128  * Immediately cancel such locks when they block some other locks. Send
129  * cancel notification to original lock holder, but expect no reply. This
130  * is for clients (like liblustre) that cannot be expected to reliably
131  * response to blocking AST.
132  */
133 #define LDLM_FL_CANCEL_ON_BLOCK         0x0000000000800000ULL /* bit 23 */
134 #define ldlm_is_cancel_on_block(_l)     LDLM_TEST_FLAG((_l), 1ULL << 23)
135 #define ldlm_set_cancel_on_block(_l)    LDLM_SET_FLAG((_l), 1ULL << 23)
136 #define ldlm_clear_cancel_on_block(_l)  LDLM_CLEAR_FLAG((_l), 1ULL << 23)
137
138 /**
139  * measure lock contention and return -EUSERS if locking contention is high */
140 #define LDLM_FL_DENY_ON_CONTENTION        0x0000000040000000ULL /* bit 30 */
141 #define ldlm_is_deny_on_contention(_l)    LDLM_TEST_FLAG((_l), 1ULL << 30)
142 #define ldlm_set_deny_on_contention(_l)   LDLM_SET_FLAG((_l), 1ULL << 30)
143 #define ldlm_clear_deny_on_contention(_l) LDLM_CLEAR_FLAG((_l), 1ULL << 30)
144
145 /**
146  * These are flags that are mapped into the flags and ASTs of blocking
147  * locks Add FL_DISCARD to blocking ASTs */
148 #define LDLM_FL_AST_DISCARD_DATA        0x0000000080000000ULL /* bit 31 */
149 #define ldlm_is_ast_discard_data(_l)    LDLM_TEST_FLAG((_l), 1ULL << 31)
150 #define ldlm_set_ast_discard_data(_l)   LDLM_SET_FLAG((_l), 1ULL << 31)
151 #define ldlm_clear_ast_discard_data(_l) LDLM_CLEAR_FLAG((_l), 1ULL << 31)
152
153 /**
154  * Used for marking lock as a target for -EINTR while cp_ast sleep emulation
155  * + race with upcoming bl_ast.
156  */
157 #define LDLM_FL_FAIL_LOC                0x0000000100000000ULL /* bit 32 */
158 #define ldlm_is_fail_loc(_l)            LDLM_TEST_FLAG((_l), 1ULL << 32)
159 #define ldlm_set_fail_loc(_l)           LDLM_SET_FLAG((_l), 1ULL << 32)
160 #define ldlm_clear_fail_loc(_l)         LDLM_CLEAR_FLAG((_l), 1ULL << 32)
161
162 /**
163  * Used while processing the unused list to know that we have already
164  * handled this lock and decided to skip it.
165  */
166 #define LDLM_FL_SKIPPED                 0x0000000200000000ULL /* bit 33 */
167 #define ldlm_is_skipped(_l)             LDLM_TEST_FLAG((_l), 1ULL << 33)
168 #define ldlm_set_skipped(_l)            LDLM_SET_FLAG((_l), 1ULL << 33)
169 #define ldlm_clear_skipped(_l)          LDLM_CLEAR_FLAG((_l), 1ULL << 33)
170
171 /** this lock is being destroyed */
172 #define LDLM_FL_CBPENDING               0x0000000400000000ULL /* bit 34 */
173 #define ldlm_is_cbpending(_l)           LDLM_TEST_FLAG((_l), 1ULL << 34)
174 #define ldlm_set_cbpending(_l)          LDLM_SET_FLAG((_l), 1ULL << 34)
175 #define ldlm_clear_cbpending(_l)        LDLM_CLEAR_FLAG((_l), 1ULL << 34)
176
177 /** not a real flag, not saved in lock */
178 #define LDLM_FL_WAIT_NOREPROC           0x0000000800000000ULL /* bit 35 */
179 #define ldlm_is_wait_noreproc(_l)       LDLM_TEST_FLAG((_l), 1ULL << 35)
180 #define ldlm_set_wait_noreproc(_l)      LDLM_SET_FLAG((_l), 1ULL << 35)
181 #define ldlm_clear_wait_noreproc(_l)    LDLM_CLEAR_FLAG((_l), 1ULL << 35)
182
183 /** cancellation callback already run */
184 #define LDLM_FL_CANCEL                  0x0000001000000000ULL /* bit 36 */
185 #define ldlm_is_cancel(_l)              LDLM_TEST_FLAG((_l), 1ULL << 36)
186 #define ldlm_set_cancel(_l)             LDLM_SET_FLAG((_l), 1ULL << 36)
187 #define ldlm_clear_cancel(_l)           LDLM_CLEAR_FLAG((_l), 1ULL << 36)
188
189 /** whatever it might mean -- never transmitted? */
190 #define LDLM_FL_LOCAL_ONLY              0x0000002000000000ULL /* bit 37 */
191 #define ldlm_is_local_only(_l)          LDLM_TEST_FLAG((_l), 1ULL << 37)
192 #define ldlm_set_local_only(_l)         LDLM_SET_FLAG((_l), 1ULL << 37)
193 #define ldlm_clear_local_only(_l)       LDLM_CLEAR_FLAG((_l), 1ULL << 37)
194
195 /** don't run the cancel callback under ldlm_cli_cancel_unused */
196 #define LDLM_FL_FAILED                  0x0000004000000000ULL /* bit 38 */
197 #define ldlm_is_failed(_l)              LDLM_TEST_FLAG((_l), 1ULL << 38)
198 #define ldlm_set_failed(_l)             LDLM_SET_FLAG((_l), 1ULL << 38)
199 #define ldlm_clear_failed(_l)           LDLM_CLEAR_FLAG((_l), 1ULL << 38)
200
201 /** lock cancel has already been sent */
202 #define LDLM_FL_CANCELING               0x0000008000000000ULL /* bit 39 */
203 #define ldlm_is_canceling(_l)           LDLM_TEST_FLAG((_l), 1ULL << 39)
204 #define ldlm_set_canceling(_l)          LDLM_SET_FLAG((_l), 1ULL << 39)
205 #define ldlm_clear_canceling(_l)        LDLM_CLEAR_FLAG((_l), 1ULL << 39)
206
207 /** local lock (ie, no srv/cli split) */
208 #define LDLM_FL_LOCAL                   0x0000010000000000ULL /* bit 40 */
209 #define ldlm_is_local(_l)               LDLM_TEST_FLAG((_l), 1ULL << 40)
210 #define ldlm_set_local(_l)              LDLM_SET_FLAG((_l), 1ULL << 40)
211 #define ldlm_clear_local(_l)            LDLM_CLEAR_FLAG((_l), 1ULL << 40)
212
213 /**
214  * XXX FIXME: This is being added to b_size as a low-risk fix to the
215  * fact that the LVB filling happens _after_ the lock has been granted,
216  * so another thread can match it before the LVB has been updated.  As a
217  * dirty hack, we set LDLM_FL_LVB_READY only after we've done the LVB poop.
218  * this is only needed on LOV/OSC now, where LVB is actually used and
219  * callers must set it in input flags.
220  *
221  * The proper fix is to do the granting inside of the completion AST,
222  * which can be replaced with a LVB-aware wrapping function for OSC locks.
223  * That change is pretty high-risk, though, and would need a lot more
224  * testing.
225  */
226 #define LDLM_FL_LVB_READY               0x0000020000000000ULL /* bit 41 */
227 #define ldlm_is_lvb_ready(_l)           LDLM_TEST_FLAG((_l), 1ULL << 41)
228 #define ldlm_set_lvb_ready(_l)          LDLM_SET_FLAG((_l), 1ULL << 41)
229 #define ldlm_clear_lvb_ready(_l)        LDLM_CLEAR_FLAG((_l), 1ULL << 41)
230
231 /**
232  * A lock contributes to the known minimum size (KMS) calculation until it
233  * has finished the part of its cancellation that performs write back on its
234  * dirty pages.  It can remain on the granted list during this whole time.
235  * Threads racing to update the KMS after performing their writeback need
236  * to know to exclude each other's locks from the calculation as they walk
237  * the granted list.
238  */
239 #define LDLM_FL_KMS_IGNORE              0x0000040000000000ULL /* bit 42 */
240 #define ldlm_is_kms_ignore(_l)          LDLM_TEST_FLAG((_l), 1ULL << 42)
241 #define ldlm_set_kms_ignore(_l)         LDLM_SET_FLAG((_l), 1ULL << 42)
242 #define ldlm_clear_kms_ignore(_l)       LDLM_CLEAR_FLAG((_l), 1ULL << 42)
243
244 /** completion AST to be executed */
245 #define LDLM_FL_CP_REQD                 0x0000080000000000ULL /* bit 43 */
246 #define ldlm_is_cp_reqd(_l)             LDLM_TEST_FLAG((_l), 1ULL << 43)
247 #define ldlm_set_cp_reqd(_l)            LDLM_SET_FLAG((_l), 1ULL << 43)
248 #define ldlm_clear_cp_reqd(_l)          LDLM_CLEAR_FLAG((_l), 1ULL << 43)
249
250 /** cleanup_resource has already handled the lock */
251 #define LDLM_FL_CLEANED                 0x0000100000000000ULL /* bit 44 */
252 #define ldlm_is_cleaned(_l)             LDLM_TEST_FLAG((_l), 1ULL << 44)
253 #define ldlm_set_cleaned(_l)            LDLM_SET_FLAG((_l), 1ULL << 44)
254 #define ldlm_clear_cleaned(_l)          LDLM_CLEAR_FLAG((_l), 1ULL << 44)
255
256 /**
257  * optimization hint: LDLM can run blocking callback from current context
258  * w/o involving separate thread. in order to decrease cs rate
259  */
260 #define LDLM_FL_ATOMIC_CB               0x0000200000000000ULL /* bit 45 */
261 #define ldlm_is_atomic_cb(_l)           LDLM_TEST_FLAG((_l), 1ULL << 45)
262 #define ldlm_set_atomic_cb(_l)          LDLM_SET_FLAG((_l), 1ULL << 45)
263 #define ldlm_clear_atomic_cb(_l)        LDLM_CLEAR_FLAG((_l), 1ULL << 45)
264
265 /**
266  * It may happen that a client initiates two operations, e.g. unlink and
267  * mkdir, such that the server sends a blocking AST for conflicting locks
268  * to this client for the first operation, whereas the second operation
269  * has canceled this lock and is waiting for rpc_lock which is taken by
270  * the first operation. LDLM_FL_BL_AST is set by ldlm_callback_handler() in
271  * the lock to prevent the Early Lock Cancel (ELC) code from cancelling it.
272  */
273 #define LDLM_FL_BL_AST                  0x0000400000000000ULL /* bit 46 */
274 #define ldlm_is_bl_ast(_l)              LDLM_TEST_FLAG((_l), 1ULL << 46)
275 #define ldlm_set_bl_ast(_l)             LDLM_SET_FLAG((_l), 1ULL << 46)
276 #define ldlm_clear_bl_ast(_l)           LDLM_CLEAR_FLAG((_l), 1ULL << 46)
277
278 /**
279  * Set by ldlm_cancel_callback() when lock cache is dropped to let
280  * ldlm_callback_handler() return EINVAL to the server. It is used when
281  * ELC RPC is already prepared and is waiting for rpc_lock, too late to
282  * send a separate CANCEL RPC.
283  */
284 #define LDLM_FL_BL_DONE                 0x0000800000000000ULL /* bit 47 */
285 #define ldlm_is_bl_done(_l)             LDLM_TEST_FLAG((_l), 1ULL << 47)
286 #define ldlm_set_bl_done(_l)            LDLM_SET_FLAG((_l), 1ULL << 47)
287 #define ldlm_clear_bl_done(_l)          LDLM_CLEAR_FLAG((_l), 1ULL << 47)
288
289 /**
290  * Don't put lock into the LRU list, so that it is not canceled due
291  * to aging.  Used by MGC locks, they are cancelled only at unmount or
292  * by callback.
293  */
294 #define LDLM_FL_NO_LRU                  0x0001000000000000ULL /* bit 48 */
295 #define ldlm_is_no_lru(_l)              LDLM_TEST_FLAG((_l), 1ULL << 48)
296 #define ldlm_set_no_lru(_l)             LDLM_SET_FLAG((_l), 1ULL << 48)
297 #define ldlm_clear_no_lru(_l)           LDLM_CLEAR_FLAG((_l), 1ULL << 48)
298
299 /**
300  * Set for locks that failed and where the server has been notified.
301  *
302  * Protected by lock and resource locks.
303  */
304 #define LDLM_FL_FAIL_NOTIFIED           0x0002000000000000ULL /* bit 49 */
305 #define ldlm_is_fail_notified(_l)       LDLM_TEST_FLAG((_l), 1ULL << 49)
306 #define ldlm_set_fail_notified(_l)      LDLM_SET_FLAG((_l), 1ULL << 49)
307 #define ldlm_clear_fail_notified(_l)    LDLM_CLEAR_FLAG((_l), 1ULL << 49)
308
309 /**
310  * Set for locks that were removed from class hash table and will
311  * be destroyed when last reference to them is released. Set by
312  * ldlm_lock_destroy_internal().
313  *
314  * Protected by lock and resource locks.
315  */
316 #define LDLM_FL_DESTROYED               0x0004000000000000ULL /* bit 50 */
317 #define ldlm_is_destroyed(_l)           LDLM_TEST_FLAG((_l), 1ULL << 50)
318 #define ldlm_set_destroyed(_l)          LDLM_SET_FLAG((_l), 1ULL << 50)
319 #define ldlm_clear_destroyed(_l)        LDLM_CLEAR_FLAG((_l), 1ULL << 50)
320
321 /** flag whether this is a server namespace lock */
322 #define LDLM_FL_SERVER_LOCK             0x0008000000000000ULL /* bit 51 */
323 #define ldlm_is_server_lock(_l)         LDLM_TEST_FLAG((_l), 1ULL << 51)
324 #define ldlm_set_server_lock(_l)        LDLM_SET_FLAG((_l), 1ULL << 51)
325 #define ldlm_clear_server_lock(_l)      LDLM_CLEAR_FLAG((_l), 1ULL << 51)
326
327 /**
328  * It's set in lock_res_and_lock() and unset in unlock_res_and_lock().
329  *
330  * NB: compared with check_res_locked(), checking this bit is cheaper.
331  * Also, spin_is_locked() is deprecated for kernel code; one reason is
332  * because it works only for SMP so user needs to add extra macros like
333  * LASSERT_SPIN_LOCKED for uniprocessor kernels.
334  */
335 #define LDLM_FL_RES_LOCKED              0x0010000000000000ULL /* bit 52 */
336 #define ldlm_is_res_locked(_l)          LDLM_TEST_FLAG((_l), 1ULL << 52)
337 #define ldlm_set_res_locked(_l)         LDLM_SET_FLAG((_l), 1ULL << 52)
338 #define ldlm_clear_res_locked(_l)       LDLM_CLEAR_FLAG((_l), 1ULL << 52)
339
340 /**
341  * It's set once we call ldlm_add_waiting_lock_res_locked() to start the
342  * lock-timeout timer and it will never be reset.
343  *
344  * Protected by lock and resource locks.
345  */
346 #define LDLM_FL_WAITED                  0x0020000000000000ULL /* bit 53 */
347 #define ldlm_is_waited(_l)              LDLM_TEST_FLAG((_l), 1ULL << 53)
348 #define ldlm_set_waited(_l)             LDLM_SET_FLAG((_l), 1ULL << 53)
349 #define ldlm_clear_waited(_l)           LDLM_CLEAR_FLAG((_l), 1ULL << 53)
350
351 /** Flag whether this is a server namespace lock. */
352 #define LDLM_FL_NS_SRV                  0x0040000000000000ULL /* bit 54 */
353 #define ldlm_is_ns_srv(_l)              LDLM_TEST_FLAG((_l), 1ULL << 54)
354 #define ldlm_set_ns_srv(_l)             LDLM_SET_FLAG((_l), 1ULL << 54)
355 #define ldlm_clear_ns_srv(_l)           LDLM_CLEAR_FLAG((_l), 1ULL << 54)
356
357 /** Flag whether this lock can be reused. Used by exclusive open. */
358 #define LDLM_FL_EXCL                    0x0080000000000000ULL /* bit  55 */
359 #define ldlm_is_excl(_l)                LDLM_TEST_FLAG((_l), 1ULL << 55)
360 #define ldlm_set_excl(_l)               LDLM_SET_FLAG((_l), 1ULL << 55)
361 #define ldlm_clear_excl(_l)             LDLM_CLEAR_FLAG((_l), 1ULL << 55)
362
363 /** l_flags bits marked as "ast" bits */
364 #define LDLM_FL_AST_MASK                (LDLM_FL_FLOCK_DEADLOCK         |\
365                                          LDLM_FL_AST_DISCARD_DATA)
366
367 /** l_flags bits marked as "blocked" bits */
368 #define LDLM_FL_BLOCKED_MASK            (LDLM_FL_BLOCK_GRANTED          |\
369                                          LDLM_FL_BLOCK_CONV             |\
370                                          LDLM_FL_BLOCK_WAIT)
371
372 /** l_flags bits marked as "gone" bits */
373 #define LDLM_FL_GONE_MASK               (LDLM_FL_DESTROYED              |\
374                                          LDLM_FL_FAILED)
375
376 /** l_flags bits marked as "inherit" bits */
377 /* Flags inherited from wire on enqueue/reply between client/server. */
378 /* NO_TIMEOUT flag to force ldlm_lock_match() to wait with no timeout. */
379 /* TEST_LOCK flag to not let TEST lock to be granted. */
380 #define LDLM_FL_INHERIT_MASK            (LDLM_FL_CANCEL_ON_BLOCK        |\
381                                          LDLM_FL_NO_TIMEOUT             |\
382                                          LDLM_FL_TEST_LOCK)
383
384 /** test for ldlm_lock flag bit set */
385 #define LDLM_TEST_FLAG(_l, _b)        (((_l)->l_flags & (_b)) != 0)
386
387 /** multi-bit test: are any of mask bits set? */
388 #define LDLM_HAVE_MASK(_l, _m)          ((_l)->l_flags & LDLM_FL_##_m##_MASK)
389
390 /** set a ldlm_lock flag bit */
391 #define LDLM_SET_FLAG(_l, _b)         ((_l)->l_flags |= (_b))
392
393 /** clear a ldlm_lock flag bit */
394 #define LDLM_CLEAR_FLAG(_l, _b)       ((_l)->l_flags &= ~(_b))
395
396 /** @} subgroup */
397 /** @} group */
398
399 #endif /* LDLM_ALL_FLAGS_MASK */