Whamcloud - gitweb
LU-3606 fallocate: Implement fallocate preallocate operation
[fs/lustre-release.git] / lustre / include / lustre_req_layout.h
1 /*
2  * GPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 only,
8  * as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License version 2 for more details (a copy is included
14  * in the LICENSE file that accompanied this code).
15  *
16  * You should have received a copy of the GNU General Public License
17  * version 2 along with this program; If not, see
18  * http://www.gnu.org/licenses/gpl-2.0.html
19  *
20  * GPL HEADER END
21  */
22 /*
23  * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
24  * Use is subject to license terms.
25  *
26  * Copyright (c) 2011, 2017, Intel Corporation.
27  */
28 /*
29  * This file is part of Lustre, http://www.lustre.org/
30  * Lustre is a trademark of Sun Microsystems, Inc.
31  *
32  * lustre/include/lustre_req_layout.h
33  *
34  * Lustre Metadata Target (mdt) request handler
35  *
36  * Author: Nikita Danilov <nikita@clusterfs.com>
37  */
38
39 #ifndef _LUSTRE_REQ_LAYOUT_H__
40 #define _LUSTRE_REQ_LAYOUT_H__
41
42 #include <linux/types.h>
43
44 /** \defgroup req_layout req_layout
45  *
46  * @{
47  */
48
49 struct req_msg_field;
50 struct req_format;
51 struct req_capsule;
52
53 struct ptlrpc_request;
54
55 enum req_location {
56         RCL_CLIENT,
57         RCL_SERVER,
58         RCL_NR
59 };
60
61 /* Maximal number of fields (buffers) in a request message. */
62 #define REQ_MAX_FIELD_NR 11
63
64 struct req_capsule {
65         struct ptlrpc_request   *rc_req;
66         const struct req_format *rc_fmt;
67         enum req_location        rc_loc;
68         __u32                    rc_area[RCL_NR][REQ_MAX_FIELD_NR];
69 };
70
71 void req_capsule_init(struct req_capsule *pill, struct ptlrpc_request *req,
72                       enum req_location location);
73 void req_capsule_fini(struct req_capsule *pill);
74
75 void req_capsule_set(struct req_capsule *pill, const struct req_format *fmt);
76 void req_capsule_client_dump(struct req_capsule *pill);
77 void req_capsule_server_dump(struct req_capsule *pill);
78 void req_capsule_init_area(struct req_capsule *pill);
79 size_t req_capsule_filled_sizes(struct req_capsule *pill,
80                                 enum req_location loc);
81 int  req_capsule_server_pack(struct req_capsule *pill);
82
83 void *req_capsule_client_get(struct req_capsule *pill,
84                              const struct req_msg_field *field);
85 void *req_capsule_client_swab_get(struct req_capsule *pill,
86                                   const struct req_msg_field *field,
87                                   void *swabber);
88 void *req_capsule_client_sized_get(struct req_capsule *pill,
89                                    const struct req_msg_field *field,
90                                    __u32 len);
91 void *req_capsule_server_get(struct req_capsule *pill,
92                              const struct req_msg_field *field);
93 void *req_capsule_server_sized_get(struct req_capsule *pill,
94                                    const struct req_msg_field *field,
95                                    __u32 len);
96 void *req_capsule_server_swab_get(struct req_capsule *pill,
97                                   const struct req_msg_field *field,
98                                   void *swabber);
99 void *req_capsule_server_sized_swab_get(struct req_capsule *pill,
100                                         const struct req_msg_field *field,
101                                         __u32 len, void *swabber);
102 const void *req_capsule_other_get(struct req_capsule *pill,
103                                   const struct req_msg_field *field);
104
105 void req_capsule_set_size(struct req_capsule *pill,
106                           const struct req_msg_field *field,
107                           enum req_location loc, __u32 size);
108 __u32 req_capsule_get_size(const struct req_capsule *pill,
109                            const struct req_msg_field *field,
110                            enum req_location loc);
111 __u32 req_capsule_msg_size(struct req_capsule *pill, enum req_location loc);
112 __u32 req_capsule_fmt_size(__u32 magic, const struct req_format *fmt,
113                          enum req_location loc);
114 void req_capsule_extend(struct req_capsule *pill, const struct req_format *fmt);
115
116 int req_capsule_has_field(const struct req_capsule *pill,
117                           const struct req_msg_field *field,
118                           enum req_location loc);
119 int req_capsule_field_present(const struct req_capsule *pill,
120                               const struct req_msg_field *field,
121                               enum req_location loc);
122 void req_capsule_shrink(struct req_capsule *pill,
123                         const struct req_msg_field *field,
124                         __u32 newlen,
125                         enum req_location loc);
126 int req_capsule_server_grow(struct req_capsule *pill,
127                             const struct req_msg_field *field,
128                             __u32 newlen);
129 int  req_layout_init(void);
130 void req_layout_fini(void);
131 int req_check_sepol(struct req_capsule *pill);
132
133 extern struct req_format RQF_OBD_PING;
134 extern struct req_format RQF_OBD_SET_INFO;
135 extern struct req_format RQF_MDT_SET_INFO;
136 extern struct req_format RQF_SEC_CTX;
137 extern struct req_format RQF_OBD_IDX_READ;
138 /* MGS req_format */
139 extern struct req_format RQF_MGS_TARGET_REG;
140 extern struct req_format RQF_MGS_SET_INFO;
141 extern struct req_format RQF_MGS_CONFIG_READ;
142 /* fid/fld req_format */
143 extern struct req_format RQF_SEQ_QUERY;
144 extern struct req_format RQF_FLD_QUERY;
145 extern struct req_format RQF_FLD_READ;
146 /* MDS req_format */
147 extern struct req_format RQF_MDS_CONNECT;
148 extern struct req_format RQF_MDS_DISCONNECT;
149 extern struct req_format RQF_MDS_STATFS;
150 extern struct req_format RQF_MDS_STATFS_NEW;
151 extern struct req_format RQF_MDS_GET_ROOT;
152 extern struct req_format RQF_MDS_SYNC;
153 extern struct req_format RQF_MDS_GETXATTR;
154 extern struct req_format RQF_MDS_GETATTR;
155 extern struct req_format RQF_OUT_UPDATE;
156
157 /*
158  * This is format of direct (non-intent) MDS_GETATTR_NAME request.
159  */
160 extern struct req_format RQF_MDS_GETATTR_NAME;
161 extern struct req_format RQF_MDS_CLOSE;
162 extern struct req_format RQF_MDS_CLOSE_INTENT;
163 extern struct req_format RQF_MDS_CONNECT;
164 extern struct req_format RQF_MDS_DISCONNECT;
165 extern struct req_format RQF_MDS_GET_INFO;
166 extern struct req_format RQF_MDS_READPAGE;
167 extern struct req_format RQF_MDS_REINT;
168 extern struct req_format RQF_MDS_REINT_CREATE;
169 extern struct req_format RQF_MDS_REINT_CREATE_ACL;
170 extern struct req_format RQF_MDS_REINT_CREATE_SLAVE;
171 extern struct req_format RQF_MDS_REINT_CREATE_SYM;
172 extern struct req_format RQF_MDS_REINT_OPEN;
173 extern struct req_format RQF_MDS_REINT_UNLINK;
174 extern struct req_format RQF_MDS_REINT_LINK;
175 extern struct req_format RQF_MDS_REINT_RENAME;
176 extern struct req_format RQF_MDS_REINT_SETATTR;
177 extern struct req_format RQF_MDS_REINT_SETXATTR;
178 extern struct req_format RQF_MDS_QUOTACTL;
179 extern struct req_format RQF_QUOTA_DQACQ;
180 extern struct req_format RQF_MDS_SWAP_LAYOUTS;
181 extern struct req_format RQF_MDS_REINT_MIGRATE;
182 extern struct req_format RQF_MDS_REINT_RESYNC;
183 extern struct req_format RQF_MDS_RMFID;
184 /* MDS hsm formats */
185 extern struct req_format RQF_MDS_HSM_STATE_GET;
186 extern struct req_format RQF_MDS_HSM_STATE_SET;
187 extern struct req_format RQF_MDS_HSM_ACTION;
188 extern struct req_format RQF_MDS_HSM_PROGRESS;
189 extern struct req_format RQF_MDS_HSM_CT_REGISTER;
190 extern struct req_format RQF_MDS_HSM_CT_UNREGISTER;
191 extern struct req_format RQF_MDS_HSM_REQUEST;
192 /* OST req_format */
193 extern struct req_format RQF_OST_CONNECT;
194 extern struct req_format RQF_OST_DISCONNECT;
195 extern struct req_format RQF_OST_QUOTACTL;
196 extern struct req_format RQF_OST_GETATTR;
197 extern struct req_format RQF_OST_SETATTR;
198 extern struct req_format RQF_OST_CREATE;
199 extern struct req_format RQF_OST_PUNCH;
200 extern struct req_format RQF_OST_FALLOCATE;
201 extern struct req_format RQF_OST_SYNC;
202 extern struct req_format RQF_OST_DESTROY;
203 extern struct req_format RQF_OST_BRW_READ;
204 extern struct req_format RQF_OST_BRW_WRITE;
205 extern struct req_format RQF_OST_STATFS;
206 extern struct req_format RQF_OST_SET_GRANT_INFO;
207 extern struct req_format RQF_OST_GET_INFO;
208 extern struct req_format RQF_OST_GET_INFO_LAST_ID;
209 extern struct req_format RQF_OST_GET_INFO_LAST_FID;
210 extern struct req_format RQF_OST_SET_INFO_LAST_FID;
211 extern struct req_format RQF_OST_GET_INFO_FIEMAP;
212 extern struct req_format RQF_OST_LADVISE;
213
214 /* LDLM req_format */
215 extern struct req_format RQF_LDLM_ENQUEUE;
216 extern struct req_format RQF_LDLM_ENQUEUE_LVB;
217 extern struct req_format RQF_LDLM_CONVERT;
218 extern struct req_format RQF_LDLM_INTENT;
219 extern struct req_format RQF_LDLM_INTENT_BASIC;
220 extern struct req_format RQF_LDLM_INTENT_LAYOUT;
221 extern struct req_format RQF_LDLM_INTENT_GETATTR;
222 extern struct req_format RQF_LDLM_INTENT_OPEN;
223 extern struct req_format RQF_LDLM_INTENT_CREATE;
224 extern struct req_format RQF_LDLM_INTENT_GETXATTR;
225 extern struct req_format RQF_LDLM_INTENT_QUOTA;
226 extern struct req_format RQF_LDLM_CANCEL;
227 extern struct req_format RQF_LDLM_CALLBACK;
228 extern struct req_format RQF_LDLM_CP_CALLBACK;
229 extern struct req_format RQF_LDLM_BL_CALLBACK;
230 extern struct req_format RQF_LDLM_GL_CALLBACK;
231 extern struct req_format RQF_LDLM_GL_CALLBACK_DESC;
232 /* LOG req_format */
233 extern struct req_format RQF_LLOG_ORIGIN_HANDLE_CREATE;
234 extern struct req_format RQF_LLOG_ORIGIN_HANDLE_NEXT_BLOCK;
235 extern struct req_format RQF_LLOG_ORIGIN_HANDLE_PREV_BLOCK;
236 extern struct req_format RQF_LLOG_ORIGIN_HANDLE_READ_HEADER;
237
238 extern struct req_format RQF_CONNECT;
239
240 /* LFSCK req_format */
241 extern struct req_format RQF_LFSCK_NOTIFY;
242 extern struct req_format RQF_LFSCK_QUERY;
243
244 extern struct req_msg_field RMF_GENERIC_DATA;
245 extern struct req_msg_field RMF_PTLRPC_BODY;
246 extern struct req_msg_field RMF_MDT_BODY;
247 extern struct req_msg_field RMF_MDT_EPOCH;
248 extern struct req_msg_field RMF_OBD_STATFS;
249 extern struct req_msg_field RMF_NAME;
250 extern struct req_msg_field RMF_SYMTGT;
251 extern struct req_msg_field RMF_TGTUUID;
252 extern struct req_msg_field RMF_CLUUID;
253 extern struct req_msg_field RMF_SETINFO_VAL;
254 extern struct req_msg_field RMF_SETINFO_KEY;
255 extern struct req_msg_field RMF_GETINFO_VAL;
256 extern struct req_msg_field RMF_GETINFO_VALLEN;
257 extern struct req_msg_field RMF_GETINFO_KEY;
258 extern struct req_msg_field RMF_IDX_INFO;
259 extern struct req_msg_field RMF_CLOSE_DATA;
260 extern struct req_msg_field RMF_FILE_SECCTX_NAME;
261 extern struct req_msg_field RMF_FILE_SECCTX;
262 extern struct req_msg_field RMF_FID_ARRAY;
263
264 /*
265  * connection handle received in MDS_CONNECT request.
266  */
267 extern struct req_msg_field RMF_CONN;
268 extern struct req_msg_field RMF_CONNECT_DATA;
269 extern struct req_msg_field RMF_DLM_REQ;
270 extern struct req_msg_field RMF_DLM_REP;
271 extern struct req_msg_field RMF_DLM_LVB;
272 extern struct req_msg_field RMF_DLM_GL_DESC;
273 extern struct req_msg_field RMF_LDLM_INTENT;
274 extern struct req_msg_field RMF_LAYOUT_INTENT;
275 extern struct req_msg_field RMF_MDT_MD;
276 extern struct req_msg_field RMF_DEFAULT_MDT_MD;
277 extern struct req_msg_field RMF_REC_REINT;
278 extern struct req_msg_field RMF_EADATA;
279 extern struct req_msg_field RMF_EAVALS;
280 extern struct req_msg_field RMF_EAVALS_LENS;
281 extern struct req_msg_field RMF_ACL;
282 extern struct req_msg_field RMF_LOGCOOKIES;
283 extern struct req_msg_field RMF_CAPA1;
284 extern struct req_msg_field RMF_CAPA2;
285 extern struct req_msg_field RMF_OBD_QUOTACHECK;
286 extern struct req_msg_field RMF_OBD_QUOTACTL;
287 extern struct req_msg_field RMF_OBD_QUOTACTL_POOL;
288 extern struct req_msg_field RMF_QUOTA_BODY;
289 extern struct req_msg_field RMF_STRING;
290 extern struct req_msg_field RMF_SWAP_LAYOUTS;
291 extern struct req_msg_field RMF_MDS_HSM_PROGRESS;
292 extern struct req_msg_field RMF_MDS_HSM_REQUEST;
293 extern struct req_msg_field RMF_MDS_HSM_USER_ITEM;
294 extern struct req_msg_field RMF_MDS_HSM_ARCHIVE;
295 extern struct req_msg_field RMF_HSM_USER_STATE;
296 extern struct req_msg_field RMF_HSM_STATE_SET;
297 extern struct req_msg_field RMF_MDS_HSM_CURRENT_ACTION;
298 extern struct req_msg_field RMF_MDS_HSM_REQUEST;
299 extern struct req_msg_field RMF_SELINUX_POL;
300
301 /* seq-mgr fields */
302 extern struct req_msg_field RMF_SEQ_OPC;
303 extern struct req_msg_field RMF_SEQ_RANGE;
304 extern struct req_msg_field RMF_FID_SPACE;
305
306 /* FLD fields */
307 extern struct req_msg_field RMF_FLD_OPC;
308 extern struct req_msg_field RMF_FLD_MDFLD;
309
310 extern struct req_msg_field RMF_LLOGD_BODY;
311 extern struct req_msg_field RMF_LLOG_LOG_HDR;
312 extern struct req_msg_field RMF_LLOGD_CONN_BODY;
313
314 extern struct req_msg_field RMF_MGS_TARGET_INFO;
315 extern struct req_msg_field RMF_MGS_SEND_PARAM;
316
317 extern struct req_msg_field RMF_OST_BODY;
318 extern struct req_msg_field RMF_OBD_IOOBJ;
319 extern struct req_msg_field RMF_OBD_ID;
320 extern struct req_msg_field RMF_FID;
321 extern struct req_msg_field RMF_NIOBUF_REMOTE;
322 extern struct req_msg_field RMF_NIOBUF_INLINE;
323 extern struct req_msg_field RMF_RCS;
324 extern struct req_msg_field RMF_FIEMAP_KEY;
325 extern struct req_msg_field RMF_FIEMAP_VAL;
326 extern struct req_msg_field RMF_OST_ID;
327 extern struct req_msg_field RMF_SHORT_IO;
328
329 /* MGS config read message format */
330 extern struct req_msg_field RMF_MGS_CONFIG_BODY;
331 extern struct req_msg_field RMF_MGS_CONFIG_RES;
332
333 /* generic uint32 */
334 extern struct req_msg_field RMF_U32;
335
336 /* OBJ update format */
337 extern struct req_msg_field RMF_OUT_UPDATE;
338 extern struct req_msg_field RMF_OUT_UPDATE_REPLY;
339 extern struct req_msg_field RMF_OUT_UPDATE_HEADER;
340 extern struct req_msg_field RMF_OUT_UPDATE_BUF;
341
342 /* LFSCK format */
343 extern struct req_msg_field RMF_LFSCK_REQUEST;
344 extern struct req_msg_field RMF_LFSCK_REPLY;
345
346 extern struct req_msg_field RMF_OST_LADVISE_HDR;
347 extern struct req_msg_field RMF_OST_LADVISE;
348 /** @} req_layout */
349
350 #endif /* _LUSTRE_REQ_LAYOUT_H__ */