Whamcloud - gitweb
- make HEAD from b_post_cmd3
[fs/lustre-release.git] / lustre / include / lustre_req_layout.h
1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2  * vim:expandtab:shiftwidth=8:tabstop=8:
3  *
4  *  lustre/include/linux/lustre_req_layout.h
5  *  Lustre Metadata Target (mdt) request handler
6  *
7  *  Copyright (c) 2006 Cluster File Systems, Inc.
8  *   Author: Nikita Danilov <nikita@clusterfs.com>
9  *
10  *   This file is part of the Lustre file system, http://www.lustre.org
11  *   Lustre is a trademark of Cluster File Systems, Inc.
12  *
13  *   You may have signed or agreed to another license before downloading
14  *   this software.  If so, you are bound by the terms and conditions
15  *   of that agreement, and the following does not apply to you.  See the
16  *   LICENSE file included with this distribution for more information.
17  *
18  *   If you did not agree to a different license, then this copy of Lustre
19  *   is open source software; you can redistribute it and/or modify it
20  *   under the terms of version 2 of the GNU General Public License as
21  *   published by the Free Software Foundation.
22  *
23  *   In either case, Lustre is distributed in the hope that it will be
24  *   useful, but WITHOUT ANY WARRANTY; without even the implied warranty
25  *   of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26  *   license text for more details.
27  */
28
29 #ifndef _LUSTRE_REQ_LAYOUT_H__
30 #define _LUSTRE_REQ_LAYOUT_H__
31
32 struct req_msg_field;
33 struct req_format;
34 struct req_capsule;
35
36 struct ptlrpc_request;
37
38 enum req_location {
39         RCL_CLIENT,
40         RCL_SERVER,
41         RCL_NR
42 };
43
44 struct req_capsule {
45         struct ptlrpc_request   *rc_req;
46         const struct req_format *rc_fmt;
47         __u32                    rc_swabbed;
48         enum req_location        rc_loc;
49         int                     *rc_area;
50 };
51
52 enum {
53         /*
54          * Maximal number of fields (buffers) in a request message.
55          */
56         REQ_MAX_FIELD_NR = 8
57 };
58
59 #if !defined(__REQ_LAYOUT_USER__)
60
61 /* struct ptlrpc_request, lustre_msg* */
62 #include <lustre_net.h>
63
64 void req_capsule_init(struct req_capsule *pill, struct ptlrpc_request *req,
65                       enum req_location location, int *area);
66 void req_capsule_fini(struct req_capsule *pill);
67
68 void req_capsule_set(struct req_capsule *pill, const struct req_format *fmt);
69 int  req_capsule_pack(struct req_capsule *pill);
70
71 void *req_capsule_client_get(struct req_capsule *pill,
72                              const struct req_msg_field *field);
73 void *req_capsule_server_get(struct req_capsule *pill,
74                              const struct req_msg_field *field);
75 const void *req_capsule_other_get(struct req_capsule *pill,
76                                   const struct req_msg_field *field);
77
78 void req_capsule_set_size(const struct req_capsule *pill,
79                           const struct req_msg_field *field,
80                           enum req_location loc, int size);
81 int req_capsule_get_size(const struct req_capsule *pill,
82                           const struct req_msg_field *field,
83                           enum req_location loc);
84 void req_capsule_extend(struct req_capsule *pill, const struct req_format *fmt);
85
86 int req_capsule_has_field(const struct req_capsule *pill,
87                           const struct req_msg_field *field,
88                           enum req_location loc);
89 int req_capsule_field_present(const struct req_capsule *pill,
90                               const struct req_msg_field *field,
91                               enum req_location loc);
92
93 int req_capsule_shrink(const struct req_capsule *pill,
94                        const struct req_msg_field *field,
95                        const unsigned int newlen,
96                        const int adjust,
97                        const int move_data);
98
99 int  req_layout_init(void);
100 void req_layout_fini(void);
101
102 /* __REQ_LAYOUT_USER__ */
103 #endif
104
105 extern const struct req_format RQF_SEQ_QUERY;
106 extern const struct req_format RQF_FLD_QUERY;
107 extern const struct req_format RQF_MDS_GETSTATUS;
108 extern const struct req_format RQF_MDS_STATFS;
109 extern const struct req_format RQF_MDS_SYNC;
110 extern const struct req_format RQF_MDS_GETXATTR;
111 extern const struct req_format RQF_MDS_SETXATTR;
112 extern const struct req_format RQF_MDS_GETATTR;
113 extern const struct req_format RQF_MDS_CLOSE;
114 extern const struct req_format RQF_MDS_PIN;
115 extern const struct req_format RQF_MDS_CONNECT;
116 extern const struct req_format RQF_MDS_DISCONNECT;
117 extern const struct req_format RQF_MDS_SET_INFO;
118 extern const struct req_format RQF_MDS_READPAGE;
119 extern const struct req_format RQF_MDS_WRITEPAGE;
120 extern const struct req_format RQF_MDS_IS_SUBDIR;
121 extern const struct req_format RQF_MDS_DONE_WRITING;
122
123 /*
124  * This is format of direct (non-intent) MDS_GETATTR_NAME request.
125  */
126 extern const struct req_format RQF_MDS_GETATTR_NAME;
127 extern const struct req_format RQF_MDS_REINT;
128 extern const struct req_format RQF_MDS_REINT_CREATE;
129 extern const struct req_format RQF_MDS_REINT_CREATE_RMT_ACL;
130 extern const struct req_format RQF_MDS_REINT_CREATE_SLAVE;
131 extern const struct req_format RQF_MDS_REINT_CREATE_SYM;
132 extern const struct req_format RQF_MDS_REINT_OPEN;
133 extern const struct req_format RQF_MDS_REINT_UNLINK;
134 extern const struct req_format RQF_MDS_REINT_LINK;
135 extern const struct req_format RQF_MDS_REINT_RENAME;
136 extern const struct req_format RQF_MDS_REINT_SETATTR;
137 extern const struct req_format RQF_LDLM_ENQUEUE;
138 extern const struct req_format RQF_LDLM_INTENT;
139 extern const struct req_format RQF_LDLM_INTENT_GETATTR;
140 extern const struct req_format RQF_LDLM_INTENT_OPEN;
141 extern const struct req_format RQF_LDLM_INTENT_CREATE;
142 extern const struct req_format RQF_LDLM_INTENT_UNLINK;
143
144 extern const struct req_msg_field RMF_PTLRPC_BODY;
145 extern const struct req_msg_field RMF_MDT_BODY;
146 extern const struct req_msg_field RMF_MDT_EPOCH;
147 extern const struct req_msg_field RMF_OBD_STATFS;
148 extern const struct req_msg_field RMF_NAME;
149 extern const struct req_msg_field RMF_SYMTGT;
150 extern const struct req_msg_field RMF_TGTUUID;
151 extern const struct req_msg_field RMF_CLUUID;
152 extern const struct req_msg_field RMF_SETINFO_VAL;
153 extern const struct req_msg_field RMF_SETINFO_KEY;
154 /*
155  * connection handle received in MDS_CONNECT request.
156  */
157 extern const struct req_msg_field RMF_CONN;
158 extern const struct req_msg_field RMF_CONNECT_DATA;
159 extern const struct req_msg_field RMF_DLM_REQ;
160 extern const struct req_msg_field RMF_DLM_REP;
161 extern const struct req_msg_field RMF_LDLM_INTENT;
162 extern const struct req_msg_field RMF_MDT_MD;
163 extern const struct req_msg_field RMF_REC_CREATE;
164 extern const struct req_msg_field RMF_REC_LINK;
165 extern const struct req_msg_field RMF_REC_UNLINK;
166 extern const struct req_msg_field RMF_REC_RENAME;
167 extern const struct req_msg_field RMF_REC_SETATTR;
168 extern const struct req_msg_field RMF_EADATA;
169 extern const struct req_msg_field RMF_ACL;
170 extern const struct req_msg_field RMF_LOGCOOKIES;
171 extern const struct req_msg_field RMF_REINT_OPC;
172 extern const struct req_msg_field RMF_CAPA1;
173 extern const struct req_msg_field RMF_CAPA2;
174
175 /* seq-mgr fields */
176 extern const struct req_msg_field RMF_SEQ_OPC;
177 extern const struct req_msg_field RMF_SEQ_RANGE;
178
179 /* FLD fields */
180 extern const struct req_msg_field RMF_FLD_OPC;
181 extern const struct req_msg_field RMF_FLD_MDFLD;
182
183 #endif /* _LUSTRE_REQ_LAYOUT_H__ */