page allocator: do not setup zonelist cache when there is only one node
[linux/fpc-iii.git] / fs / ocfs2 / ocfs2_lockid.h
bloba53ce87481bf20b1c724d2c699fab3c52674b991
1 /* -*- mode: c; c-basic-offset: 8; -*-
2 * vim: noexpandtab sw=8 ts=8 sts=0:
4 * ocfs2_lockid.h
6 * Defines OCFS2 lockid bits.
8 * Copyright (C) 2002, 2005 Oracle. All rights reserved.
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.
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.
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.
26 #ifndef OCFS2_LOCKID_H
27 #define OCFS2_LOCKID_H
29 /* lock ids are made up in the following manner:
30 * name[0] --> type
31 * name[1-6] --> 6 pad characters, reserved for now
32 * name[7-22] --> block number, expressed in hex as 16 chars
33 * name[23-30] --> i_generation, expressed in hex 8 chars
34 * name[31] --> '\0' */
35 #define OCFS2_LOCK_ID_MAX_LEN 32
36 #define OCFS2_LOCK_ID_PAD "000000"
38 #define OCFS2_DENTRY_LOCK_INO_START 18
40 enum ocfs2_lock_type {
41 OCFS2_LOCK_TYPE_META = 0,
42 OCFS2_LOCK_TYPE_DATA,
43 OCFS2_LOCK_TYPE_SUPER,
44 OCFS2_LOCK_TYPE_RENAME,
45 OCFS2_LOCK_TYPE_RW,
46 OCFS2_LOCK_TYPE_DENTRY,
47 OCFS2_LOCK_TYPE_OPEN,
48 OCFS2_LOCK_TYPE_FLOCK,
49 OCFS2_LOCK_TYPE_QINFO,
50 OCFS2_LOCK_TYPE_NFS_SYNC,
51 OCFS2_NUM_LOCK_TYPES
54 static inline char ocfs2_lock_type_char(enum ocfs2_lock_type type)
56 char c;
57 switch (type) {
58 case OCFS2_LOCK_TYPE_META:
59 c = 'M';
60 break;
61 case OCFS2_LOCK_TYPE_DATA:
62 c = 'D';
63 break;
64 case OCFS2_LOCK_TYPE_SUPER:
65 c = 'S';
66 break;
67 case OCFS2_LOCK_TYPE_RENAME:
68 c = 'R';
69 break;
70 case OCFS2_LOCK_TYPE_RW:
71 c = 'W';
72 break;
73 case OCFS2_LOCK_TYPE_DENTRY:
74 c = 'N';
75 break;
76 case OCFS2_LOCK_TYPE_OPEN:
77 c = 'O';
78 break;
79 case OCFS2_LOCK_TYPE_FLOCK:
80 c = 'F';
81 break;
82 case OCFS2_LOCK_TYPE_QINFO:
83 c = 'Q';
84 break;
85 case OCFS2_LOCK_TYPE_NFS_SYNC:
86 c = 'Y';
87 break;
88 default:
89 c = '\0';
92 return c;
95 static char *ocfs2_lock_type_strings[] = {
96 [OCFS2_LOCK_TYPE_META] = "Meta",
97 [OCFS2_LOCK_TYPE_DATA] = "Data",
98 [OCFS2_LOCK_TYPE_SUPER] = "Super",
99 [OCFS2_LOCK_TYPE_RENAME] = "Rename",
100 /* Need to differntiate from [R]ename.. serializing writes is the
101 * important job it does, anyway. */
102 [OCFS2_LOCK_TYPE_RW] = "Write/Read",
103 [OCFS2_LOCK_TYPE_DENTRY] = "Dentry",
104 [OCFS2_LOCK_TYPE_OPEN] = "Open",
105 [OCFS2_LOCK_TYPE_FLOCK] = "Flock",
106 [OCFS2_LOCK_TYPE_QINFO] = "Quota",
109 static inline const char *ocfs2_lock_type_string(enum ocfs2_lock_type type)
111 #ifdef __KERNEL__
112 BUG_ON(type >= OCFS2_NUM_LOCK_TYPES);
113 #endif
114 return ocfs2_lock_type_strings[type];
117 #endif /* OCFS2_LOCKID_H */