Whamcloud - gitweb
Revert "LU-3544 nfs: writing to new files will return ENOENT"
[fs/lustre-release.git] / lustre / llite / file.c
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.sun.com/software/products/lustre/docs/GPLv2.pdf
19  *
20  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21  * CA 95054 USA or visit www.sun.com if you need additional information or
22  * have any questions.
23  *
24  * GPL HEADER END
25  */
26 /*
27  * Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved.
28  * Use is subject to license terms.
29  *
30  * Copyright (c) 2011, 2013, Intel Corporation.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  *
36  * lustre/llite/file.c
37  *
38  * Author: Peter Braam <braam@clusterfs.com>
39  * Author: Phil Schwan <phil@clusterfs.com>
40  * Author: Andreas Dilger <adilger@clusterfs.com>
41  */
42
43 #define DEBUG_SUBSYSTEM S_LLITE
44 #include <lustre_dlm.h>
45 #include <lustre_lite.h>
46 #include <linux/pagemap.h>
47 #include <linux/file.h>
48 #include "llite_internal.h"
49 #include <lustre/ll_fiemap.h>
50
51 #include "cl_object.h"
52
53 struct ll_file_data *ll_file_data_get(void)
54 {
55         struct ll_file_data *fd;
56
57         OBD_SLAB_ALLOC_PTR_GFP(fd, ll_file_data_slab, __GFP_IO);
58         if (fd == NULL)
59                 return NULL;
60
61         fd->fd_write_failed = false;
62
63         return fd;
64 }
65
66 static void ll_file_data_put(struct ll_file_data *fd)
67 {
68         if (fd != NULL)
69                 OBD_SLAB_FREE_PTR(fd, ll_file_data_slab);
70 }
71
72 void ll_pack_inode2opdata(struct inode *inode, struct md_op_data *op_data,
73                           struct lustre_handle *fh)
74 {
75         op_data->op_fid1 = ll_i2info(inode)->lli_fid;
76         op_data->op_attr.ia_mode = inode->i_mode;
77         op_data->op_attr.ia_atime = inode->i_atime;
78         op_data->op_attr.ia_mtime = inode->i_mtime;
79         op_data->op_attr.ia_ctime = inode->i_ctime;
80         op_data->op_attr.ia_size = i_size_read(inode);
81         op_data->op_attr_blocks = inode->i_blocks;
82         ((struct ll_iattr *)&op_data->op_attr)->ia_attr_flags =
83                                         ll_inode_to_ext_flags(inode->i_flags);
84         op_data->op_ioepoch = ll_i2info(inode)->lli_ioepoch;
85         if (fh)
86                 op_data->op_handle = *fh;
87         op_data->op_capa1 = ll_mdscapa_get(inode);
88
89         if (LLIF_DATA_MODIFIED & ll_i2info(inode)->lli_flags)
90                 op_data->op_bias |= MDS_DATA_MODIFIED;
91 }
92
93 /**
94  * Closes the IO epoch and packs all the attributes into @op_data for
95  * the CLOSE rpc.
96  */
97 static void ll_prepare_close(struct inode *inode, struct md_op_data *op_data,
98                              struct obd_client_handle *och)
99 {
100         ENTRY;
101
102         op_data->op_attr.ia_valid = ATTR_MODE | ATTR_ATIME | ATTR_ATIME_SET |
103                                         ATTR_MTIME | ATTR_MTIME_SET |
104                                         ATTR_CTIME | ATTR_CTIME_SET;
105
106         if (!(och->och_flags & FMODE_WRITE))
107                 goto out;
108
109         if (!exp_connect_som(ll_i2mdexp(inode)) || !S_ISREG(inode->i_mode))
110                 op_data->op_attr.ia_valid |= ATTR_SIZE | ATTR_BLOCKS;
111         else
112                 ll_ioepoch_close(inode, op_data, &och, 0);
113
114 out:
115         ll_pack_inode2opdata(inode, op_data, &och->och_fh);
116         ll_prep_md_op_data(op_data, inode, NULL, NULL,
117                            0, 0, LUSTRE_OPC_ANY, NULL);
118         EXIT;
119 }
120
121 static int ll_close_inode_openhandle(struct obd_export *md_exp,
122                                      struct inode *inode,
123                                      struct obd_client_handle *och,
124                                      const __u64 *data_version)
125 {
126         struct obd_export *exp = ll_i2mdexp(inode);
127         struct md_op_data *op_data;
128         struct ptlrpc_request *req = NULL;
129         struct obd_device *obd = class_exp2obd(exp);
130         int epoch_close = 1;
131         int rc;
132         ENTRY;
133
134         if (obd == NULL) {
135                 /*
136                  * XXX: in case of LMV, is this correct to access
137                  * ->exp_handle?
138                  */
139                 CERROR("Invalid MDC connection handle "LPX64"\n",
140                        ll_i2mdexp(inode)->exp_handle.h_cookie);
141                 GOTO(out, rc = 0);
142         }
143
144         OBD_ALLOC_PTR(op_data);
145         if (op_data == NULL)
146                 GOTO(out, rc = -ENOMEM); // XXX We leak openhandle and request here.
147
148         ll_prepare_close(inode, op_data, och);
149         if (data_version != NULL) {
150                 /* Pass in data_version implies release. */
151                 op_data->op_bias |= MDS_HSM_RELEASE;
152                 op_data->op_data_version = *data_version;
153                 op_data->op_lease_handle = och->och_lease_handle;
154                 op_data->op_attr.ia_valid |= ATTR_SIZE | ATTR_BLOCKS;
155         }
156         epoch_close = (op_data->op_flags & MF_EPOCH_CLOSE);
157         rc = md_close(md_exp, op_data, och->och_mod, &req);
158         if (rc == -EAGAIN) {
159                 /* This close must have the epoch closed. */
160                 LASSERT(epoch_close);
161                 /* MDS has instructed us to obtain Size-on-MDS attribute from
162                  * OSTs and send setattr to back to MDS. */
163                 rc = ll_som_update(inode, op_data);
164                 if (rc) {
165                         CERROR("inode %lu mdc Size-on-MDS update failed: "
166                                "rc = %d\n", inode->i_ino, rc);
167                         rc = 0;
168                 }
169         } else if (rc) {
170                 CERROR("inode %lu mdc close failed: rc = %d\n",
171                        inode->i_ino, rc);
172         }
173
174         /* DATA_MODIFIED flag was successfully sent on close, cancel data
175          * modification flag. */
176         if (rc == 0 && (op_data->op_bias & MDS_DATA_MODIFIED)) {
177                 struct ll_inode_info *lli = ll_i2info(inode);
178
179                 spin_lock(&lli->lli_lock);
180                 lli->lli_flags &= ~LLIF_DATA_MODIFIED;
181                 spin_unlock(&lli->lli_lock);
182         }
183
184         if (rc == 0) {
185                 rc = ll_objects_destroy(req, inode);
186                 if (rc)
187                         CERROR("inode %lu ll_objects destroy: rc = %d\n",
188                                inode->i_ino, rc);
189         }
190
191         if (rc == 0 && op_data->op_bias & MDS_HSM_RELEASE) {
192                 struct mdt_body *body;
193                 body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
194                 if (!(body->valid & OBD_MD_FLRELEASED))
195                         rc = -EBUSY;
196         }
197
198         ll_finish_md_op_data(op_data);
199         EXIT;
200 out:
201
202         if (exp_connect_som(exp) && !epoch_close &&
203             S_ISREG(inode->i_mode) && (och->och_flags & FMODE_WRITE)) {
204                 ll_queue_done_writing(inode, LLIF_DONE_WRITING);
205         } else {
206                 md_clear_open_replay_data(md_exp, och);
207                 /* Free @och if it is not waiting for DONE_WRITING. */
208                 och->och_fh.cookie = DEAD_HANDLE_MAGIC;
209                 OBD_FREE_PTR(och);
210         }
211         if (req) /* This is close request */
212                 ptlrpc_req_finished(req);
213         return rc;
214 }
215
216 int ll_md_real_close(struct inode *inode, int flags)
217 {
218         struct ll_inode_info *lli = ll_i2info(inode);
219         struct obd_client_handle **och_p;
220         struct obd_client_handle *och;
221         __u64 *och_usecount;
222         int rc = 0;
223         ENTRY;
224
225         if (flags & FMODE_WRITE) {
226                 och_p = &lli->lli_mds_write_och;
227                 och_usecount = &lli->lli_open_fd_write_count;
228         } else if (flags & FMODE_EXEC) {
229                 och_p = &lli->lli_mds_exec_och;
230                 och_usecount = &lli->lli_open_fd_exec_count;
231         } else {
232                 LASSERT(flags & FMODE_READ);
233                 och_p = &lli->lli_mds_read_och;
234                 och_usecount = &lli->lli_open_fd_read_count;
235         }
236
237         mutex_lock(&lli->lli_och_mutex);
238         if (*och_usecount) { /* There are still users of this handle, so
239                                 skip freeing it. */
240                 mutex_unlock(&lli->lli_och_mutex);
241                 RETURN(0);
242         }
243         och=*och_p;
244         *och_p = NULL;
245         mutex_unlock(&lli->lli_och_mutex);
246
247         if (och) { /* There might be a race and somebody have freed this och
248                       already */
249                 rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp,
250                                                inode, och, NULL);
251         }
252
253         RETURN(rc);
254 }
255
256 int ll_md_close(struct obd_export *md_exp, struct inode *inode,
257                 struct file *file)
258 {
259         struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
260         struct ll_inode_info *lli = ll_i2info(inode);
261         int rc = 0;
262         ENTRY;
263
264         /* clear group lock, if present */
265         if (unlikely(fd->fd_flags & LL_FILE_GROUP_LOCKED))
266                 ll_put_grouplock(inode, file, fd->fd_grouplock.cg_gid);
267
268         if (fd->fd_lease_och != NULL) {
269                 bool lease_broken;
270
271                 /* Usually the lease is not released when the
272                  * application crashed, we need to release here. */
273                 rc = ll_lease_close(fd->fd_lease_och, inode, &lease_broken);
274                 CDEBUG(rc ? D_ERROR : D_INODE, "Clean up lease "DFID" %d/%d\n",
275                         PFID(&lli->lli_fid), rc, lease_broken);
276
277                 fd->fd_lease_och = NULL;
278         }
279
280         if (fd->fd_och != NULL) {
281                 rc = ll_close_inode_openhandle(md_exp, inode, fd->fd_och, NULL);
282                 fd->fd_och = NULL;
283                 GOTO(out, rc);
284         }
285
286         /* Let's see if we have good enough OPEN lock on the file and if
287            we can skip talking to MDS */
288         if (file->f_dentry->d_inode) { /* Can this ever be false? */
289                 int lockmode;
290                 int flags = LDLM_FL_BLOCK_GRANTED | LDLM_FL_TEST_LOCK;
291                 struct lustre_handle lockh;
292                 struct inode *inode = file->f_dentry->d_inode;
293                 ldlm_policy_data_t policy = {.l_inodebits={MDS_INODELOCK_OPEN}};
294
295                 mutex_lock(&lli->lli_och_mutex);
296                 if (fd->fd_omode & FMODE_WRITE) {
297                         lockmode = LCK_CW;
298                         LASSERT(lli->lli_open_fd_write_count);
299                         lli->lli_open_fd_write_count--;
300                 } else if (fd->fd_omode & FMODE_EXEC) {
301                         lockmode = LCK_PR;
302                         LASSERT(lli->lli_open_fd_exec_count);
303                         lli->lli_open_fd_exec_count--;
304                 } else {
305                         lockmode = LCK_CR;
306                         LASSERT(lli->lli_open_fd_read_count);
307                         lli->lli_open_fd_read_count--;
308                 }
309                 mutex_unlock(&lli->lli_och_mutex);
310
311                 if (!md_lock_match(md_exp, flags, ll_inode2fid(inode),
312                                    LDLM_IBITS, &policy, lockmode,
313                                    &lockh)) {
314                         rc = ll_md_real_close(file->f_dentry->d_inode,
315                                               fd->fd_omode);
316                 }
317         } else {
318                 CERROR("Releasing a file %p with negative dentry %p. Name %s",
319                        file, file->f_dentry, file->f_dentry->d_name.name);
320         }
321
322 out:
323         LUSTRE_FPRIVATE(file) = NULL;
324         ll_file_data_put(fd);
325         ll_capa_close(inode);
326
327         RETURN(rc);
328 }
329
330 /* While this returns an error code, fput() the caller does not, so we need
331  * to make every effort to clean up all of our state here.  Also, applications
332  * rarely check close errors and even if an error is returned they will not
333  * re-try the close call.
334  */
335 int ll_file_release(struct inode *inode, struct file *file)
336 {
337         struct ll_file_data *fd;
338         struct ll_sb_info *sbi = ll_i2sbi(inode);
339         struct ll_inode_info *lli = ll_i2info(inode);
340         int rc;
341         ENTRY;
342
343         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p)\n", inode->i_ino,
344                inode->i_generation, inode);
345
346 #ifdef CONFIG_FS_POSIX_ACL
347         if (sbi->ll_flags & LL_SBI_RMT_CLIENT &&
348             inode == inode->i_sb->s_root->d_inode) {
349                 struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
350
351                 LASSERT(fd != NULL);
352                 if (unlikely(fd->fd_flags & LL_FILE_RMTACL)) {
353                         fd->fd_flags &= ~LL_FILE_RMTACL;
354                         rct_del(&sbi->ll_rct, current_pid());
355                         et_search_free(&sbi->ll_et, current_pid());
356                 }
357         }
358 #endif
359
360         if (inode->i_sb->s_root != file->f_dentry)
361                 ll_stats_ops_tally(sbi, LPROC_LL_RELEASE, 1);
362         fd = LUSTRE_FPRIVATE(file);
363         LASSERT(fd != NULL);
364
365         /* The last ref on @file, maybe not the the owner pid of statahead.
366          * Different processes can open the same dir, "ll_opendir_key" means:
367          * it is me that should stop the statahead thread. */
368         if (S_ISDIR(inode->i_mode) && lli->lli_opendir_key == fd &&
369             lli->lli_opendir_pid != 0)
370                 ll_stop_statahead(inode, lli->lli_opendir_key);
371
372         if (inode->i_sb->s_root == file->f_dentry) {
373                 LUSTRE_FPRIVATE(file) = NULL;
374                 ll_file_data_put(fd);
375                 RETURN(0);
376         }
377
378         if (!S_ISDIR(inode->i_mode)) {
379                 lov_read_and_clear_async_rc(lli->lli_clob);
380                 lli->lli_async_rc = 0;
381         }
382
383         rc = ll_md_close(sbi->ll_md_exp, inode, file);
384
385         if (CFS_FAIL_TIMEOUT_MS(OBD_FAIL_PTLRPC_DUMP_LOG, cfs_fail_val))
386                 libcfs_debug_dumplog();
387
388         RETURN(rc);
389 }
390
391 static int ll_intent_file_open(struct file *file, void *lmm,
392                                int lmmsize, struct lookup_intent *itp)
393 {
394         struct ll_sb_info *sbi = ll_i2sbi(file->f_dentry->d_inode);
395         struct dentry *parent = file->f_dentry->d_parent;
396         const char *name = file->f_dentry->d_name.name;
397         const int len = file->f_dentry->d_name.len;
398         struct md_op_data *op_data;
399         struct ptlrpc_request *req;
400         __u32 opc = LUSTRE_OPC_ANY;
401         int rc;
402         ENTRY;
403
404         if (!parent)
405                 RETURN(-ENOENT);
406
407         /* Usually we come here only for NFSD, and we want open lock.
408            But we can also get here with pre 2.6.15 patchless kernels, and in
409            that case that lock is also ok */
410         /* We can also get here if there was cached open handle in revalidate_it
411          * but it disappeared while we were getting from there to ll_file_open.
412          * But this means this file was closed and immediatelly opened which
413          * makes a good candidate for using OPEN lock */
414         /* If lmmsize & lmm are not 0, we are just setting stripe info
415          * parameters. No need for the open lock */
416         if (lmm == NULL && lmmsize == 0) {
417                 itp->it_flags |= MDS_OPEN_LOCK;
418                 if (itp->it_flags & FMODE_WRITE)
419                         opc = LUSTRE_OPC_CREATE;
420         }
421
422         op_data  = ll_prep_md_op_data(NULL, parent->d_inode,
423                                       file->f_dentry->d_inode, name, len,
424                                       O_RDWR, opc, NULL);
425         if (IS_ERR(op_data))
426                 RETURN(PTR_ERR(op_data));
427
428         itp->it_flags |= MDS_OPEN_BY_FID;
429         rc = md_intent_lock(sbi->ll_md_exp, op_data, lmm, lmmsize, itp,
430                             0 /*unused */, &req, ll_md_blocking_ast, 0);
431         ll_finish_md_op_data(op_data);
432         if (rc == -ESTALE) {
433                 /* reason for keep own exit path - don`t flood log
434                 * with messages with -ESTALE errors.
435                 */
436                 if (!it_disposition(itp, DISP_OPEN_OPEN) ||
437                      it_open_error(DISP_OPEN_OPEN, itp))
438                         GOTO(out, rc);
439                 ll_release_openhandle(file->f_dentry, itp);
440                 GOTO(out, rc);
441         }
442
443         if (it_disposition(itp, DISP_LOOKUP_NEG))
444                 GOTO(out, rc = -ENOENT);
445
446         if (rc != 0 || it_open_error(DISP_OPEN_OPEN, itp)) {
447                 rc = rc ? rc : it_open_error(DISP_OPEN_OPEN, itp);
448                 CDEBUG(D_VFSTRACE, "lock enqueue: err: %d\n", rc);
449                 GOTO(out, rc);
450         }
451
452         rc = ll_prep_inode(&file->f_dentry->d_inode, req, NULL, itp);
453         if (!rc && itp->d.lustre.it_lock_mode)
454                 ll_set_lock_data(sbi->ll_md_exp, file->f_dentry->d_inode,
455                                  itp, NULL);
456
457 out:
458         ptlrpc_req_finished(itp->d.lustre.it_data);
459         it_clear_disposition(itp, DISP_ENQ_COMPLETE);
460         ll_intent_drop_lock(itp);
461
462         RETURN(rc);
463 }
464
465 /**
466  * Assign an obtained @ioepoch to client's inode. No lock is needed, MDS does
467  * not believe attributes if a few ioepoch holders exist. Attributes for
468  * previous ioepoch if new one is opened are also skipped by MDS.
469  */
470 void ll_ioepoch_open(struct ll_inode_info *lli, __u64 ioepoch)
471 {
472         if (ioepoch && lli->lli_ioepoch != ioepoch) {
473                 lli->lli_ioepoch = ioepoch;
474                 CDEBUG(D_INODE, "Epoch "LPU64" opened on "DFID"\n",
475                        ioepoch, PFID(&lli->lli_fid));
476         }
477 }
478
479 static int ll_och_fill(struct obd_export *md_exp, struct lookup_intent *it,
480                        struct obd_client_handle *och)
481 {
482         struct ptlrpc_request *req = it->d.lustre.it_data;
483         struct mdt_body *body;
484
485         body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
486         och->och_fh = body->handle;
487         och->och_fid = body->fid1;
488         och->och_lease_handle.cookie = it->d.lustre.it_lock_handle;
489         och->och_magic = OBD_CLIENT_HANDLE_MAGIC;
490         och->och_flags = it->it_flags;
491
492         return md_set_open_replay_data(md_exp, och, req);
493 }
494
495 int ll_local_open(struct file *file, struct lookup_intent *it,
496                   struct ll_file_data *fd, struct obd_client_handle *och)
497 {
498         struct inode *inode = file->f_dentry->d_inode;
499         struct ll_inode_info *lli = ll_i2info(inode);
500         ENTRY;
501
502         LASSERT(!LUSTRE_FPRIVATE(file));
503
504         LASSERT(fd != NULL);
505
506         if (och) {
507                 struct ptlrpc_request *req = it->d.lustre.it_data;
508                 struct mdt_body *body;
509                 int rc;
510
511                 rc = ll_och_fill(ll_i2sbi(inode)->ll_md_exp, it, och);
512                 if (rc != 0)
513                         RETURN(rc);
514
515                 body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
516                 ll_ioepoch_open(lli, body->ioepoch);
517         }
518
519         LUSTRE_FPRIVATE(file) = fd;
520         ll_readahead_init(inode, &fd->fd_ras);
521         fd->fd_omode = it->it_flags & (FMODE_READ | FMODE_WRITE | FMODE_EXEC);
522
523         RETURN(0);
524 }
525
526 /* Open a file, and (for the very first open) create objects on the OSTs at
527  * this time.  If opened with O_LOV_DELAY_CREATE, then we don't do the object
528  * creation or open until ll_lov_setstripe() ioctl is called.
529  *
530  * If we already have the stripe MD locally then we don't request it in
531  * md_open(), by passing a lmm_size = 0.
532  *
533  * It is up to the application to ensure no other processes open this file
534  * in the O_LOV_DELAY_CREATE case, or the default striping pattern will be
535  * used.  We might be able to avoid races of that sort by getting lli_open_sem
536  * before returning in the O_LOV_DELAY_CREATE case and dropping it here
537  * or in ll_file_release(), but I'm not sure that is desirable/necessary.
538  */
539 int ll_file_open(struct inode *inode, struct file *file)
540 {
541         struct ll_inode_info *lli = ll_i2info(inode);
542         struct lookup_intent *it, oit = { .it_op = IT_OPEN,
543                                           .it_flags = file->f_flags };
544         struct obd_client_handle **och_p = NULL;
545         __u64 *och_usecount = NULL;
546         struct ll_file_data *fd;
547         int rc = 0, opendir_set = 0;
548         ENTRY;
549
550         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p), flags %o\n", inode->i_ino,
551                inode->i_generation, inode, file->f_flags);
552
553         it = file->private_data; /* XXX: compat macro */
554         file->private_data = NULL; /* prevent ll_local_open assertion */
555
556         fd = ll_file_data_get();
557         if (fd == NULL)
558                 GOTO(out_openerr, rc = -ENOMEM);
559
560         fd->fd_file = file;
561         if (S_ISDIR(inode->i_mode)) {
562                 spin_lock(&lli->lli_sa_lock);
563                 if (lli->lli_opendir_key == NULL && lli->lli_sai == NULL &&
564                     lli->lli_opendir_pid == 0) {
565                         lli->lli_opendir_key = fd;
566                         lli->lli_opendir_pid = current_pid();
567                         opendir_set = 1;
568                 }
569                 spin_unlock(&lli->lli_sa_lock);
570         }
571
572         if (inode->i_sb->s_root == file->f_dentry) {
573                 LUSTRE_FPRIVATE(file) = fd;
574                 RETURN(0);
575         }
576
577         if (!it || !it->d.lustre.it_disposition) {
578                 /* Convert f_flags into access mode. We cannot use file->f_mode,
579                  * because everything but O_ACCMODE mask was stripped from
580                  * there */
581                 if ((oit.it_flags + 1) & O_ACCMODE)
582                         oit.it_flags++;
583                 if (file->f_flags & O_TRUNC)
584                         oit.it_flags |= FMODE_WRITE;
585
586                 /* kernel only call f_op->open in dentry_open.  filp_open calls
587                  * dentry_open after call to open_namei that checks permissions.
588                  * Only nfsd_open call dentry_open directly without checking
589                  * permissions and because of that this code below is safe. */
590                 if (oit.it_flags & (FMODE_WRITE | FMODE_READ))
591                         oit.it_flags |= MDS_OPEN_OWNEROVERRIDE;
592
593                 /* We do not want O_EXCL here, presumably we opened the file
594                  * already? XXX - NFS implications? */
595                 oit.it_flags &= ~O_EXCL;
596
597                 /* bug20584, if "it_flags" contains O_CREAT, the file will be
598                  * created if necessary, then "IT_CREAT" should be set to keep
599                  * consistent with it */
600                 if (oit.it_flags & O_CREAT)
601                         oit.it_op |= IT_CREAT;
602
603                 it = &oit;
604         }
605
606 restart:
607         /* Let's see if we have file open on MDS already. */
608         if (it->it_flags & FMODE_WRITE) {
609                 och_p = &lli->lli_mds_write_och;
610                 och_usecount = &lli->lli_open_fd_write_count;
611         } else if (it->it_flags & FMODE_EXEC) {
612                 och_p = &lli->lli_mds_exec_och;
613                 och_usecount = &lli->lli_open_fd_exec_count;
614          } else {
615                 och_p = &lli->lli_mds_read_och;
616                 och_usecount = &lli->lli_open_fd_read_count;
617         }
618
619         mutex_lock(&lli->lli_och_mutex);
620         if (*och_p) { /* Open handle is present */
621                 if (it_disposition(it, DISP_OPEN_OPEN)) {
622                         /* Well, there's extra open request that we do not need,
623                            let's close it somehow. This will decref request. */
624                         rc = it_open_error(DISP_OPEN_OPEN, it);
625                         if (rc) {
626                                 mutex_unlock(&lli->lli_och_mutex);
627                                 GOTO(out_openerr, rc);
628                         }
629
630                         ll_release_openhandle(file->f_dentry, it);
631                 }
632                 (*och_usecount)++;
633
634                 rc = ll_local_open(file, it, fd, NULL);
635                 if (rc) {
636                         (*och_usecount)--;
637                         mutex_unlock(&lli->lli_och_mutex);
638                         GOTO(out_openerr, rc);
639                 }
640         } else {
641                 LASSERT(*och_usecount == 0);
642                 if (!it->d.lustre.it_disposition) {
643                         /* We cannot just request lock handle now, new ELC code
644                            means that one of other OPEN locks for this file
645                            could be cancelled, and since blocking ast handler
646                            would attempt to grab och_mutex as well, that would
647                            result in a deadlock */
648                         mutex_unlock(&lli->lli_och_mutex);
649                         it->it_create_mode |= M_CHECK_STALE;
650                         rc = ll_intent_file_open(file, NULL, 0, it);
651                         it->it_create_mode &= ~M_CHECK_STALE;
652                         if (rc)
653                                 GOTO(out_openerr, rc);
654
655                         goto restart;
656                 }
657                 OBD_ALLOC(*och_p, sizeof (struct obd_client_handle));
658                 if (!*och_p)
659                         GOTO(out_och_free, rc = -ENOMEM);
660
661                 (*och_usecount)++;
662
663                 /* md_intent_lock() didn't get a request ref if there was an
664                  * open error, so don't do cleanup on the request here
665                  * (bug 3430) */
666                 /* XXX (green): Should not we bail out on any error here, not
667                  * just open error? */
668                 rc = it_open_error(DISP_OPEN_OPEN, it);
669                 if (rc)
670                         GOTO(out_och_free, rc);
671
672                 LASSERT(it_disposition(it, DISP_ENQ_OPEN_REF));
673
674                 rc = ll_local_open(file, it, fd, *och_p);
675                 if (rc)
676                         GOTO(out_och_free, rc);
677         }
678         mutex_unlock(&lli->lli_och_mutex);
679         fd = NULL;
680
681         /* Must do this outside lli_och_mutex lock to prevent deadlock where
682            different kind of OPEN lock for this same inode gets cancelled
683            by ldlm_cancel_lru */
684         if (!S_ISREG(inode->i_mode))
685                 GOTO(out_och_free, rc);
686
687         ll_capa_open(inode);
688
689         if (!lli->lli_has_smd) {
690                 if (file->f_flags & O_LOV_DELAY_CREATE ||
691                     !(file->f_mode & FMODE_WRITE)) {
692                         CDEBUG(D_INODE, "object creation was delayed\n");
693                         GOTO(out_och_free, rc);
694                 }
695         }
696         file->f_flags &= ~O_LOV_DELAY_CREATE;
697         GOTO(out_och_free, rc);
698
699 out_och_free:
700         if (rc) {
701                 if (och_p && *och_p) {
702                         OBD_FREE(*och_p, sizeof (struct obd_client_handle));
703                         *och_p = NULL; /* OBD_FREE writes some magic there */
704                         (*och_usecount)--;
705                 }
706                 mutex_unlock(&lli->lli_och_mutex);
707
708 out_openerr:
709                 if (opendir_set != 0)
710                         ll_stop_statahead(inode, lli->lli_opendir_key);
711                 if (fd != NULL)
712                         ll_file_data_put(fd);
713         } else {
714                 ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_OPEN, 1);
715         }
716
717         if (it && it_disposition(it, DISP_ENQ_OPEN_REF)) {
718                 ptlrpc_req_finished(it->d.lustre.it_data);
719                 it_clear_disposition(it, DISP_ENQ_OPEN_REF);
720         }
721
722         return rc;
723 }
724
725 static int ll_md_blocking_lease_ast(struct ldlm_lock *lock,
726                         struct ldlm_lock_desc *desc, void *data, int flag)
727 {
728         int rc;
729         struct lustre_handle lockh;
730         ENTRY;
731
732         switch (flag) {
733         case LDLM_CB_BLOCKING:
734                 ldlm_lock2handle(lock, &lockh);
735                 rc = ldlm_cli_cancel(&lockh, LCF_ASYNC);
736                 if (rc < 0) {
737                         CDEBUG(D_INODE, "ldlm_cli_cancel: %d\n", rc);
738                         RETURN(rc);
739                 }
740                 break;
741         case LDLM_CB_CANCELING:
742                 /* do nothing */
743                 break;
744         }
745         RETURN(0);
746 }
747
748 /**
749  * Acquire a lease and open the file.
750  */
751 struct obd_client_handle *ll_lease_open(struct inode *inode, struct file *file,
752                                         fmode_t fmode, __u64 open_flags)
753 {
754         struct lookup_intent it = { .it_op = IT_OPEN };
755         struct ll_sb_info *sbi = ll_i2sbi(inode);
756         struct md_op_data *op_data;
757         struct ptlrpc_request *req;
758         struct lustre_handle old_handle = { 0 };
759         struct obd_client_handle *och = NULL;
760         int rc;
761         int rc2;
762         ENTRY;
763
764         if (fmode != FMODE_WRITE && fmode != FMODE_READ)
765                 RETURN(ERR_PTR(-EINVAL));
766
767         if (file != NULL) {
768                 struct ll_inode_info *lli = ll_i2info(inode);
769                 struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
770                 struct obd_client_handle **och_p;
771                 __u64 *och_usecount;
772
773                 if (!(fmode & file->f_mode) || (file->f_mode & FMODE_EXEC))
774                         RETURN(ERR_PTR(-EPERM));
775
776                 /* Get the openhandle of the file */
777                 rc = -EBUSY;
778                 mutex_lock(&lli->lli_och_mutex);
779                 if (fd->fd_lease_och != NULL) {
780                         mutex_unlock(&lli->lli_och_mutex);
781                         RETURN(ERR_PTR(rc));
782                 }
783
784                 if (fd->fd_och == NULL) {
785                         if (file->f_mode & FMODE_WRITE) {
786                                 LASSERT(lli->lli_mds_write_och != NULL);
787                                 och_p = &lli->lli_mds_write_och;
788                                 och_usecount = &lli->lli_open_fd_write_count;
789                         } else {
790                                 LASSERT(lli->lli_mds_read_och != NULL);
791                                 och_p = &lli->lli_mds_read_och;
792                                 och_usecount = &lli->lli_open_fd_read_count;
793                         }
794                         if (*och_usecount == 1) {
795                                 fd->fd_och = *och_p;
796                                 *och_p = NULL;
797                                 *och_usecount = 0;
798                                 rc = 0;
799                         }
800                 }
801                 mutex_unlock(&lli->lli_och_mutex);
802                 if (rc < 0) /* more than 1 opener */
803                         RETURN(ERR_PTR(rc));
804
805                 LASSERT(fd->fd_och != NULL);
806                 old_handle = fd->fd_och->och_fh;
807         }
808
809         OBD_ALLOC_PTR(och);
810         if (och == NULL)
811                 RETURN(ERR_PTR(-ENOMEM));
812
813         op_data = ll_prep_md_op_data(NULL, inode, inode, NULL, 0, 0,
814                                         LUSTRE_OPC_ANY, NULL);
815         if (IS_ERR(op_data))
816                 GOTO(out, rc = PTR_ERR(op_data));
817
818         /* To tell the MDT this openhandle is from the same owner */
819         op_data->op_handle = old_handle;
820
821         it.it_flags = fmode | open_flags;
822         it.it_flags |= MDS_OPEN_LOCK | MDS_OPEN_BY_FID | MDS_OPEN_LEASE;
823         rc = md_intent_lock(sbi->ll_md_exp, op_data, NULL, 0, &it, 0, &req,
824                                 ll_md_blocking_lease_ast,
825         /* LDLM_FL_NO_LRU: To not put the lease lock into LRU list, otherwise
826          * it can be cancelled which may mislead applications that the lease is
827          * broken;
828          * LDLM_FL_EXCL: Set this flag so that it won't be matched by normal
829          * open in ll_md_blocking_ast(). Otherwise as ll_md_blocking_lease_ast
830          * doesn't deal with openhandle, so normal openhandle will be leaked. */
831                                 LDLM_FL_NO_LRU | LDLM_FL_EXCL);
832         ll_finish_md_op_data(op_data);
833         if (req != NULL) {
834                 ptlrpc_req_finished(req);
835                 it_clear_disposition(&it, DISP_ENQ_COMPLETE);
836         }
837         if (rc < 0)
838                 GOTO(out_release_it, rc);
839
840         if (it_disposition(&it, DISP_LOOKUP_NEG))
841                 GOTO(out_release_it, rc = -ENOENT);
842
843         rc = it_open_error(DISP_OPEN_OPEN, &it);
844         if (rc)
845                 GOTO(out_release_it, rc);
846
847         LASSERT(it_disposition(&it, DISP_ENQ_OPEN_REF));
848         ll_och_fill(sbi->ll_md_exp, &it, och);
849
850         if (!it_disposition(&it, DISP_OPEN_LEASE)) /* old server? */
851                 GOTO(out_close, rc = -EOPNOTSUPP);
852
853         /* already get lease, handle lease lock */
854         ll_set_lock_data(sbi->ll_md_exp, inode, &it, NULL);
855         if (it.d.lustre.it_lock_mode == 0 ||
856             it.d.lustre.it_lock_bits != MDS_INODELOCK_OPEN) {
857                 /* open lock must return for lease */
858                 CERROR(DFID "lease granted but no open lock, %d/%Lu.\n",
859                         PFID(ll_inode2fid(inode)), it.d.lustre.it_lock_mode,
860                         it.d.lustre.it_lock_bits);
861                 GOTO(out_close, rc = -EPROTO);
862         }
863
864         ll_intent_release(&it);
865         RETURN(och);
866
867 out_close:
868         /* Cancel open lock */
869         if (it.d.lustre.it_lock_mode != 0) {
870                 ldlm_lock_decref_and_cancel(&och->och_lease_handle,
871                                             it.d.lustre.it_lock_mode);
872                 it.d.lustre.it_lock_mode = 0;
873                 och->och_lease_handle.cookie = 0ULL;
874         }
875         rc2 = ll_close_inode_openhandle(sbi->ll_md_exp, inode, och, NULL);
876         if (rc2 < 0)
877                 CERROR("%s: error closing file "DFID": %d\n",
878                        ll_get_fsname(inode->i_sb, NULL, 0),
879                        PFID(&ll_i2info(inode)->lli_fid), rc2);
880         och = NULL; /* och has been freed in ll_close_inode_openhandle() */
881 out_release_it:
882         ll_intent_release(&it);
883 out:
884         if (och != NULL)
885                 OBD_FREE_PTR(och);
886         RETURN(ERR_PTR(rc));
887 }
888 EXPORT_SYMBOL(ll_lease_open);
889
890 /**
891  * Release lease and close the file.
892  * It will check if the lease has ever broken.
893  */
894 int ll_lease_close(struct obd_client_handle *och, struct inode *inode,
895                         bool *lease_broken)
896 {
897         struct ldlm_lock *lock;
898         bool cancelled = true;
899         int rc;
900         ENTRY;
901
902         lock = ldlm_handle2lock(&och->och_lease_handle);
903         if (lock != NULL) {
904                 lock_res_and_lock(lock);
905                 cancelled = ldlm_is_cancel(lock);
906                 unlock_res_and_lock(lock);
907                 LDLM_LOCK_PUT(lock);
908         }
909
910         CDEBUG(D_INODE, "lease for "DFID" broken? %d\n",
911                 PFID(&ll_i2info(inode)->lli_fid), cancelled);
912
913         if (!cancelled)
914                 ldlm_cli_cancel(&och->och_lease_handle, 0);
915         if (lease_broken != NULL)
916                 *lease_broken = cancelled;
917
918         rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp, inode, och,
919                                        NULL);
920         RETURN(rc);
921 }
922 EXPORT_SYMBOL(ll_lease_close);
923
924 /* Fills the obdo with the attributes for the lsm */
925 static int ll_lsm_getattr(struct lov_stripe_md *lsm, struct obd_export *exp,
926                           struct obd_capa *capa, struct obdo *obdo,
927                           __u64 ioepoch, int dv_flags)
928 {
929         struct ptlrpc_request_set *set;
930         struct obd_info            oinfo = { { { 0 } } };
931         int                        rc;
932
933         ENTRY;
934
935         LASSERT(lsm != NULL);
936
937         oinfo.oi_md = lsm;
938         oinfo.oi_oa = obdo;
939         oinfo.oi_oa->o_oi = lsm->lsm_oi;
940         oinfo.oi_oa->o_mode = S_IFREG;
941         oinfo.oi_oa->o_ioepoch = ioepoch;
942         oinfo.oi_oa->o_valid = OBD_MD_FLID | OBD_MD_FLTYPE |
943                                OBD_MD_FLSIZE | OBD_MD_FLBLOCKS |
944                                OBD_MD_FLBLKSZ | OBD_MD_FLATIME |
945                                OBD_MD_FLMTIME | OBD_MD_FLCTIME |
946                                OBD_MD_FLGROUP | OBD_MD_FLEPOCH |
947                                OBD_MD_FLDATAVERSION;
948         oinfo.oi_capa = capa;
949         if (dv_flags & (LL_DV_WR_FLUSH | LL_DV_RD_FLUSH)) {
950                 oinfo.oi_oa->o_valid |= OBD_MD_FLFLAGS;
951                 oinfo.oi_oa->o_flags |= OBD_FL_SRVLOCK;
952                 if (dv_flags & LL_DV_WR_FLUSH)
953                         oinfo.oi_oa->o_flags |= OBD_FL_FLUSH;
954         }
955
956         set = ptlrpc_prep_set();
957         if (set == NULL) {
958                 CERROR("can't allocate ptlrpc set\n");
959                 rc = -ENOMEM;
960         } else {
961                 rc = obd_getattr_async(exp, &oinfo, set);
962                 if (rc == 0)
963                         rc = ptlrpc_set_wait(set);
964                 ptlrpc_set_destroy(set);
965         }
966         if (rc == 0) {
967                 oinfo.oi_oa->o_valid &= (OBD_MD_FLBLOCKS | OBD_MD_FLBLKSZ |
968                                          OBD_MD_FLATIME | OBD_MD_FLMTIME |
969                                          OBD_MD_FLCTIME | OBD_MD_FLSIZE |
970                                          OBD_MD_FLDATAVERSION | OBD_MD_FLFLAGS);
971                 if (dv_flags & LL_DV_WR_FLUSH &&
972                     !(oinfo.oi_oa->o_valid & OBD_MD_FLFLAGS &&
973                       oinfo.oi_oa->o_flags & OBD_FL_FLUSH))
974                         RETURN(-ENOTSUPP);
975         }
976         RETURN(rc);
977 }
978
979 /**
980   * Performs the getattr on the inode and updates its fields.
981   * If @sync != 0, perform the getattr under the server-side lock.
982   */
983 int ll_inode_getattr(struct inode *inode, struct obdo *obdo,
984                      __u64 ioepoch, int sync)
985 {
986         struct obd_capa      *capa = ll_mdscapa_get(inode);
987         struct lov_stripe_md *lsm;
988         int rc;
989         ENTRY;
990
991         lsm = ccc_inode_lsm_get(inode);
992         rc = ll_lsm_getattr(lsm, ll_i2dtexp(inode),
993                                 capa, obdo, ioepoch, sync ? LL_DV_RD_FLUSH : 0);
994         capa_put(capa);
995         if (rc == 0) {
996                 struct ost_id *oi = lsm ? &lsm->lsm_oi : &obdo->o_oi;
997
998                 obdo_refresh_inode(inode, obdo, obdo->o_valid);
999                 CDEBUG(D_INODE, "objid "DOSTID" size %llu, blocks %llu,"
1000                        " blksize %lu\n", POSTID(oi), i_size_read(inode),
1001                        (unsigned long long)inode->i_blocks,
1002                        (unsigned long)ll_inode_blksize(inode));
1003         }
1004         ccc_inode_lsm_put(inode, lsm);
1005         RETURN(rc);
1006 }
1007
1008 int ll_merge_lvb(const struct lu_env *env, struct inode *inode)
1009 {
1010         struct ll_inode_info *lli = ll_i2info(inode);
1011         struct cl_object *obj = lli->lli_clob;
1012         struct cl_attr *attr = ccc_env_thread_attr(env);
1013         struct ost_lvb lvb;
1014         int rc = 0;
1015
1016         ENTRY;
1017
1018         ll_inode_size_lock(inode);
1019         /* merge timestamps the most recently obtained from mds with
1020            timestamps obtained from osts */
1021         LTIME_S(inode->i_atime) = lli->lli_lvb.lvb_atime;
1022         LTIME_S(inode->i_mtime) = lli->lli_lvb.lvb_mtime;
1023         LTIME_S(inode->i_ctime) = lli->lli_lvb.lvb_ctime;
1024         inode_init_lvb(inode, &lvb);
1025
1026         cl_object_attr_lock(obj);
1027         rc = cl_object_attr_get(env, obj, attr);
1028         cl_object_attr_unlock(obj);
1029
1030         if (rc == 0) {
1031                 if (lvb.lvb_atime < attr->cat_atime)
1032                         lvb.lvb_atime = attr->cat_atime;
1033                 if (lvb.lvb_ctime < attr->cat_ctime)
1034                         lvb.lvb_ctime = attr->cat_ctime;
1035                 if (lvb.lvb_mtime < attr->cat_mtime)
1036                         lvb.lvb_mtime = attr->cat_mtime;
1037
1038                 CDEBUG(D_VFSTRACE, DFID" updating i_size "LPU64"\n",
1039                                 PFID(&lli->lli_fid), attr->cat_size);
1040                 cl_isize_write_nolock(inode, attr->cat_size);
1041
1042                 inode->i_blocks = attr->cat_blocks;
1043
1044                 LTIME_S(inode->i_mtime) = lvb.lvb_mtime;
1045                 LTIME_S(inode->i_atime) = lvb.lvb_atime;
1046                 LTIME_S(inode->i_ctime) = lvb.lvb_ctime;
1047         }
1048         ll_inode_size_unlock(inode);
1049
1050         RETURN(rc);
1051 }
1052
1053 int ll_glimpse_ioctl(struct ll_sb_info *sbi, struct lov_stripe_md *lsm,
1054                      lstat_t *st)
1055 {
1056         struct obdo obdo = { 0 };
1057         int rc;
1058
1059         rc = ll_lsm_getattr(lsm, sbi->ll_dt_exp, NULL, &obdo, 0, 0);
1060         if (rc == 0) {
1061                 st->st_size   = obdo.o_size;
1062                 st->st_blocks = obdo.o_blocks;
1063                 st->st_mtime  = obdo.o_mtime;
1064                 st->st_atime  = obdo.o_atime;
1065                 st->st_ctime  = obdo.o_ctime;
1066         }
1067         return rc;
1068 }
1069
1070 static bool file_is_noatime(const struct file *file)
1071 {
1072         const struct vfsmount *mnt = file->f_path.mnt;
1073         const struct inode *inode = file->f_path.dentry->d_inode;
1074
1075         /* Adapted from file_accessed() and touch_atime().*/
1076         if (file->f_flags & O_NOATIME)
1077                 return true;
1078
1079         if (inode->i_flags & S_NOATIME)
1080                 return true;
1081
1082         if (IS_NOATIME(inode))
1083                 return true;
1084
1085         if (mnt->mnt_flags & (MNT_NOATIME | MNT_READONLY))
1086                 return true;
1087
1088         if ((mnt->mnt_flags & MNT_NODIRATIME) && S_ISDIR(inode->i_mode))
1089                 return true;
1090
1091         if ((inode->i_sb->s_flags & MS_NODIRATIME) && S_ISDIR(inode->i_mode))
1092                 return true;
1093
1094         return false;
1095 }
1096
1097 void ll_io_init(struct cl_io *io, const struct file *file, int write)
1098 {
1099         struct inode *inode = file->f_dentry->d_inode;
1100
1101         io->u.ci_rw.crw_nonblock = file->f_flags & O_NONBLOCK;
1102         if (write) {
1103                 io->u.ci_wr.wr_append = !!(file->f_flags & O_APPEND);
1104                 io->u.ci_wr.wr_sync = file->f_flags & O_SYNC ||
1105                                       file->f_flags & O_DIRECT ||
1106                                       IS_SYNC(inode);
1107         }
1108         io->ci_obj     = ll_i2info(inode)->lli_clob;
1109         io->ci_lockreq = CILR_MAYBE;
1110         if (ll_file_nolock(file)) {
1111                 io->ci_lockreq = CILR_NEVER;
1112                 io->ci_no_srvlock = 1;
1113         } else if (file->f_flags & O_APPEND) {
1114                 io->ci_lockreq = CILR_MANDATORY;
1115         }
1116
1117         io->ci_noatime = file_is_noatime(file);
1118 }
1119
1120 static ssize_t
1121 ll_file_io_generic(const struct lu_env *env, struct vvp_io_args *args,
1122                    struct file *file, enum cl_io_type iot,
1123                    loff_t *ppos, size_t count)
1124 {
1125         struct ll_inode_info *lli = ll_i2info(file->f_dentry->d_inode);
1126         struct ll_file_data  *fd  = LUSTRE_FPRIVATE(file);
1127         struct cl_io         *io;
1128         ssize_t               result;
1129         ENTRY;
1130
1131 restart:
1132         io = ccc_env_thread_io(env);
1133         ll_io_init(io, file, iot == CIT_WRITE);
1134
1135         if (cl_io_rw_init(env, io, iot, *ppos, count) == 0) {
1136                 struct vvp_io *vio = vvp_env_io(env);
1137                 struct ccc_io *cio = ccc_env_io(env);
1138                 int write_mutex_locked = 0;
1139
1140                 cio->cui_fd  = LUSTRE_FPRIVATE(file);
1141                 vio->cui_io_subtype = args->via_io_subtype;
1142
1143                 switch (vio->cui_io_subtype) {
1144                 case IO_NORMAL:
1145                         cio->cui_iov = args->u.normal.via_iov;
1146                         cio->cui_nrsegs = args->u.normal.via_nrsegs;
1147                         cio->cui_tot_nrsegs = cio->cui_nrsegs;
1148                         cio->cui_iocb = args->u.normal.via_iocb;
1149                         if ((iot == CIT_WRITE) &&
1150                             !(cio->cui_fd->fd_flags & LL_FILE_GROUP_LOCKED)) {
1151                                 if (mutex_lock_interruptible(&lli->
1152                                                                lli_write_mutex))
1153                                         GOTO(out, result = -ERESTARTSYS);
1154                                 write_mutex_locked = 1;
1155                         } else if (iot == CIT_READ) {
1156                                 down_read(&lli->lli_trunc_sem);
1157                         }
1158                         break;
1159                 case IO_SENDFILE:
1160                         vio->u.sendfile.cui_actor = args->u.sendfile.via_actor;
1161                         vio->u.sendfile.cui_target = args->u.sendfile.via_target;
1162                         break;
1163                 case IO_SPLICE:
1164                         vio->u.splice.cui_pipe = args->u.splice.via_pipe;
1165                         vio->u.splice.cui_flags = args->u.splice.via_flags;
1166                         break;
1167                 default:
1168                         CERROR("Unknow IO type - %u\n", vio->cui_io_subtype);
1169                         LBUG();
1170                 }
1171                 result = cl_io_loop(env, io);
1172                 if (write_mutex_locked)
1173                         mutex_unlock(&lli->lli_write_mutex);
1174                 else if (args->via_io_subtype == IO_NORMAL && iot == CIT_READ)
1175                         up_read(&lli->lli_trunc_sem);
1176         } else {
1177                 /* cl_io_rw_init() handled IO */
1178                 result = io->ci_result;
1179         }
1180
1181         if (io->ci_nob > 0) {
1182                 result = io->ci_nob;
1183                 *ppos = io->u.ci_wr.wr.crw_pos;
1184         }
1185         GOTO(out, result);
1186 out:
1187         cl_io_fini(env, io);
1188         /* If any bit been read/written (result != 0), we just return
1189          * short read/write instead of restart io. */
1190         if ((result == 0 || result == -ENODATA) && io->ci_need_restart) {
1191                 CDEBUG(D_VFSTRACE, "Restart %s on %s from %lld, count:%zd\n",
1192                        iot == CIT_READ ? "read" : "write",
1193                        file->f_dentry->d_name.name, *ppos, count);
1194                 LASSERTF(io->ci_nob == 0, "%zd", io->ci_nob);
1195                 goto restart;
1196         }
1197
1198         if (iot == CIT_READ) {
1199                 if (result >= 0)
1200                         ll_stats_ops_tally(ll_i2sbi(file->f_dentry->d_inode),
1201                                            LPROC_LL_READ_BYTES, result);
1202         } else if (iot == CIT_WRITE) {
1203                 if (result >= 0) {
1204                         ll_stats_ops_tally(ll_i2sbi(file->f_dentry->d_inode),
1205                                            LPROC_LL_WRITE_BYTES, result);
1206                         fd->fd_write_failed = false;
1207                 } else if (result != -ERESTARTSYS) {
1208                         fd->fd_write_failed = true;
1209                 }
1210         }
1211
1212         return result;
1213 }
1214
1215
1216 /*
1217  * XXX: exact copy from kernel code (__generic_file_aio_write_nolock)
1218  */
1219 static int ll_file_get_iov_count(const struct iovec *iov,
1220                                  unsigned long *nr_segs, size_t *count)
1221 {
1222         size_t cnt = 0;
1223         unsigned long seg;
1224
1225         for (seg = 0; seg < *nr_segs; seg++) {
1226                 const struct iovec *iv = &iov[seg];
1227
1228                 /*
1229                  * If any segment has a negative length, or the cumulative
1230                  * length ever wraps negative then return -EINVAL.
1231                  */
1232                 cnt += iv->iov_len;
1233                 if (unlikely((ssize_t)(cnt|iv->iov_len) < 0))
1234                         return -EINVAL;
1235                 if (access_ok(VERIFY_READ, iv->iov_base, iv->iov_len))
1236                         continue;
1237                 if (seg == 0)
1238                         return -EFAULT;
1239                 *nr_segs = seg;
1240                 cnt -= iv->iov_len;   /* This segment is no good */
1241                 break;
1242         }
1243         *count = cnt;
1244         return 0;
1245 }
1246
1247 static ssize_t ll_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
1248                                 unsigned long nr_segs, loff_t pos)
1249 {
1250         struct lu_env      *env;
1251         struct vvp_io_args *args;
1252         size_t              count;
1253         ssize_t             result;
1254         int                 refcheck;
1255         ENTRY;
1256
1257         result = ll_file_get_iov_count(iov, &nr_segs, &count);
1258         if (result)
1259                 RETURN(result);
1260
1261         env = cl_env_get(&refcheck);
1262         if (IS_ERR(env))
1263                 RETURN(PTR_ERR(env));
1264
1265         args = vvp_env_args(env, IO_NORMAL);
1266         args->u.normal.via_iov = (struct iovec *)iov;
1267         args->u.normal.via_nrsegs = nr_segs;
1268         args->u.normal.via_iocb = iocb;
1269
1270         result = ll_file_io_generic(env, args, iocb->ki_filp, CIT_READ,
1271                                     &iocb->ki_pos, count);
1272         cl_env_put(env, &refcheck);
1273         RETURN(result);
1274 }
1275
1276 static ssize_t ll_file_read(struct file *file, char *buf, size_t count,
1277                             loff_t *ppos)
1278 {
1279         struct lu_env *env;
1280         struct iovec  *local_iov;
1281         struct kiocb  *kiocb;
1282         ssize_t        result;
1283         int            refcheck;
1284         ENTRY;
1285
1286         env = cl_env_get(&refcheck);
1287         if (IS_ERR(env))
1288                 RETURN(PTR_ERR(env));
1289
1290         local_iov = &vvp_env_info(env)->vti_local_iov;
1291         kiocb = &vvp_env_info(env)->vti_kiocb;
1292         local_iov->iov_base = (void __user *)buf;
1293         local_iov->iov_len = count;
1294         init_sync_kiocb(kiocb, file);
1295         kiocb->ki_pos = *ppos;
1296         kiocb->ki_left = count;
1297
1298         result = ll_file_aio_read(kiocb, local_iov, 1, kiocb->ki_pos);
1299         *ppos = kiocb->ki_pos;
1300
1301         cl_env_put(env, &refcheck);
1302         RETURN(result);
1303 }
1304
1305 /*
1306  * Write to a file (through the page cache).
1307  * AIO stuff
1308  */
1309 static ssize_t ll_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
1310                                  unsigned long nr_segs, loff_t pos)
1311 {
1312         struct lu_env      *env;
1313         struct vvp_io_args *args;
1314         size_t              count;
1315         ssize_t             result;
1316         int                 refcheck;
1317         ENTRY;
1318
1319         result = ll_file_get_iov_count(iov, &nr_segs, &count);
1320         if (result)
1321                 RETURN(result);
1322
1323         env = cl_env_get(&refcheck);
1324         if (IS_ERR(env))
1325                 RETURN(PTR_ERR(env));
1326
1327         args = vvp_env_args(env, IO_NORMAL);
1328         args->u.normal.via_iov = (struct iovec *)iov;
1329         args->u.normal.via_nrsegs = nr_segs;
1330         args->u.normal.via_iocb = iocb;
1331
1332         result = ll_file_io_generic(env, args, iocb->ki_filp, CIT_WRITE,
1333                                   &iocb->ki_pos, count);
1334         cl_env_put(env, &refcheck);
1335         RETURN(result);
1336 }
1337
1338 static ssize_t ll_file_write(struct file *file, const char *buf, size_t count,
1339                              loff_t *ppos)
1340 {
1341         struct lu_env *env;
1342         struct iovec  *local_iov;
1343         struct kiocb  *kiocb;
1344         ssize_t        result;
1345         int            refcheck;
1346         ENTRY;
1347
1348         env = cl_env_get(&refcheck);
1349         if (IS_ERR(env))
1350                 RETURN(PTR_ERR(env));
1351
1352         local_iov = &vvp_env_info(env)->vti_local_iov;
1353         kiocb = &vvp_env_info(env)->vti_kiocb;
1354         local_iov->iov_base = (void __user *)buf;
1355         local_iov->iov_len = count;
1356         init_sync_kiocb(kiocb, file);
1357         kiocb->ki_pos = *ppos;
1358         kiocb->ki_left = count;
1359
1360         result = ll_file_aio_write(kiocb, local_iov, 1, kiocb->ki_pos);
1361         *ppos = kiocb->ki_pos;
1362
1363         cl_env_put(env, &refcheck);
1364         RETURN(result);
1365 }
1366
1367 /*
1368  * Send file content (through pagecache) somewhere with helper
1369  */
1370 static ssize_t ll_file_splice_read(struct file *in_file, loff_t *ppos,
1371                                    struct pipe_inode_info *pipe, size_t count,
1372                                    unsigned int flags)
1373 {
1374         struct lu_env      *env;
1375         struct vvp_io_args *args;
1376         ssize_t             result;
1377         int                 refcheck;
1378         ENTRY;
1379
1380         env = cl_env_get(&refcheck);
1381         if (IS_ERR(env))
1382                 RETURN(PTR_ERR(env));
1383
1384         args = vvp_env_args(env, IO_SPLICE);
1385         args->u.splice.via_pipe = pipe;
1386         args->u.splice.via_flags = flags;
1387
1388         result = ll_file_io_generic(env, args, in_file, CIT_READ, ppos, count);
1389         cl_env_put(env, &refcheck);
1390         RETURN(result);
1391 }
1392
1393 static int ll_lov_recreate(struct inode *inode, struct ost_id *oi,
1394                            obd_count ost_idx)
1395 {
1396         struct obd_export *exp = ll_i2dtexp(inode);
1397         struct obd_trans_info oti = { 0 };
1398         struct obdo *oa = NULL;
1399         int lsm_size;
1400         int rc = 0;
1401         struct lov_stripe_md *lsm = NULL, *lsm2;
1402         ENTRY;
1403
1404         OBDO_ALLOC(oa);
1405         if (oa == NULL)
1406                 RETURN(-ENOMEM);
1407
1408         lsm = ccc_inode_lsm_get(inode);
1409         if (!lsm_has_objects(lsm))
1410                 GOTO(out, rc = -ENOENT);
1411
1412         lsm_size = sizeof(*lsm) + (sizeof(struct lov_oinfo) *
1413                    (lsm->lsm_stripe_count));
1414
1415         OBD_ALLOC_LARGE(lsm2, lsm_size);
1416         if (lsm2 == NULL)
1417                 GOTO(out, rc = -ENOMEM);
1418
1419         oa->o_oi = *oi;
1420         oa->o_nlink = ost_idx;
1421         oa->o_flags |= OBD_FL_RECREATE_OBJS;
1422         oa->o_valid = OBD_MD_FLID | OBD_MD_FLFLAGS | OBD_MD_FLGROUP;
1423         obdo_from_inode(oa, inode, OBD_MD_FLTYPE | OBD_MD_FLATIME |
1424                                    OBD_MD_FLMTIME | OBD_MD_FLCTIME);
1425         obdo_set_parent_fid(oa, &ll_i2info(inode)->lli_fid);
1426         memcpy(lsm2, lsm, lsm_size);
1427         ll_inode_size_lock(inode);
1428         rc = obd_create(NULL, exp, oa, &lsm2, &oti);
1429         ll_inode_size_unlock(inode);
1430
1431         OBD_FREE_LARGE(lsm2, lsm_size);
1432         GOTO(out, rc);
1433 out:
1434         ccc_inode_lsm_put(inode, lsm);
1435         OBDO_FREE(oa);
1436         return rc;
1437 }
1438
1439 static int ll_lov_recreate_obj(struct inode *inode, unsigned long arg)
1440 {
1441         struct ll_recreate_obj ucreat;
1442         struct ost_id           oi;
1443         ENTRY;
1444
1445         if (!cfs_capable(CFS_CAP_SYS_ADMIN))
1446                 RETURN(-EPERM);
1447
1448         if (copy_from_user(&ucreat, (struct ll_recreate_obj *)arg,
1449                            sizeof(ucreat)))
1450                 RETURN(-EFAULT);
1451
1452         ostid_set_seq_mdt0(&oi);
1453         ostid_set_id(&oi, ucreat.lrc_id);
1454         RETURN(ll_lov_recreate(inode, &oi, ucreat.lrc_ost_idx));
1455 }
1456
1457 static int ll_lov_recreate_fid(struct inode *inode, unsigned long arg)
1458 {
1459         struct lu_fid   fid;
1460         struct ost_id   oi;
1461         obd_count       ost_idx;
1462         ENTRY;
1463
1464         if (!cfs_capable(CFS_CAP_SYS_ADMIN))
1465                 RETURN(-EPERM);
1466
1467         if (copy_from_user(&fid, (struct lu_fid *)arg, sizeof(fid)))
1468                 RETURN(-EFAULT);
1469
1470         fid_to_ostid(&fid, &oi);
1471         ost_idx = (fid_seq(&fid) >> 16) & 0xffff;
1472         RETURN(ll_lov_recreate(inode, &oi, ost_idx));
1473 }
1474
1475 int ll_lov_setstripe_ea_info(struct inode *inode, struct file *file,
1476                              __u64  flags, struct lov_user_md *lum,
1477                              int lum_size)
1478 {
1479         struct lov_stripe_md *lsm = NULL;
1480         struct lookup_intent oit = {.it_op = IT_OPEN, .it_flags = flags};
1481         int rc = 0;
1482         ENTRY;
1483
1484         lsm = ccc_inode_lsm_get(inode);
1485         if (lsm != NULL) {
1486                 ccc_inode_lsm_put(inode, lsm);
1487                 CDEBUG(D_IOCTL, "stripe already exists for ino %lu\n",
1488                        inode->i_ino);
1489                 RETURN(-EEXIST);
1490         }
1491
1492         ll_inode_size_lock(inode);
1493         rc = ll_intent_file_open(file, lum, lum_size, &oit);
1494         if (rc)
1495                 GOTO(out, rc);
1496         rc = oit.d.lustre.it_status;
1497         if (rc < 0)
1498                 GOTO(out_req_free, rc);
1499
1500         ll_release_openhandle(file->f_dentry, &oit);
1501
1502  out:
1503         ll_inode_size_unlock(inode);
1504         ll_intent_release(&oit);
1505         ccc_inode_lsm_put(inode, lsm);
1506         RETURN(rc);
1507 out_req_free:
1508         ptlrpc_req_finished((struct ptlrpc_request *) oit.d.lustre.it_data);
1509         goto out;
1510 }
1511
1512 int ll_lov_getstripe_ea_info(struct inode *inode, const char *filename,
1513                              struct lov_mds_md **lmmp, int *lmm_size,
1514                              struct ptlrpc_request **request)
1515 {
1516         struct ll_sb_info *sbi = ll_i2sbi(inode);
1517         struct mdt_body  *body;
1518         struct lov_mds_md *lmm = NULL;
1519         struct ptlrpc_request *req = NULL;
1520         struct md_op_data *op_data;
1521         int rc, lmmsize;
1522
1523         rc = ll_get_max_mdsize(sbi, &lmmsize);
1524         if (rc)
1525                 RETURN(rc);
1526
1527         op_data = ll_prep_md_op_data(NULL, inode, NULL, filename,
1528                                      strlen(filename), lmmsize,
1529                                      LUSTRE_OPC_ANY, NULL);
1530         if (IS_ERR(op_data))
1531                 RETURN(PTR_ERR(op_data));
1532
1533         op_data->op_valid = OBD_MD_FLEASIZE | OBD_MD_FLDIREA;
1534         rc = md_getattr_name(sbi->ll_md_exp, op_data, &req);
1535         ll_finish_md_op_data(op_data);
1536         if (rc < 0) {
1537                 CDEBUG(D_INFO, "md_getattr_name failed "
1538                        "on %s: rc %d\n", filename, rc);
1539                 GOTO(out, rc);
1540         }
1541
1542         body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
1543         LASSERT(body != NULL); /* checked by mdc_getattr_name */
1544
1545         lmmsize = body->eadatasize;
1546
1547         if (!(body->valid & (OBD_MD_FLEASIZE | OBD_MD_FLDIREA)) ||
1548                         lmmsize == 0) {
1549                 GOTO(out, rc = -ENODATA);
1550         }
1551
1552         lmm = req_capsule_server_sized_get(&req->rq_pill, &RMF_MDT_MD, lmmsize);
1553         LASSERT(lmm != NULL);
1554
1555         if ((lmm->lmm_magic != cpu_to_le32(LOV_MAGIC_V1)) &&
1556             (lmm->lmm_magic != cpu_to_le32(LOV_MAGIC_V3))) {
1557                 GOTO(out, rc = -EPROTO);
1558         }
1559
1560         /*
1561          * This is coming from the MDS, so is probably in
1562          * little endian.  We convert it to host endian before
1563          * passing it to userspace.
1564          */
1565         if (LOV_MAGIC != cpu_to_le32(LOV_MAGIC)) {
1566                 int stripe_count;
1567
1568                 stripe_count = le16_to_cpu(lmm->lmm_stripe_count);
1569                 if (le32_to_cpu(lmm->lmm_pattern) & LOV_PATTERN_F_RELEASED)
1570                         stripe_count = 0;
1571
1572                 /* if function called for directory - we should
1573                  * avoid swab not existent lsm objects */
1574                 if (lmm->lmm_magic == cpu_to_le32(LOV_MAGIC_V1)) {
1575                         lustre_swab_lov_user_md_v1((struct lov_user_md_v1 *)lmm);
1576                         if (S_ISREG(body->mode))
1577                                 lustre_swab_lov_user_md_objects(
1578                                  ((struct lov_user_md_v1 *)lmm)->lmm_objects,
1579                                  stripe_count);
1580                 } else if (lmm->lmm_magic == cpu_to_le32(LOV_MAGIC_V3)) {
1581                         lustre_swab_lov_user_md_v3((struct lov_user_md_v3 *)lmm);
1582                         if (S_ISREG(body->mode))
1583                                 lustre_swab_lov_user_md_objects(
1584                                  ((struct lov_user_md_v3 *)lmm)->lmm_objects,
1585                                  stripe_count);
1586                 }
1587         }
1588
1589 out:
1590         *lmmp = lmm;
1591         *lmm_size = lmmsize;
1592         *request = req;
1593         return rc;
1594 }
1595
1596 static int ll_lov_setea(struct inode *inode, struct file *file,
1597                             unsigned long arg)
1598 {
1599         __u64                    flags = MDS_OPEN_HAS_OBJS | FMODE_WRITE;
1600         struct lov_user_md      *lump;
1601         int                      lum_size = sizeof(struct lov_user_md) +
1602                                             sizeof(struct lov_user_ost_data);
1603         int                      rc;
1604         ENTRY;
1605
1606         if (!cfs_capable(CFS_CAP_SYS_ADMIN))
1607                 RETURN(-EPERM);
1608
1609         OBD_ALLOC_LARGE(lump, lum_size);
1610         if (lump == NULL)
1611                 RETURN(-ENOMEM);
1612
1613         if (copy_from_user(lump, (struct lov_user_md  *)arg, lum_size)) {
1614                 OBD_FREE_LARGE(lump, lum_size);
1615                 RETURN(-EFAULT);
1616         }
1617
1618         rc = ll_lov_setstripe_ea_info(inode, file, flags, lump, lum_size);
1619
1620         OBD_FREE_LARGE(lump, lum_size);
1621         RETURN(rc);
1622 }
1623
1624 static int ll_lov_setstripe(struct inode *inode, struct file *file,
1625                             unsigned long arg)
1626 {
1627         struct lov_user_md_v3    lumv3;
1628         struct lov_user_md_v1   *lumv1 = (struct lov_user_md_v1 *)&lumv3;
1629         struct lov_user_md_v1   *lumv1p = (struct lov_user_md_v1 *)arg;
1630         struct lov_user_md_v3   *lumv3p = (struct lov_user_md_v3 *)arg;
1631         int                      lum_size, rc;
1632         __u64                    flags = FMODE_WRITE;
1633         ENTRY;
1634
1635         /* first try with v1 which is smaller than v3 */
1636         lum_size = sizeof(struct lov_user_md_v1);
1637         if (copy_from_user(lumv1, lumv1p, lum_size))
1638                 RETURN(-EFAULT);
1639
1640         if (lumv1->lmm_magic == LOV_USER_MAGIC_V3) {
1641                 lum_size = sizeof(struct lov_user_md_v3);
1642                 if (copy_from_user(&lumv3, lumv3p, lum_size))
1643                         RETURN(-EFAULT);
1644         }
1645
1646         rc = ll_lov_setstripe_ea_info(inode, file, flags, lumv1, lum_size);
1647         if (rc == 0) {
1648                 struct lov_stripe_md *lsm;
1649                 __u32 gen;
1650
1651                 put_user(0, &lumv1p->lmm_stripe_count);
1652
1653                 ll_layout_refresh(inode, &gen);
1654                 lsm = ccc_inode_lsm_get(inode);
1655                 rc = obd_iocontrol(LL_IOC_LOV_GETSTRIPE, ll_i2dtexp(inode),
1656                                    0, lsm, (void *)arg);
1657                 ccc_inode_lsm_put(inode, lsm);
1658         }
1659         RETURN(rc);
1660 }
1661
1662 static int ll_lov_getstripe(struct inode *inode, unsigned long arg)
1663 {
1664         struct lov_stripe_md *lsm;
1665         int rc = -ENODATA;
1666         ENTRY;
1667
1668         lsm = ccc_inode_lsm_get(inode);
1669         if (lsm != NULL)
1670                 rc = obd_iocontrol(LL_IOC_LOV_GETSTRIPE, ll_i2dtexp(inode), 0,
1671                                    lsm, (void *)arg);
1672         ccc_inode_lsm_put(inode, lsm);
1673         RETURN(rc);
1674 }
1675
1676 int ll_get_grouplock(struct inode *inode, struct file *file, unsigned long arg)
1677 {
1678         struct ll_inode_info   *lli = ll_i2info(inode);
1679         struct ll_file_data    *fd = LUSTRE_FPRIVATE(file);
1680         struct ccc_grouplock    grouplock;
1681         int                     rc;
1682         ENTRY;
1683
1684         if (ll_file_nolock(file))
1685                 RETURN(-EOPNOTSUPP);
1686
1687         spin_lock(&lli->lli_lock);
1688         if (fd->fd_flags & LL_FILE_GROUP_LOCKED) {
1689                 CWARN("group lock already existed with gid %lu\n",
1690                       fd->fd_grouplock.cg_gid);
1691                 spin_unlock(&lli->lli_lock);
1692                 RETURN(-EINVAL);
1693         }
1694         LASSERT(fd->fd_grouplock.cg_lock == NULL);
1695         spin_unlock(&lli->lli_lock);
1696
1697         rc = cl_get_grouplock(cl_i2info(inode)->lli_clob,
1698                               arg, (file->f_flags & O_NONBLOCK), &grouplock);
1699         if (rc)
1700                 RETURN(rc);
1701
1702         spin_lock(&lli->lli_lock);
1703         if (fd->fd_flags & LL_FILE_GROUP_LOCKED) {
1704                 spin_unlock(&lli->lli_lock);
1705                 CERROR("another thread just won the race\n");
1706                 cl_put_grouplock(&grouplock);
1707                 RETURN(-EINVAL);
1708         }
1709
1710         fd->fd_flags |= LL_FILE_GROUP_LOCKED;
1711         fd->fd_grouplock = grouplock;
1712         spin_unlock(&lli->lli_lock);
1713
1714         CDEBUG(D_INFO, "group lock %lu obtained\n", arg);
1715         RETURN(0);
1716 }
1717
1718 int ll_put_grouplock(struct inode *inode, struct file *file, unsigned long arg)
1719 {
1720         struct ll_inode_info   *lli = ll_i2info(inode);
1721         struct ll_file_data    *fd = LUSTRE_FPRIVATE(file);
1722         struct ccc_grouplock    grouplock;
1723         ENTRY;
1724
1725         spin_lock(&lli->lli_lock);
1726         if (!(fd->fd_flags & LL_FILE_GROUP_LOCKED)) {
1727                 spin_unlock(&lli->lli_lock);
1728                 CWARN("no group lock held\n");
1729                 RETURN(-EINVAL);
1730         }
1731         LASSERT(fd->fd_grouplock.cg_lock != NULL);
1732
1733         if (fd->fd_grouplock.cg_gid != arg) {
1734                 CWARN("group lock %lu doesn't match current id %lu\n",
1735                        arg, fd->fd_grouplock.cg_gid);
1736                 spin_unlock(&lli->lli_lock);
1737                 RETURN(-EINVAL);
1738         }
1739
1740         grouplock = fd->fd_grouplock;
1741         memset(&fd->fd_grouplock, 0, sizeof(fd->fd_grouplock));
1742         fd->fd_flags &= ~LL_FILE_GROUP_LOCKED;
1743         spin_unlock(&lli->lli_lock);
1744
1745         cl_put_grouplock(&grouplock);
1746         CDEBUG(D_INFO, "group lock %lu released\n", arg);
1747         RETURN(0);
1748 }
1749
1750 /**
1751  * Close inode open handle
1752  *
1753  * \param dentry [in]     dentry which contains the inode
1754  * \param it     [in,out] intent which contains open info and result
1755  *
1756  * \retval 0     success
1757  * \retval <0    failure
1758  */
1759 int ll_release_openhandle(struct dentry *dentry, struct lookup_intent *it)
1760 {
1761         struct inode *inode = dentry->d_inode;
1762         struct obd_client_handle *och;
1763         int rc;
1764         ENTRY;
1765
1766         LASSERT(inode);
1767
1768         /* Root ? Do nothing. */
1769         if (dentry->d_inode->i_sb->s_root == dentry)
1770                 RETURN(0);
1771
1772         /* No open handle to close? Move away */
1773         if (!it_disposition(it, DISP_OPEN_OPEN))
1774                 RETURN(0);
1775
1776         LASSERT(it_open_error(DISP_OPEN_OPEN, it) == 0);
1777
1778         OBD_ALLOC(och, sizeof(*och));
1779         if (!och)
1780                 GOTO(out, rc = -ENOMEM);
1781
1782         ll_och_fill(ll_i2sbi(inode)->ll_md_exp, it, och);
1783
1784         rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp,
1785                                        inode, och, NULL);
1786 out:
1787         /* this one is in place of ll_file_open */
1788         if (it_disposition(it, DISP_ENQ_OPEN_REF)) {
1789                 ptlrpc_req_finished(it->d.lustre.it_data);
1790                 it_clear_disposition(it, DISP_ENQ_OPEN_REF);
1791         }
1792         RETURN(rc);
1793 }
1794
1795 /**
1796  * Get size for inode for which FIEMAP mapping is requested.
1797  * Make the FIEMAP get_info call and returns the result.
1798  */
1799 int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap,
1800               int num_bytes)
1801 {
1802         struct obd_export *exp = ll_i2dtexp(inode);
1803         struct lov_stripe_md *lsm = NULL;
1804         struct ll_fiemap_info_key fm_key = { .name = KEY_FIEMAP, };
1805         int vallen = num_bytes;
1806         int rc;
1807         ENTRY;
1808
1809         /* Checks for fiemap flags */
1810         if (fiemap->fm_flags & ~LUSTRE_FIEMAP_FLAGS_COMPAT) {
1811                 fiemap->fm_flags &= ~LUSTRE_FIEMAP_FLAGS_COMPAT;
1812                 return -EBADR;
1813         }
1814
1815         /* Check for FIEMAP_FLAG_SYNC */
1816         if (fiemap->fm_flags & FIEMAP_FLAG_SYNC) {
1817                 rc = filemap_fdatawrite(inode->i_mapping);
1818                 if (rc)
1819                         return rc;
1820         }
1821
1822         lsm = ccc_inode_lsm_get(inode);
1823         if (lsm == NULL)
1824                 return -ENOENT;
1825
1826         /* If the stripe_count > 1 and the application does not understand
1827          * DEVICE_ORDER flag, then it cannot interpret the extents correctly.
1828          */
1829         if (lsm->lsm_stripe_count > 1 &&
1830             !(fiemap->fm_flags & FIEMAP_FLAG_DEVICE_ORDER))
1831                 GOTO(out, rc = -EOPNOTSUPP);
1832
1833         fm_key.oa.o_oi = lsm->lsm_oi;
1834         fm_key.oa.o_valid = OBD_MD_FLID | OBD_MD_FLGROUP;
1835
1836         obdo_from_inode(&fm_key.oa, inode, OBD_MD_FLSIZE);
1837         obdo_set_parent_fid(&fm_key.oa, &ll_i2info(inode)->lli_fid);
1838         /* If filesize is 0, then there would be no objects for mapping */
1839         if (fm_key.oa.o_size == 0) {
1840                 fiemap->fm_mapped_extents = 0;
1841                 GOTO(out, rc = 0);
1842         }
1843
1844         memcpy(&fm_key.fiemap, fiemap, sizeof(*fiemap));
1845
1846         rc = obd_get_info(NULL, exp, sizeof(fm_key), &fm_key, &vallen,
1847                           fiemap, lsm);
1848         if (rc)
1849                 CERROR("obd_get_info failed: rc = %d\n", rc);
1850
1851 out:
1852         ccc_inode_lsm_put(inode, lsm);
1853         RETURN(rc);
1854 }
1855
1856 int ll_fid2path(struct inode *inode, void *arg)
1857 {
1858         struct obd_export       *exp = ll_i2mdexp(inode);
1859         struct getinfo_fid2path *gfout, *gfin;
1860         int                      outsize, rc;
1861         ENTRY;
1862
1863         if (!cfs_capable(CFS_CAP_DAC_READ_SEARCH) &&
1864             !(ll_i2sbi(inode)->ll_flags & LL_SBI_USER_FID2PATH))
1865                 RETURN(-EPERM);
1866
1867         /* Need to get the buflen */
1868         OBD_ALLOC_PTR(gfin);
1869         if (gfin == NULL)
1870                 RETURN(-ENOMEM);
1871         if (copy_from_user(gfin, arg, sizeof(*gfin))) {
1872                 OBD_FREE_PTR(gfin);
1873                 RETURN(-EFAULT);
1874         }
1875
1876         outsize = sizeof(*gfout) + gfin->gf_pathlen;
1877         OBD_ALLOC(gfout, outsize);
1878         if (gfout == NULL) {
1879                 OBD_FREE_PTR(gfin);
1880                 RETURN(-ENOMEM);
1881         }
1882         memcpy(gfout, gfin, sizeof(*gfout));
1883         OBD_FREE_PTR(gfin);
1884
1885         /* Call mdc_iocontrol */
1886         rc = obd_iocontrol(OBD_IOC_FID2PATH, exp, outsize, gfout, NULL);
1887         if (rc)
1888                 GOTO(gf_free, rc);
1889
1890         if (copy_to_user(arg, gfout, outsize))
1891                 rc = -EFAULT;
1892
1893 gf_free:
1894         OBD_FREE(gfout, outsize);
1895         RETURN(rc);
1896 }
1897
1898 static int ll_ioctl_fiemap(struct inode *inode, unsigned long arg)
1899 {
1900         struct ll_user_fiemap *fiemap_s;
1901         size_t num_bytes, ret_bytes;
1902         unsigned int extent_count;
1903         int rc = 0;
1904
1905         /* Get the extent count so we can calculate the size of
1906          * required fiemap buffer */
1907         if (get_user(extent_count,
1908             &((struct ll_user_fiemap __user *)arg)->fm_extent_count))
1909                 RETURN(-EFAULT);
1910         num_bytes = sizeof(*fiemap_s) + (extent_count *
1911                                          sizeof(struct ll_fiemap_extent));
1912
1913         OBD_ALLOC_LARGE(fiemap_s, num_bytes);
1914         if (fiemap_s == NULL)
1915                 RETURN(-ENOMEM);
1916
1917         /* get the fiemap value */
1918         if (copy_from_user(fiemap_s, (struct ll_user_fiemap __user *)arg,
1919                            sizeof(*fiemap_s)))
1920                 GOTO(error, rc = -EFAULT);
1921
1922         /* If fm_extent_count is non-zero, read the first extent since
1923          * it is used to calculate end_offset and device from previous
1924          * fiemap call. */
1925         if (extent_count) {
1926                 if (copy_from_user(&fiemap_s->fm_extents[0],
1927                     (char __user *)arg + sizeof(*fiemap_s),
1928                     sizeof(struct ll_fiemap_extent)))
1929                         GOTO(error, rc = -EFAULT);
1930         }
1931
1932         rc = ll_do_fiemap(inode, fiemap_s, num_bytes);
1933         if (rc)
1934                 GOTO(error, rc);
1935
1936         ret_bytes = sizeof(struct ll_user_fiemap);
1937
1938         if (extent_count != 0)
1939                 ret_bytes += (fiemap_s->fm_mapped_extents *
1940                                  sizeof(struct ll_fiemap_extent));
1941
1942         if (copy_to_user((void *)arg, fiemap_s, ret_bytes))
1943                 rc = -EFAULT;
1944
1945 error:
1946         OBD_FREE_LARGE(fiemap_s, num_bytes);
1947         RETURN(rc);
1948 }
1949
1950 /*
1951  * Read the data_version for inode.
1952  *
1953  * This value is computed using stripe object version on OST.
1954  * Version is computed using server side locking.
1955  *
1956  * @param sync if do sync on the OST side;
1957  *              0: no sync
1958  *              LL_DV_RD_FLUSH: flush dirty pages, LCK_PR on OSTs
1959  *              LL_DV_WR_FLUSH: drop all caching pages, LCK_PW on OSTs
1960  */
1961 int ll_data_version(struct inode *inode, __u64 *data_version, int flags)
1962 {
1963         struct lov_stripe_md    *lsm = NULL;
1964         struct ll_sb_info       *sbi = ll_i2sbi(inode);
1965         struct obdo             *obdo = NULL;
1966         int                      rc;
1967         ENTRY;
1968
1969         /* If no stripe, we consider version is 0. */
1970         lsm = ccc_inode_lsm_get(inode);
1971         if (!lsm_has_objects(lsm)) {
1972                 *data_version = 0;
1973                 CDEBUG(D_INODE, "No object for inode\n");
1974                 GOTO(out, rc = 0);
1975         }
1976
1977         OBD_ALLOC_PTR(obdo);
1978         if (obdo == NULL)
1979                 GOTO(out, rc = -ENOMEM);
1980
1981         rc = ll_lsm_getattr(lsm, sbi->ll_dt_exp, NULL, obdo, 0, flags);
1982         if (rc == 0) {
1983                 if (!(obdo->o_valid & OBD_MD_FLDATAVERSION))
1984                         rc = -EOPNOTSUPP;
1985                 else
1986                         *data_version = obdo->o_data_version;
1987         }
1988
1989         OBD_FREE_PTR(obdo);
1990         EXIT;
1991 out:
1992         ccc_inode_lsm_put(inode, lsm);
1993         RETURN(rc);
1994 }
1995
1996 /*
1997  * Trigger a HSM release request for the provided inode.
1998  */
1999 int ll_hsm_release(struct inode *inode)
2000 {
2001         struct cl_env_nest nest;
2002         struct lu_env *env;
2003         struct obd_client_handle *och = NULL;
2004         __u64 data_version = 0;
2005         int rc;
2006         ENTRY;
2007
2008         CDEBUG(D_INODE, "%s: Releasing file "DFID".\n",
2009                ll_get_fsname(inode->i_sb, NULL, 0),
2010                PFID(&ll_i2info(inode)->lli_fid));
2011
2012         och = ll_lease_open(inode, NULL, FMODE_WRITE, MDS_OPEN_RELEASE);
2013         if (IS_ERR(och))
2014                 GOTO(out, rc = PTR_ERR(och));
2015
2016         /* Grab latest data_version and [am]time values */
2017         rc = ll_data_version(inode, &data_version, LL_DV_WR_FLUSH);
2018         if (rc != 0)
2019                 GOTO(out, rc);
2020
2021         env = cl_env_nested_get(&nest);
2022         if (IS_ERR(env))
2023                 GOTO(out, rc = PTR_ERR(env));
2024
2025         ll_merge_lvb(env, inode);
2026         cl_env_nested_put(&nest, env);
2027
2028         /* Release the file.
2029          * NB: lease lock handle is released in mdc_hsm_release_pack() because
2030          * we still need it to pack l_remote_handle to MDT. */
2031         rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp, inode, och,
2032                                        &data_version);
2033         och = NULL;
2034
2035         EXIT;
2036 out:
2037         if (och != NULL && !IS_ERR(och)) /* close the file */
2038                 ll_lease_close(och, inode, NULL);
2039
2040         return rc;
2041 }
2042
2043 struct ll_swap_stack {
2044         struct iattr             ia1, ia2;
2045         __u64                    dv1, dv2;
2046         struct inode            *inode1, *inode2;
2047         bool                     check_dv1, check_dv2;
2048 };
2049
2050 static int ll_swap_layouts(struct file *file1, struct file *file2,
2051                            struct lustre_swap_layouts *lsl)
2052 {
2053         struct mdc_swap_layouts  msl;
2054         struct md_op_data       *op_data;
2055         __u32                    gid;
2056         __u64                    dv;
2057         struct ll_swap_stack    *llss = NULL;
2058         int                      rc;
2059
2060         OBD_ALLOC_PTR(llss);
2061         if (llss == NULL)
2062                 RETURN(-ENOMEM);
2063
2064         llss->inode1 = file1->f_dentry->d_inode;
2065         llss->inode2 = file2->f_dentry->d_inode;
2066
2067         if (!S_ISREG(llss->inode2->i_mode))
2068                 GOTO(free, rc = -EINVAL);
2069
2070         if (inode_permission(llss->inode1, MAY_WRITE) ||
2071             inode_permission(llss->inode2, MAY_WRITE))
2072                 GOTO(free, rc = -EPERM);
2073
2074         if (llss->inode2->i_sb != llss->inode1->i_sb)
2075                 GOTO(free, rc = -EXDEV);
2076
2077         /* we use 2 bool because it is easier to swap than 2 bits */
2078         if (lsl->sl_flags & SWAP_LAYOUTS_CHECK_DV1)
2079                 llss->check_dv1 = true;
2080
2081         if (lsl->sl_flags & SWAP_LAYOUTS_CHECK_DV2)
2082                 llss->check_dv2 = true;
2083
2084         /* we cannot use lsl->sl_dvX directly because we may swap them */
2085         llss->dv1 = lsl->sl_dv1;
2086         llss->dv2 = lsl->sl_dv2;
2087
2088         rc = lu_fid_cmp(ll_inode2fid(llss->inode1), ll_inode2fid(llss->inode2));
2089         if (rc == 0) /* same file, done! */
2090                 GOTO(free, rc = 0);
2091
2092         if (rc < 0) { /* sequentialize it */
2093                 swap(llss->inode1, llss->inode2);
2094                 swap(file1, file2);
2095                 swap(llss->dv1, llss->dv2);
2096                 swap(llss->check_dv1, llss->check_dv2);
2097         }
2098
2099         gid = lsl->sl_gid;
2100         if (gid != 0) { /* application asks to flush dirty cache */
2101                 rc = ll_get_grouplock(llss->inode1, file1, gid);
2102                 if (rc < 0)
2103                         GOTO(free, rc);
2104
2105                 rc = ll_get_grouplock(llss->inode2, file2, gid);
2106                 if (rc < 0) {
2107                         ll_put_grouplock(llss->inode1, file1, gid);
2108                         GOTO(free, rc);
2109                 }
2110         }
2111
2112         /* to be able to restore mtime and atime after swap
2113          * we need to first save them */
2114         if (lsl->sl_flags &
2115             (SWAP_LAYOUTS_KEEP_MTIME | SWAP_LAYOUTS_KEEP_ATIME)) {
2116                 llss->ia1.ia_mtime = llss->inode1->i_mtime;
2117                 llss->ia1.ia_atime = llss->inode1->i_atime;
2118                 llss->ia1.ia_valid = ATTR_MTIME | ATTR_ATIME;
2119                 llss->ia2.ia_mtime = llss->inode2->i_mtime;
2120                 llss->ia2.ia_atime = llss->inode2->i_atime;
2121                 llss->ia2.ia_valid = ATTR_MTIME | ATTR_ATIME;
2122         }
2123
2124         /* ultimate check, before swaping the layouts we check if
2125          * dataversion has changed (if requested) */
2126         if (llss->check_dv1) {
2127                 rc = ll_data_version(llss->inode1, &dv, 0);
2128                 if (rc)
2129                         GOTO(putgl, rc);
2130                 if (dv != llss->dv1)
2131                         GOTO(putgl, rc = -EAGAIN);
2132         }
2133
2134         if (llss->check_dv2) {
2135                 rc = ll_data_version(llss->inode2, &dv, 0);
2136                 if (rc)
2137                         GOTO(putgl, rc);
2138                 if (dv != llss->dv2)
2139                         GOTO(putgl, rc = -EAGAIN);
2140         }
2141
2142         /* struct md_op_data is used to send the swap args to the mdt
2143          * only flags is missing, so we use struct mdc_swap_layouts
2144          * through the md_op_data->op_data */
2145         /* flags from user space have to be converted before they are send to
2146          * server, no flag is sent today, they are only used on the client */
2147         msl.msl_flags = 0;
2148         rc = -ENOMEM;
2149         op_data = ll_prep_md_op_data(NULL, llss->inode1, llss->inode2, NULL, 0,
2150                                      0, LUSTRE_OPC_ANY, &msl);
2151         if (IS_ERR(op_data))
2152                 GOTO(free, rc = PTR_ERR(op_data));
2153
2154         rc = obd_iocontrol(LL_IOC_LOV_SWAP_LAYOUTS, ll_i2mdexp(llss->inode1),
2155                            sizeof(*op_data), op_data, NULL);
2156         ll_finish_md_op_data(op_data);
2157
2158 putgl:
2159         if (gid != 0) {
2160                 ll_put_grouplock(llss->inode2, file2, gid);
2161                 ll_put_grouplock(llss->inode1, file1, gid);
2162         }
2163
2164         /* rc can be set from obd_iocontrol() or from a GOTO(putgl, ...) */
2165         if (rc != 0)
2166                 GOTO(free, rc);
2167
2168         /* clear useless flags */
2169         if (!(lsl->sl_flags & SWAP_LAYOUTS_KEEP_MTIME)) {
2170                 llss->ia1.ia_valid &= ~ATTR_MTIME;
2171                 llss->ia2.ia_valid &= ~ATTR_MTIME;
2172         }
2173
2174         if (!(lsl->sl_flags & SWAP_LAYOUTS_KEEP_ATIME)) {
2175                 llss->ia1.ia_valid &= ~ATTR_ATIME;
2176                 llss->ia2.ia_valid &= ~ATTR_ATIME;
2177         }
2178
2179         /* update time if requested */
2180         rc = 0;
2181         if (llss->ia2.ia_valid != 0) {
2182                 mutex_lock(&llss->inode1->i_mutex);
2183                 rc = ll_setattr(file1->f_dentry, &llss->ia2);
2184                 mutex_unlock(&llss->inode1->i_mutex);
2185         }
2186
2187         if (llss->ia1.ia_valid != 0) {
2188                 int rc1;
2189
2190                 mutex_lock(&llss->inode2->i_mutex);
2191                 rc1 = ll_setattr(file2->f_dentry, &llss->ia1);
2192                 mutex_unlock(&llss->inode2->i_mutex);
2193                 if (rc == 0)
2194                         rc = rc1;
2195         }
2196
2197 free:
2198         if (llss != NULL)
2199                 OBD_FREE_PTR(llss);
2200
2201         RETURN(rc);
2202 }
2203
2204 static int ll_hsm_state_set(struct inode *inode, struct hsm_state_set *hss)
2205 {
2206         struct md_op_data       *op_data;
2207         int                      rc;
2208
2209         /* Non-root users are forbidden to set or clear flags which are
2210          * NOT defined in HSM_USER_MASK. */
2211         if (((hss->hss_setmask | hss->hss_clearmask) & ~HSM_USER_MASK) &&
2212             !cfs_capable(CFS_CAP_SYS_ADMIN))
2213                 RETURN(-EPERM);
2214
2215         op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL, 0, 0,
2216                                      LUSTRE_OPC_ANY, hss);
2217         if (IS_ERR(op_data))
2218                 RETURN(PTR_ERR(op_data));
2219
2220         rc = obd_iocontrol(LL_IOC_HSM_STATE_SET, ll_i2mdexp(inode),
2221                            sizeof(*op_data), op_data, NULL);
2222
2223         ll_finish_md_op_data(op_data);
2224
2225         RETURN(rc);
2226 }
2227
2228 static int ll_hsm_import(struct inode *inode, struct file *file,
2229                          struct hsm_user_import *hui)
2230 {
2231         struct hsm_state_set    *hss = NULL;
2232         struct iattr            *attr = NULL;
2233         int                      rc;
2234         ENTRY;
2235
2236         if (!S_ISREG(inode->i_mode))
2237                 RETURN(-EINVAL);
2238
2239         /* set HSM flags */
2240         OBD_ALLOC_PTR(hss);
2241         if (hss == NULL)
2242                 GOTO(out, rc = -ENOMEM);
2243
2244         hss->hss_valid = HSS_SETMASK | HSS_ARCHIVE_ID;
2245         hss->hss_archive_id = hui->hui_archive_id;
2246         hss->hss_setmask = HS_ARCHIVED | HS_EXISTS | HS_RELEASED;
2247         rc = ll_hsm_state_set(inode, hss);
2248         if (rc != 0)
2249                 GOTO(out, rc);
2250
2251         OBD_ALLOC_PTR(attr);
2252         if (attr == NULL)
2253                 GOTO(out, rc = -ENOMEM);
2254
2255         attr->ia_mode = hui->hui_mode & (S_IRWXU | S_IRWXG | S_IRWXO);
2256         attr->ia_mode |= S_IFREG;
2257         attr->ia_uid = hui->hui_uid;
2258         attr->ia_gid = hui->hui_gid;
2259         attr->ia_size = hui->hui_size;
2260         attr->ia_mtime.tv_sec = hui->hui_mtime;
2261         attr->ia_mtime.tv_nsec = hui->hui_mtime_ns;
2262         attr->ia_atime.tv_sec = hui->hui_atime;
2263         attr->ia_atime.tv_nsec = hui->hui_atime_ns;
2264
2265         attr->ia_valid = ATTR_SIZE | ATTR_MODE | ATTR_FORCE |
2266                          ATTR_UID | ATTR_GID |
2267                          ATTR_MTIME | ATTR_MTIME_SET |
2268                          ATTR_ATIME | ATTR_ATIME_SET;
2269
2270         rc = ll_setattr_raw(file->f_dentry, attr, true);
2271         if (rc == -ENODATA)
2272                 rc = 0;
2273
2274 out:
2275         if (hss != NULL)
2276                 OBD_FREE_PTR(hss);
2277
2278         if (attr != NULL)
2279                 OBD_FREE_PTR(attr);
2280
2281         RETURN(rc);
2282 }
2283
2284 long ll_file_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
2285 {
2286         struct inode            *inode = file->f_dentry->d_inode;
2287         struct ll_file_data     *fd = LUSTRE_FPRIVATE(file);
2288         int                      flags, rc;
2289         ENTRY;
2290
2291         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p),cmd=%x\n", inode->i_ino,
2292                inode->i_generation, inode, cmd);
2293         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_IOCTL, 1);
2294
2295         /* asm-ppc{,64} declares TCGETS, et. al. as type 't' not 'T' */
2296         if (_IOC_TYPE(cmd) == 'T' || _IOC_TYPE(cmd) == 't') /* tty ioctls */
2297                 RETURN(-ENOTTY);
2298
2299         switch(cmd) {
2300         case LL_IOC_GETFLAGS:
2301                 /* Get the current value of the file flags */
2302                 return put_user(fd->fd_flags, (int *)arg);
2303         case LL_IOC_SETFLAGS:
2304         case LL_IOC_CLRFLAGS:
2305                 /* Set or clear specific file flags */
2306                 /* XXX This probably needs checks to ensure the flags are
2307                  *     not abused, and to handle any flag side effects.
2308                  */
2309                 if (get_user(flags, (int *) arg))
2310                         RETURN(-EFAULT);
2311
2312                 if (cmd == LL_IOC_SETFLAGS) {
2313                         if ((flags & LL_FILE_IGNORE_LOCK) &&
2314                             !(file->f_flags & O_DIRECT)) {
2315                                 CERROR("%s: unable to disable locking on "
2316                                        "non-O_DIRECT file\n", current->comm);
2317                                 RETURN(-EINVAL);
2318                         }
2319
2320                         fd->fd_flags |= flags;
2321                 } else {
2322                         fd->fd_flags &= ~flags;
2323                 }
2324                 RETURN(0);
2325         case LL_IOC_LOV_SETSTRIPE:
2326                 RETURN(ll_lov_setstripe(inode, file, arg));
2327         case LL_IOC_LOV_SETEA:
2328                 RETURN(ll_lov_setea(inode, file, arg));
2329         case LL_IOC_LOV_SWAP_LAYOUTS: {
2330                 struct file *file2;
2331                 struct lustre_swap_layouts lsl;
2332
2333                 if (copy_from_user(&lsl, (char *)arg,
2334                                        sizeof(struct lustre_swap_layouts)))
2335                         RETURN(-EFAULT);
2336
2337                 if ((file->f_flags & O_ACCMODE) == 0) /* O_RDONLY */
2338                         RETURN(-EPERM);
2339
2340                 file2 = fget(lsl.sl_fd);
2341                 if (file2 == NULL)
2342                         RETURN(-EBADF);
2343
2344                 rc = -EPERM;
2345                 if ((file2->f_flags & O_ACCMODE) != 0) /* O_WRONLY or O_RDWR */
2346                         rc = ll_swap_layouts(file, file2, &lsl);
2347                 fput(file2);
2348                 RETURN(rc);
2349         }
2350         case LL_IOC_LOV_GETSTRIPE:
2351                 RETURN(ll_lov_getstripe(inode, arg));
2352         case LL_IOC_RECREATE_OBJ:
2353                 RETURN(ll_lov_recreate_obj(inode, arg));
2354         case LL_IOC_RECREATE_FID:
2355                 RETURN(ll_lov_recreate_fid(inode, arg));
2356         case FSFILT_IOC_FIEMAP:
2357                 RETURN(ll_ioctl_fiemap(inode, arg));
2358         case FSFILT_IOC_GETFLAGS:
2359         case FSFILT_IOC_SETFLAGS:
2360                 RETURN(ll_iocontrol(inode, file, cmd, arg));
2361         case FSFILT_IOC_GETVERSION_OLD:
2362         case FSFILT_IOC_GETVERSION:
2363                 RETURN(put_user(inode->i_generation, (int *)arg));
2364         case LL_IOC_GROUP_LOCK:
2365                 RETURN(ll_get_grouplock(inode, file, arg));
2366         case LL_IOC_GROUP_UNLOCK:
2367                 RETURN(ll_put_grouplock(inode, file, arg));
2368         case IOC_OBD_STATFS:
2369                 RETURN(ll_obd_statfs(inode, (void *)arg));
2370
2371         /* We need to special case any other ioctls we want to handle,
2372          * to send them to the MDS/OST as appropriate and to properly
2373          * network encode the arg field.
2374         case FSFILT_IOC_SETVERSION_OLD:
2375         case FSFILT_IOC_SETVERSION:
2376         */
2377         case LL_IOC_FLUSHCTX:
2378                 RETURN(ll_flush_ctx(inode));
2379         case LL_IOC_PATH2FID: {
2380                 if (copy_to_user((void *)arg, ll_inode2fid(inode),
2381                                  sizeof(struct lu_fid)))
2382                         RETURN(-EFAULT);
2383
2384                 RETURN(0);
2385         }
2386         case OBD_IOC_FID2PATH:
2387                 RETURN(ll_fid2path(inode, (void *)arg));
2388         case LL_IOC_DATA_VERSION: {
2389                 struct ioc_data_version idv;
2390                 int rc;
2391
2392                 if (copy_from_user(&idv, (char *)arg, sizeof(idv)))
2393                         RETURN(-EFAULT);
2394
2395                 idv.idv_flags &= LL_DV_RD_FLUSH | LL_DV_WR_FLUSH;
2396                 rc = ll_data_version(inode, &idv.idv_version, idv.idv_flags);
2397
2398                 if (rc == 0 && copy_to_user((char *) arg, &idv, sizeof(idv)))
2399                         RETURN(-EFAULT);
2400
2401                 RETURN(rc);
2402         }
2403
2404         case LL_IOC_GET_MDTIDX: {
2405                 int mdtidx;
2406
2407                 mdtidx = ll_get_mdt_idx(inode);
2408                 if (mdtidx < 0)
2409                         RETURN(mdtidx);
2410
2411                 if (put_user((int)mdtidx, (int*)arg))
2412                         RETURN(-EFAULT);
2413
2414                 RETURN(0);
2415         }
2416         case OBD_IOC_GETDTNAME:
2417         case OBD_IOC_GETMDNAME:
2418                 RETURN(ll_get_obd_name(inode, cmd, arg));
2419         case LL_IOC_HSM_STATE_GET: {
2420                 struct md_op_data       *op_data;
2421                 struct hsm_user_state   *hus;
2422                 int                      rc;
2423
2424                 OBD_ALLOC_PTR(hus);
2425                 if (hus == NULL)
2426                         RETURN(-ENOMEM);
2427
2428                 op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL, 0, 0,
2429                                              LUSTRE_OPC_ANY, hus);
2430                 if (IS_ERR(op_data)) {
2431                         OBD_FREE_PTR(hus);
2432                         RETURN(PTR_ERR(op_data));
2433                 }
2434
2435                 rc = obd_iocontrol(cmd, ll_i2mdexp(inode), sizeof(*op_data),
2436                                    op_data, NULL);
2437
2438                 if (copy_to_user((void *)arg, hus, sizeof(*hus)))
2439                         rc = -EFAULT;
2440
2441                 ll_finish_md_op_data(op_data);
2442                 OBD_FREE_PTR(hus);
2443                 RETURN(rc);
2444         }
2445         case LL_IOC_HSM_STATE_SET: {
2446                 struct hsm_state_set    *hss;
2447                 int                      rc;
2448
2449                 OBD_ALLOC_PTR(hss);
2450                 if (hss == NULL)
2451                         RETURN(-ENOMEM);
2452
2453                 if (copy_from_user(hss, (char *)arg, sizeof(*hss))) {
2454                         OBD_FREE_PTR(hss);
2455                         RETURN(-EFAULT);
2456                 }
2457
2458                 rc = ll_hsm_state_set(inode, hss);
2459
2460                 OBD_FREE_PTR(hss);
2461                 RETURN(rc);
2462         }
2463         case LL_IOC_HSM_ACTION: {
2464                 struct md_op_data               *op_data;
2465                 struct hsm_current_action       *hca;
2466                 int                              rc;
2467
2468                 OBD_ALLOC_PTR(hca);
2469                 if (hca == NULL)
2470                         RETURN(-ENOMEM);
2471
2472                 op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL, 0, 0,
2473                                              LUSTRE_OPC_ANY, hca);
2474                 if (IS_ERR(op_data)) {
2475                         OBD_FREE_PTR(hca);
2476                         RETURN(PTR_ERR(op_data));
2477                 }
2478
2479                 rc = obd_iocontrol(cmd, ll_i2mdexp(inode), sizeof(*op_data),
2480                                    op_data, NULL);
2481
2482                 if (copy_to_user((char *)arg, hca, sizeof(*hca)))
2483                         rc = -EFAULT;
2484
2485                 ll_finish_md_op_data(op_data);
2486                 OBD_FREE_PTR(hca);
2487                 RETURN(rc);
2488         }
2489         case LL_IOC_SET_LEASE: {
2490                 struct ll_inode_info *lli = ll_i2info(inode);
2491                 struct obd_client_handle *och = NULL;
2492                 bool lease_broken;
2493                 fmode_t mode = 0;
2494
2495                 switch (arg) {
2496                 case F_WRLCK:
2497                         if (!(file->f_mode & FMODE_WRITE))
2498                                 RETURN(-EPERM);
2499                         mode = FMODE_WRITE;
2500                         break;
2501                 case F_RDLCK:
2502                         if (!(file->f_mode & FMODE_READ))
2503                                 RETURN(-EPERM);
2504                         mode = FMODE_READ;
2505                         break;
2506                 case F_UNLCK:
2507                         mutex_lock(&lli->lli_och_mutex);
2508                         if (fd->fd_lease_och != NULL) {
2509                                 och = fd->fd_lease_och;
2510                                 fd->fd_lease_och = NULL;
2511                         }
2512                         mutex_unlock(&lli->lli_och_mutex);
2513
2514                         if (och != NULL) {
2515                                 mode = och->och_flags &(FMODE_READ|FMODE_WRITE);
2516                                 rc = ll_lease_close(och, inode, &lease_broken);
2517                                 if (rc == 0 && lease_broken)
2518                                         mode = 0;
2519                         } else {
2520                                 rc = -ENOLCK;
2521                         }
2522
2523                         /* return the type of lease or error */
2524                         RETURN(rc < 0 ? rc : (int)mode);
2525                 default:
2526                         RETURN(-EINVAL);
2527                 }
2528
2529                 CDEBUG(D_INODE, "Set lease with mode %d\n", mode);
2530
2531                 /* apply for lease */
2532                 och = ll_lease_open(inode, file, mode, 0);
2533                 if (IS_ERR(och))
2534                         RETURN(PTR_ERR(och));
2535
2536                 rc = 0;
2537                 mutex_lock(&lli->lli_och_mutex);
2538                 if (fd->fd_lease_och == NULL) {
2539                         fd->fd_lease_och = och;
2540                         och = NULL;
2541                 }
2542                 mutex_unlock(&lli->lli_och_mutex);
2543                 if (och != NULL) {
2544                         /* impossible now that only excl is supported for now */
2545                         ll_lease_close(och, inode, &lease_broken);
2546                         rc = -EBUSY;
2547                 }
2548                 RETURN(rc);
2549         }
2550         case LL_IOC_GET_LEASE: {
2551                 struct ll_inode_info *lli = ll_i2info(inode);
2552                 struct ldlm_lock *lock = NULL;
2553
2554                 rc = 0;
2555                 mutex_lock(&lli->lli_och_mutex);
2556                 if (fd->fd_lease_och != NULL) {
2557                         struct obd_client_handle *och = fd->fd_lease_och;
2558
2559                         lock = ldlm_handle2lock(&och->och_lease_handle);
2560                         if (lock != NULL) {
2561                                 lock_res_and_lock(lock);
2562                                 if (!ldlm_is_cancel(lock))
2563                                         rc = och->och_flags &
2564                                                 (FMODE_READ | FMODE_WRITE);
2565                                 unlock_res_and_lock(lock);
2566                                 LDLM_LOCK_PUT(lock);
2567                         }
2568                 }
2569                 mutex_unlock(&lli->lli_och_mutex);
2570                 RETURN(rc);
2571         }
2572         case LL_IOC_HSM_IMPORT: {
2573                 struct hsm_user_import *hui;
2574
2575                 OBD_ALLOC_PTR(hui);
2576                 if (hui == NULL)
2577                         RETURN(-ENOMEM);
2578
2579                 if (copy_from_user(hui, (void *)arg, sizeof(*hui))) {
2580                         OBD_FREE_PTR(hui);
2581                         RETURN(-EFAULT);
2582                 }
2583
2584                 rc = ll_hsm_import(inode, file, hui);
2585
2586                 OBD_FREE_PTR(hui);
2587                 RETURN(rc);
2588         }
2589         default: {
2590                 int err;
2591
2592                 if (LLIOC_STOP ==
2593                      ll_iocontrol_call(inode, file, cmd, arg, &err))
2594                         RETURN(err);
2595
2596                 RETURN(obd_iocontrol(cmd, ll_i2dtexp(inode), 0, NULL,
2597                                      (void *)arg));
2598         }
2599         }
2600 }
2601
2602 #ifndef HAVE_FILE_LLSEEK_SIZE
2603 static inline loff_t
2604 llseek_execute(struct file *file, loff_t offset, loff_t maxsize)
2605 {
2606         if (offset < 0 && !(file->f_mode & FMODE_UNSIGNED_OFFSET))
2607                 return -EINVAL;
2608         if (offset > maxsize)
2609                 return -EINVAL;
2610
2611         if (offset != file->f_pos) {
2612                 file->f_pos = offset;
2613                 file->f_version = 0;
2614         }
2615         return offset;
2616 }
2617
2618 static loff_t
2619 generic_file_llseek_size(struct file *file, loff_t offset, int origin,
2620                 loff_t maxsize, loff_t eof)
2621 {
2622         struct inode *inode = file->f_dentry->d_inode;
2623
2624         switch (origin) {
2625         case SEEK_END:
2626                 offset += eof;
2627                 break;
2628         case SEEK_CUR:
2629                 /*
2630                  * Here we special-case the lseek(fd, 0, SEEK_CUR)
2631                  * position-querying operation.  Avoid rewriting the "same"
2632                  * f_pos value back to the file because a concurrent read(),
2633                  * write() or lseek() might have altered it
2634                  */
2635                 if (offset == 0)
2636                         return file->f_pos;
2637                 /*
2638                  * f_lock protects against read/modify/write race with other
2639                  * SEEK_CURs. Note that parallel writes and reads behave
2640                  * like SEEK_SET.
2641                  */
2642                 mutex_lock(&inode->i_mutex);
2643                 offset = llseek_execute(file, file->f_pos + offset, maxsize);
2644                 mutex_unlock(&inode->i_mutex);
2645                 return offset;
2646         case SEEK_DATA:
2647                 /*
2648                  * In the generic case the entire file is data, so as long as
2649                  * offset isn't at the end of the file then the offset is data.
2650                  */
2651                 if (offset >= eof)
2652                         return -ENXIO;
2653                 break;
2654         case SEEK_HOLE:
2655                 /*
2656                  * There is a virtual hole at the end of the file, so as long as
2657                  * offset isn't i_size or larger, return i_size.
2658                  */
2659                 if (offset >= eof)
2660                         return -ENXIO;
2661                 offset = eof;
2662                 break;
2663         }
2664
2665         return llseek_execute(file, offset, maxsize);
2666 }
2667 #endif
2668
2669 loff_t ll_file_seek(struct file *file, loff_t offset, int origin)
2670 {
2671         struct inode *inode = file->f_dentry->d_inode;
2672         loff_t retval, eof = 0;
2673
2674         ENTRY;
2675         retval = offset + ((origin == SEEK_END) ? i_size_read(inode) :
2676                            (origin == SEEK_CUR) ? file->f_pos : 0);
2677         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p), to=%llu=%#llx(%d)\n",
2678                inode->i_ino, inode->i_generation, inode, retval, retval,
2679                origin);
2680         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_LLSEEK, 1);
2681
2682         if (origin == SEEK_END || origin == SEEK_HOLE || origin == SEEK_DATA) {
2683                 retval = ll_glimpse_size(inode);
2684                 if (retval != 0)
2685                         RETURN(retval);
2686                 eof = i_size_read(inode);
2687         }
2688
2689         retval = ll_generic_file_llseek_size(file, offset, origin,
2690                                           ll_file_maxbytes(inode), eof);
2691         RETURN(retval);
2692 }
2693
2694 int ll_flush(struct file *file, fl_owner_t id)
2695 {
2696         struct inode *inode = file->f_dentry->d_inode;
2697         struct ll_inode_info *lli = ll_i2info(inode);
2698         struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
2699         int rc, err;
2700
2701         LASSERT(!S_ISDIR(inode->i_mode));
2702
2703         /* catch async errors that were recorded back when async writeback
2704          * failed for pages in this mapping. */
2705         rc = lli->lli_async_rc;
2706         lli->lli_async_rc = 0;
2707         err = lov_read_and_clear_async_rc(lli->lli_clob);
2708         if (rc == 0)
2709                 rc = err;
2710
2711         /* The application has been told write failure already.
2712          * Do not report failure again. */
2713         if (fd->fd_write_failed)
2714                 return 0;
2715         return rc ? -EIO : 0;
2716 }
2717
2718 /**
2719  * Called to make sure a portion of file has been written out.
2720  * if @local_only is not true, it will send OST_SYNC RPCs to ost.
2721  *
2722  * Return how many pages have been written.
2723  */
2724 int cl_sync_file_range(struct inode *inode, loff_t start, loff_t end,
2725                        enum cl_fsync_mode mode, int ignore_layout)
2726 {
2727         struct cl_env_nest nest;
2728         struct lu_env *env;
2729         struct cl_io *io;
2730         struct obd_capa *capa = NULL;
2731         struct cl_fsync_io *fio;
2732         int result;
2733         ENTRY;
2734
2735         if (mode != CL_FSYNC_NONE && mode != CL_FSYNC_LOCAL &&
2736             mode != CL_FSYNC_DISCARD && mode != CL_FSYNC_ALL)
2737                 RETURN(-EINVAL);
2738
2739         env = cl_env_nested_get(&nest);
2740         if (IS_ERR(env))
2741                 RETURN(PTR_ERR(env));
2742
2743         capa = ll_osscapa_get(inode, CAPA_OPC_OSS_WRITE);
2744
2745         io = ccc_env_thread_io(env);
2746         io->ci_obj = cl_i2info(inode)->lli_clob;
2747         io->ci_ignore_layout = ignore_layout;
2748
2749         /* initialize parameters for sync */
2750         fio = &io->u.ci_fsync;
2751         fio->fi_capa = capa;
2752         fio->fi_start = start;
2753         fio->fi_end = end;
2754         fio->fi_fid = ll_inode2fid(inode);
2755         fio->fi_mode = mode;
2756         fio->fi_nr_written = 0;
2757
2758         if (cl_io_init(env, io, CIT_FSYNC, io->ci_obj) == 0)
2759                 result = cl_io_loop(env, io);
2760         else
2761                 result = io->ci_result;
2762         if (result == 0)
2763                 result = fio->fi_nr_written;
2764         cl_io_fini(env, io);
2765         cl_env_nested_put(&nest, env);
2766
2767         capa_put(capa);
2768
2769         RETURN(result);
2770 }
2771
2772 /*
2773  * When dentry is provided (the 'else' case), *file->f_dentry may be
2774  * null and dentry must be used directly rather than pulled from
2775  * *file->f_dentry as is done otherwise.
2776  */
2777
2778 #ifdef HAVE_FILE_FSYNC_4ARGS
2779 int ll_fsync(struct file *file, loff_t start, loff_t end, int datasync)
2780 {
2781         struct dentry *dentry = file->f_dentry;
2782 #elif defined(HAVE_FILE_FSYNC_2ARGS)
2783 int ll_fsync(struct file *file, int datasync)
2784 {
2785         struct dentry *dentry = file->f_dentry;
2786 #else
2787 int ll_fsync(struct file *file, struct dentry *dentry, int datasync)
2788 {
2789 #endif
2790         struct inode *inode = dentry->d_inode;
2791         struct ll_inode_info *lli = ll_i2info(inode);
2792         struct ptlrpc_request *req;
2793         struct obd_capa *oc;
2794         int rc, err;
2795         ENTRY;
2796
2797         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p)\n", inode->i_ino,
2798                inode->i_generation, inode);
2799         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_FSYNC, 1);
2800
2801 #ifdef HAVE_FILE_FSYNC_4ARGS
2802         rc = filemap_write_and_wait_range(inode->i_mapping, start, end);
2803         mutex_lock(&inode->i_mutex);
2804 #else
2805         /* fsync's caller has already called _fdata{sync,write}, we want
2806          * that IO to finish before calling the osc and mdc sync methods */
2807         rc = filemap_fdatawait(inode->i_mapping);
2808 #endif
2809
2810         /* catch async errors that were recorded back when async writeback
2811          * failed for pages in this mapping. */
2812         if (!S_ISDIR(inode->i_mode)) {
2813                 err = lli->lli_async_rc;
2814                 lli->lli_async_rc = 0;
2815                 if (rc == 0)
2816                         rc = err;
2817                 err = lov_read_and_clear_async_rc(lli->lli_clob);
2818                 if (rc == 0)
2819                         rc = err;
2820         }
2821
2822         oc = ll_mdscapa_get(inode);
2823         err = md_fsync(ll_i2sbi(inode)->ll_md_exp, ll_inode2fid(inode), oc,
2824                        &req);
2825         capa_put(oc);
2826         if (!rc)
2827                 rc = err;
2828         if (!err)
2829                 ptlrpc_req_finished(req);
2830
2831         if (datasync && S_ISREG(inode->i_mode)) {
2832                 struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
2833
2834                 err = cl_sync_file_range(inode, 0, OBD_OBJECT_EOF,
2835                                 CL_FSYNC_ALL, 0);
2836                 if (rc == 0 && err < 0)
2837                         rc = err;
2838                 if (rc < 0)
2839                         fd->fd_write_failed = true;
2840                 else
2841                         fd->fd_write_failed = false;
2842         }
2843
2844 #ifdef HAVE_FILE_FSYNC_4ARGS
2845         mutex_unlock(&inode->i_mutex);
2846 #endif
2847         RETURN(rc);
2848 }
2849
2850 int ll_file_flock(struct file *file, int cmd, struct file_lock *file_lock)
2851 {
2852         struct inode *inode = file->f_dentry->d_inode;
2853         struct ll_sb_info *sbi = ll_i2sbi(inode);
2854         struct ldlm_enqueue_info einfo = {
2855                 .ei_type        = LDLM_FLOCK,
2856                 .ei_cb_cp       = ldlm_flock_completion_ast,
2857                 .ei_cbdata      = file_lock,
2858         };
2859         struct md_op_data *op_data;
2860         struct lustre_handle lockh = {0};
2861         ldlm_policy_data_t flock = {{0}};
2862         int flags = 0;
2863         int rc;
2864         int rc2 = 0;
2865         ENTRY;
2866
2867         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu file_lock=%p\n",
2868                inode->i_ino, file_lock);
2869
2870         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_FLOCK, 1);
2871
2872         if (file_lock->fl_flags & FL_FLOCK) {
2873                 LASSERT((cmd == F_SETLKW) || (cmd == F_SETLK));
2874                 /* flocks are whole-file locks */
2875                 flock.l_flock.end = OFFSET_MAX;
2876                 /* For flocks owner is determined by the local file desctiptor*/
2877                 flock.l_flock.owner = (unsigned long)file_lock->fl_file;
2878         } else if (file_lock->fl_flags & FL_POSIX) {
2879                 flock.l_flock.owner = (unsigned long)file_lock->fl_owner;
2880                 flock.l_flock.start = file_lock->fl_start;
2881                 flock.l_flock.end = file_lock->fl_end;
2882         } else {
2883                 RETURN(-EINVAL);
2884         }
2885         flock.l_flock.pid = file_lock->fl_pid;
2886
2887         /* Somewhat ugly workaround for svc lockd.
2888          * lockd installs custom fl_lmops->lm_compare_owner that checks
2889          * for the fl_owner to be the same (which it always is on local node
2890          * I guess between lockd processes) and then compares pid.
2891          * As such we assign pid to the owner field to make it all work,
2892          * conflict with normal locks is unlikely since pid space and
2893          * pointer space for current->files are not intersecting */
2894         if (file_lock->fl_lmops && file_lock->fl_lmops->lm_compare_owner)
2895                 flock.l_flock.owner = (unsigned long)file_lock->fl_pid;
2896
2897         switch (file_lock->fl_type) {
2898         case F_RDLCK:
2899                 einfo.ei_mode = LCK_PR;
2900                 break;
2901         case F_UNLCK:
2902                 /* An unlock request may or may not have any relation to
2903                  * existing locks so we may not be able to pass a lock handle
2904                  * via a normal ldlm_lock_cancel() request. The request may even
2905                  * unlock a byte range in the middle of an existing lock. In
2906                  * order to process an unlock request we need all of the same
2907                  * information that is given with a normal read or write record
2908                  * lock request. To avoid creating another ldlm unlock (cancel)
2909                  * message we'll treat a LCK_NL flock request as an unlock. */
2910                 einfo.ei_mode = LCK_NL;
2911                 break;
2912         case F_WRLCK:
2913                 einfo.ei_mode = LCK_PW;
2914                 break;
2915         default:
2916                 CDEBUG(D_INFO, "Unknown fcntl lock type: %d\n",
2917                         file_lock->fl_type);
2918                 RETURN (-ENOTSUPP);
2919         }
2920
2921         switch (cmd) {
2922         case F_SETLKW:
2923 #ifdef F_SETLKW64
2924         case F_SETLKW64:
2925 #endif
2926                 flags = 0;
2927                 break;
2928         case F_SETLK:
2929 #ifdef F_SETLK64
2930         case F_SETLK64:
2931 #endif
2932                 flags = LDLM_FL_BLOCK_NOWAIT;
2933                 break;
2934         case F_GETLK:
2935 #ifdef F_GETLK64
2936         case F_GETLK64:
2937 #endif
2938                 flags = LDLM_FL_TEST_LOCK;
2939                 /* Save the old mode so that if the mode in the lock changes we
2940                  * can decrement the appropriate reader or writer refcount. */
2941                 file_lock->fl_type = einfo.ei_mode;
2942                 break;
2943         default:
2944                 CERROR("unknown fcntl lock command: %d\n", cmd);
2945                 RETURN (-EINVAL);
2946         }
2947
2948         op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL, 0, 0,
2949                                      LUSTRE_OPC_ANY, NULL);
2950         if (IS_ERR(op_data))
2951                 RETURN(PTR_ERR(op_data));
2952
2953         CDEBUG(D_DLMTRACE, "inode=%lu, pid=%u, flags=%#x, mode=%u, "
2954                "start="LPU64", end="LPU64"\n", inode->i_ino, flock.l_flock.pid,
2955                flags, einfo.ei_mode, flock.l_flock.start, flock.l_flock.end);
2956
2957         rc = md_enqueue(sbi->ll_md_exp, &einfo, NULL,
2958                         op_data, &lockh, &flock, 0, NULL /* req */, flags);
2959
2960         if ((file_lock->fl_flags & FL_FLOCK) &&
2961             (rc == 0 || file_lock->fl_type == F_UNLCK))
2962                 rc2  = flock_lock_file_wait(file, file_lock);
2963         if ((file_lock->fl_flags & FL_POSIX) &&
2964             (rc == 0 || file_lock->fl_type == F_UNLCK) &&
2965             !(flags & LDLM_FL_TEST_LOCK))
2966                 rc2  = posix_lock_file_wait(file, file_lock);
2967
2968         if (rc2 && file_lock->fl_type != F_UNLCK) {
2969                 einfo.ei_mode = LCK_NL;
2970                 md_enqueue(sbi->ll_md_exp, &einfo, NULL,
2971                         op_data, &lockh, &flock, 0, NULL /* req */, flags);
2972                 rc = rc2;
2973         }
2974
2975         ll_finish_md_op_data(op_data);
2976
2977         RETURN(rc);
2978 }
2979
2980 int ll_file_noflock(struct file *file, int cmd, struct file_lock *file_lock)
2981 {
2982         ENTRY;
2983
2984         RETURN(-ENOSYS);
2985 }
2986
2987 /**
2988  * test if some locks matching bits and l_req_mode are acquired
2989  * - bits can be in different locks
2990  * - if found clear the common lock bits in *bits
2991  * - the bits not found, are kept in *bits
2992  * \param inode [IN]
2993  * \param bits [IN] searched lock bits [IN]
2994  * \param l_req_mode [IN] searched lock mode
2995  * \retval boolean, true iff all bits are found
2996  */
2997 int ll_have_md_lock(struct inode *inode, __u64 *bits,  ldlm_mode_t l_req_mode)
2998 {
2999         struct lustre_handle lockh;
3000         ldlm_policy_data_t policy;
3001         ldlm_mode_t mode = (l_req_mode == LCK_MINMODE) ?
3002                                 (LCK_CR|LCK_CW|LCK_PR|LCK_PW) : l_req_mode;
3003         struct lu_fid *fid;
3004         __u64 flags;
3005         int i;
3006         ENTRY;
3007
3008         if (!inode)
3009                RETURN(0);
3010
3011         fid = &ll_i2info(inode)->lli_fid;
3012         CDEBUG(D_INFO, "trying to match res "DFID" mode %s\n", PFID(fid),
3013                ldlm_lockname[mode]);
3014
3015         flags = LDLM_FL_BLOCK_GRANTED | LDLM_FL_CBPENDING | LDLM_FL_TEST_LOCK;
3016         for (i = 0; i <= MDS_INODELOCK_MAXSHIFT && *bits != 0; i++) {
3017                 policy.l_inodebits.bits = *bits & (1 << i);
3018                 if (policy.l_inodebits.bits == 0)
3019                         continue;
3020
3021                 if (md_lock_match(ll_i2mdexp(inode), flags, fid, LDLM_IBITS,
3022                                   &policy, mode, &lockh)) {
3023                         struct ldlm_lock *lock;
3024
3025                         lock = ldlm_handle2lock(&lockh);
3026                         if (lock) {
3027                                 *bits &=
3028                                       ~(lock->l_policy_data.l_inodebits.bits);
3029                                 LDLM_LOCK_PUT(lock);
3030                         } else {
3031                                 *bits &= ~policy.l_inodebits.bits;
3032                         }
3033                 }
3034         }
3035         RETURN(*bits == 0);
3036 }
3037
3038 ldlm_mode_t ll_take_md_lock(struct inode *inode, __u64 bits,
3039                             struct lustre_handle *lockh, __u64 flags,
3040                             ldlm_mode_t mode)
3041 {
3042         ldlm_policy_data_t policy = { .l_inodebits = {bits}};
3043         struct lu_fid *fid;
3044         ldlm_mode_t rc;
3045         ENTRY;
3046
3047         fid = &ll_i2info(inode)->lli_fid;
3048         CDEBUG(D_INFO, "trying to match res "DFID"\n", PFID(fid));
3049
3050         rc = md_lock_match(ll_i2mdexp(inode), LDLM_FL_BLOCK_GRANTED|flags,
3051                            fid, LDLM_IBITS, &policy, mode, lockh);
3052
3053         RETURN(rc);
3054 }
3055
3056 static int ll_inode_revalidate_fini(struct inode *inode, int rc)
3057 {
3058         /* Already unlinked. Just update nlink and return success */
3059         if (rc == -ENOENT) {
3060                 clear_nlink(inode);
3061                 /* This path cannot be hit for regular files unless in
3062                  * case of obscure races, so no need to to validate
3063                  * size. */
3064                 if (!S_ISREG(inode->i_mode) && !S_ISDIR(inode->i_mode))
3065                         return 0;
3066         } else if (rc != 0) {
3067                 CERROR("%s: revalidate FID "DFID" error: rc = %d\n",
3068                        ll_get_fsname(inode->i_sb, NULL, 0),
3069                        PFID(ll_inode2fid(inode)), rc);
3070         }
3071
3072         return rc;
3073 }
3074
3075 int __ll_inode_revalidate_it(struct dentry *dentry, struct lookup_intent *it,
3076                              __u64 ibits)
3077 {
3078         struct inode *inode = dentry->d_inode;
3079         struct ptlrpc_request *req = NULL;
3080         struct obd_export *exp;
3081         int rc = 0;
3082         ENTRY;
3083
3084         LASSERT(inode != NULL);
3085
3086         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p),name=%s\n",
3087                inode->i_ino, inode->i_generation, inode, dentry->d_name.name);
3088
3089         exp = ll_i2mdexp(inode);
3090
3091         /* XXX: Enable OBD_CONNECT_ATTRFID to reduce unnecessary getattr RPC.
3092          *      But under CMD case, it caused some lock issues, should be fixed
3093          *      with new CMD ibits lock. See bug 12718 */
3094         if (exp_connect_flags(exp) & OBD_CONNECT_ATTRFID) {
3095                 struct lookup_intent oit = { .it_op = IT_GETATTR };
3096                 struct md_op_data *op_data;
3097
3098                 if (ibits == MDS_INODELOCK_LOOKUP)
3099                         oit.it_op = IT_LOOKUP;
3100
3101                 /* Call getattr by fid, so do not provide name at all. */
3102                 op_data = ll_prep_md_op_data(NULL, dentry->d_parent->d_inode,
3103                                              dentry->d_inode, NULL, 0, 0,
3104                                              LUSTRE_OPC_ANY, NULL);
3105                 if (IS_ERR(op_data))
3106                         RETURN(PTR_ERR(op_data));
3107
3108                 oit.it_create_mode |= M_CHECK_STALE;
3109                 rc = md_intent_lock(exp, op_data, NULL, 0,
3110                                     /* we are not interested in name
3111                                        based lookup */
3112                                     &oit, 0, &req,
3113                                     ll_md_blocking_ast, 0);
3114                 ll_finish_md_op_data(op_data);
3115                 oit.it_create_mode &= ~M_CHECK_STALE;
3116                 if (rc < 0) {
3117                         rc = ll_inode_revalidate_fini(inode, rc);
3118                         GOTO (out, rc);
3119                 }
3120
3121                 rc = ll_revalidate_it_finish(req, &oit, dentry);
3122                 if (rc != 0) {
3123                         ll_intent_release(&oit);
3124                         GOTO(out, rc);
3125                 }
3126
3127                 /* Unlinked? Unhash dentry, so it is not picked up later by
3128                    do_lookup() -> ll_revalidate_it(). We cannot use d_drop
3129                    here to preserve get_cwd functionality on 2.6.
3130                    Bug 10503 */
3131                 if (!dentry->d_inode->i_nlink)
3132                         d_lustre_invalidate(dentry, 0);
3133
3134                 ll_lookup_finish_locks(&oit, dentry);
3135         } else if (!ll_have_md_lock(dentry->d_inode, &ibits, LCK_MINMODE)) {
3136                 struct ll_sb_info *sbi = ll_i2sbi(dentry->d_inode);
3137                 obd_valid valid = OBD_MD_FLGETATTR;
3138                 struct md_op_data *op_data;
3139                 int ealen = 0;
3140
3141                 if (S_ISREG(inode->i_mode)) {
3142                         rc = ll_get_max_mdsize(sbi, &ealen);
3143                         if (rc)
3144                                 RETURN(rc);
3145                         valid |= OBD_MD_FLEASIZE | OBD_MD_FLMODEASIZE;
3146                 }
3147
3148                 op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL,
3149                                              0, ealen, LUSTRE_OPC_ANY,
3150                                              NULL);
3151                 if (IS_ERR(op_data))
3152                         RETURN(PTR_ERR(op_data));
3153
3154                 op_data->op_valid = valid;
3155                 /* Once OBD_CONNECT_ATTRFID is not supported, we can't find one
3156                  * capa for this inode. Because we only keep capas of dirs
3157                  * fresh. */
3158                 rc = md_getattr(sbi->ll_md_exp, op_data, &req);
3159                 ll_finish_md_op_data(op_data);
3160                 if (rc) {
3161                         rc = ll_inode_revalidate_fini(inode, rc);
3162                         RETURN(rc);
3163                 }
3164
3165                 rc = ll_prep_inode(&inode, req, NULL, NULL);
3166         }
3167 out:
3168         ptlrpc_req_finished(req);
3169         return rc;
3170 }
3171
3172 int ll_inode_revalidate_it(struct dentry *dentry, struct lookup_intent *it,
3173                            __u64 ibits)
3174 {
3175         struct inode    *inode = dentry->d_inode;
3176         int              rc;
3177         ENTRY;
3178
3179         rc = __ll_inode_revalidate_it(dentry, it, ibits);
3180         if (rc != 0)
3181                 RETURN(rc);
3182
3183         /* if object isn't regular file, don't validate size */
3184         if (!S_ISREG(inode->i_mode)) {
3185                 LTIME_S(inode->i_atime) = ll_i2info(inode)->lli_lvb.lvb_atime;
3186                 LTIME_S(inode->i_mtime) = ll_i2info(inode)->lli_lvb.lvb_mtime;
3187                 LTIME_S(inode->i_ctime) = ll_i2info(inode)->lli_lvb.lvb_ctime;
3188         } else {
3189                 /* In case of restore, the MDT has the right size and has
3190                  * already send it back without granting the layout lock,
3191                  * inode is up-to-date so glimpse is useless.
3192                  * Also to glimpse we need the layout, in case of a running
3193                  * restore the MDT holds the layout lock so the glimpse will
3194                  * block up to the end of restore (getattr will block)
3195                  */
3196                 if (!(ll_i2info(inode)->lli_flags & LLIF_FILE_RESTORING))
3197                         rc = ll_glimpse_size(inode);
3198         }
3199         RETURN(rc);
3200 }
3201
3202 int ll_getattr_it(struct vfsmount *mnt, struct dentry *de,
3203                   struct lookup_intent *it, struct kstat *stat)
3204 {
3205         struct inode *inode = de->d_inode;
3206         struct ll_sb_info *sbi = ll_i2sbi(inode);
3207         struct ll_inode_info *lli = ll_i2info(inode);
3208         int res = 0;
3209
3210         res = ll_inode_revalidate_it(de, it, MDS_INODELOCK_UPDATE |
3211                                              MDS_INODELOCK_LOOKUP);
3212         ll_stats_ops_tally(sbi, LPROC_LL_GETATTR, 1);
3213
3214         if (res)
3215                 return res;
3216
3217         stat->dev = inode->i_sb->s_dev;
3218         if (ll_need_32bit_api(sbi))
3219                 stat->ino = cl_fid_build_ino(&lli->lli_fid, 1);
3220         else
3221                 stat->ino = inode->i_ino;
3222         stat->mode = inode->i_mode;
3223         stat->nlink = inode->i_nlink;
3224         stat->uid = inode->i_uid;
3225         stat->gid = inode->i_gid;
3226         stat->rdev = inode->i_rdev;
3227         stat->atime = inode->i_atime;
3228         stat->mtime = inode->i_mtime;
3229         stat->ctime = inode->i_ctime;
3230         stat->blksize = 1 << inode->i_blkbits;
3231
3232         stat->size = i_size_read(inode);
3233         stat->blocks = inode->i_blocks;
3234
3235         return 0;
3236 }
3237 int ll_getattr(struct vfsmount *mnt, struct dentry *de, struct kstat *stat)
3238 {
3239         struct lookup_intent it = { .it_op = IT_GETATTR };
3240
3241         return ll_getattr_it(mnt, de, &it, stat);
3242 }
3243
3244 int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
3245                 __u64 start, __u64 len)
3246 {
3247         int rc;
3248         size_t num_bytes;
3249         struct ll_user_fiemap *fiemap;
3250         unsigned int extent_count = fieinfo->fi_extents_max;
3251
3252         num_bytes = sizeof(*fiemap) + (extent_count *
3253                                        sizeof(struct ll_fiemap_extent));
3254         OBD_ALLOC_LARGE(fiemap, num_bytes);
3255
3256         if (fiemap == NULL)
3257                 RETURN(-ENOMEM);
3258
3259         fiemap->fm_flags = fieinfo->fi_flags;
3260         fiemap->fm_extent_count = fieinfo->fi_extents_max;
3261         fiemap->fm_start = start;
3262         fiemap->fm_length = len;
3263         memcpy(&fiemap->fm_extents[0], fieinfo->fi_extents_start,
3264                sizeof(struct ll_fiemap_extent));
3265
3266         rc = ll_do_fiemap(inode, fiemap, num_bytes);
3267
3268         fieinfo->fi_flags = fiemap->fm_flags;
3269         fieinfo->fi_extents_mapped = fiemap->fm_mapped_extents;
3270         memcpy(fieinfo->fi_extents_start, &fiemap->fm_extents[0],
3271                fiemap->fm_mapped_extents * sizeof(struct ll_fiemap_extent));
3272
3273         OBD_FREE_LARGE(fiemap, num_bytes);
3274         return rc;
3275 }
3276
3277 struct posix_acl * ll_get_acl(struct inode *inode, int type)
3278 {
3279         struct ll_inode_info *lli = ll_i2info(inode);
3280         struct posix_acl *acl = NULL;
3281         ENTRY;
3282
3283         spin_lock(&lli->lli_lock);
3284         /* VFS' acl_permission_check->check_acl will release the refcount */
3285         acl = posix_acl_dup(lli->lli_posix_acl);
3286         spin_unlock(&lli->lli_lock);
3287
3288         RETURN(acl);
3289 }
3290
3291 #ifndef HAVE_GENERIC_PERMISSION_2ARGS
3292 static int
3293 # ifdef HAVE_GENERIC_PERMISSION_4ARGS
3294 ll_check_acl(struct inode *inode, int mask, unsigned int flags)
3295 # else
3296 ll_check_acl(struct inode *inode, int mask)
3297 # endif
3298 {
3299 # ifdef CONFIG_FS_POSIX_ACL
3300         struct posix_acl *acl;
3301         int rc;