Whamcloud - gitweb
af8869396a2ef1dbab205dd25336cdebdbc0a84f
[fs/lustre-release.git] / lustre / llite / file.c
1 /* -*- mode: c; c-basic-offset: 8; indent-tabs-mode: nil; -*-
2  * vim:expandtab:shiftwidth=8:tabstop=8:
3  *
4  * GPL HEADER START
5  *
6  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License version 2 only,
10  * as published by the Free Software Foundation.
11  *
12  * This program is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * General Public License version 2 for more details (a copy is included
16  * in the LICENSE file that accompanied this code).
17  *
18  * You should have received a copy of the GNU General Public License
19  * version 2 along with this program; If not, see
20  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
21  *
22  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
23  * CA 95054 USA or visit www.sun.com if you need additional information or
24  * have any questions.
25  *
26  * GPL HEADER END
27  */
28 /*
29  * Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved.
30  * Use is subject to license terms.
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 <lustre_mdc.h>
47 #include <linux/pagemap.h>
48 #include <linux/file.h>
49 #include "llite_internal.h"
50 #include <lustre/ll_fiemap.h>
51
52 #include "cl_object.h"
53
54 struct ll_file_data *ll_file_data_get(void)
55 {
56         struct ll_file_data *fd;
57
58         OBD_SLAB_ALLOC_PTR_GFP(fd, ll_file_data_slab, CFS_ALLOC_IO);
59         return fd;
60 }
61
62 static void ll_file_data_put(struct ll_file_data *fd)
63 {
64         if (fd != NULL)
65                 OBD_SLAB_FREE_PTR(fd, ll_file_data_slab);
66 }
67
68 void ll_pack_inode2opdata(struct inode *inode, struct md_op_data *op_data,
69                           struct lustre_handle *fh)
70 {
71         op_data->op_fid1 = ll_i2info(inode)->lli_fid;
72         op_data->op_attr.ia_mode = inode->i_mode;
73         op_data->op_attr.ia_atime = inode->i_atime;
74         op_data->op_attr.ia_mtime = inode->i_mtime;
75         op_data->op_attr.ia_ctime = inode->i_ctime;
76         op_data->op_attr.ia_size = i_size_read(inode);
77         op_data->op_attr_blocks = inode->i_blocks;
78         ((struct ll_iattr *)&op_data->op_attr)->ia_attr_flags =
79                                         ll_inode_to_ext_flags(inode->i_flags);
80         op_data->op_ioepoch = ll_i2info(inode)->lli_ioepoch;
81         if (fh)
82                 op_data->op_handle = *fh;
83         op_data->op_capa1 = ll_mdscapa_get(inode);
84 }
85
86 /**
87  * Closes the IO epoch and packs all the attributes into @op_data for
88  * the CLOSE rpc.
89  */
90 static void ll_prepare_close(struct inode *inode, struct md_op_data *op_data,
91                              struct obd_client_handle *och)
92 {
93         ENTRY;
94
95         op_data->op_attr.ia_valid = ATTR_MODE | ATTR_ATIME_SET |
96                                  ATTR_MTIME_SET | ATTR_CTIME_SET;
97
98         if (!(och->och_flags & FMODE_WRITE))
99                 goto out;
100
101         if (!exp_connect_som(ll_i2mdexp(inode)) || !S_ISREG(inode->i_mode))
102                 op_data->op_attr.ia_valid |= ATTR_SIZE | ATTR_BLOCKS;
103         else
104                 ll_ioepoch_close(inode, op_data, &och, 0);
105
106 out:
107         ll_pack_inode2opdata(inode, op_data, &och->och_fh);
108         ll_prep_md_op_data(op_data, inode, NULL, NULL,
109                            0, 0, LUSTRE_OPC_ANY, NULL);
110         EXIT;
111 }
112
113 static int ll_close_inode_openhandle(struct obd_export *md_exp,
114                                      struct inode *inode,
115                                      struct obd_client_handle *och)
116 {
117         struct obd_export *exp = ll_i2mdexp(inode);
118         struct md_op_data *op_data;
119         struct ptlrpc_request *req = NULL;
120         struct obd_device *obd = class_exp2obd(exp);
121         int epoch_close = 1;
122         int rc;
123         ENTRY;
124
125         if (obd == NULL) {
126                 /*
127                  * XXX: in case of LMV, is this correct to access
128                  * ->exp_handle?
129                  */
130                 CERROR("Invalid MDC connection handle "LPX64"\n",
131                        ll_i2mdexp(inode)->exp_handle.h_cookie);
132                 GOTO(out, rc = 0);
133         }
134
135         OBD_ALLOC_PTR(op_data);
136         if (op_data == NULL)
137                 GOTO(out, rc = -ENOMEM); // XXX We leak openhandle and request here.
138
139         ll_prepare_close(inode, op_data, och);
140         epoch_close = (op_data->op_flags & MF_EPOCH_CLOSE);
141         rc = md_close(md_exp, op_data, och->och_mod, &req);
142         if (rc == -EAGAIN) {
143                 /* This close must have the epoch closed. */
144                 LASSERT(epoch_close);
145                 /* MDS has instructed us to obtain Size-on-MDS attribute from
146                  * OSTs and send setattr to back to MDS. */
147                 rc = ll_som_update(inode, op_data);
148                 if (rc) {
149                         CERROR("inode %lu mdc Size-on-MDS update failed: "
150                                "rc = %d\n", inode->i_ino, rc);
151                         rc = 0;
152                 }
153         } else if (rc) {
154                 CERROR("inode %lu mdc close failed: rc = %d\n",
155                        inode->i_ino, rc);
156         }
157         ll_finish_md_op_data(op_data);
158
159         if (rc == 0) {
160                 rc = ll_objects_destroy(req, inode);
161                 if (rc)
162                         CERROR("inode %lu ll_objects destroy: rc = %d\n",
163                                inode->i_ino, rc);
164         }
165
166         EXIT;
167 out:
168
169         if (exp_connect_som(exp) && !epoch_close &&
170             S_ISREG(inode->i_mode) && (och->och_flags & FMODE_WRITE)) {
171                 ll_queue_done_writing(inode, LLIF_DONE_WRITING);
172         } else {
173                 md_clear_open_replay_data(md_exp, och);
174                 /* Free @och if it is not waiting for DONE_WRITING. */
175                 och->och_fh.cookie = DEAD_HANDLE_MAGIC;
176                 OBD_FREE_PTR(och);
177         }
178         if (req) /* This is close request */
179                 ptlrpc_req_finished(req);
180         return rc;
181 }
182
183 int ll_md_real_close(struct inode *inode, int flags)
184 {
185         struct ll_inode_info *lli = ll_i2info(inode);
186         struct obd_client_handle **och_p;
187         struct obd_client_handle *och;
188         __u64 *och_usecount;
189         int rc = 0;
190         ENTRY;
191
192         if (flags & FMODE_WRITE) {
193                 och_p = &lli->lli_mds_write_och;
194                 och_usecount = &lli->lli_open_fd_write_count;
195         } else if (flags & FMODE_EXEC) {
196                 och_p = &lli->lli_mds_exec_och;
197                 och_usecount = &lli->lli_open_fd_exec_count;
198         } else {
199                 LASSERT(flags & FMODE_READ);
200                 och_p = &lli->lli_mds_read_och;
201                 och_usecount = &lli->lli_open_fd_read_count;
202         }
203
204         cfs_down(&lli->lli_och_sem);
205         if (*och_usecount) { /* There are still users of this handle, so
206                                 skip freeing it. */
207                 cfs_up(&lli->lli_och_sem);
208                 RETURN(0);
209         }
210         och=*och_p;
211         *och_p = NULL;
212         cfs_up(&lli->lli_och_sem);
213
214         if (och) { /* There might be a race and somebody have freed this och
215                       already */
216                 rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp,
217                                                inode, och);
218         }
219
220         RETURN(rc);
221 }
222
223 int ll_md_close(struct obd_export *md_exp, struct inode *inode,
224                 struct file *file)
225 {
226         struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
227         struct ll_inode_info *lli = ll_i2info(inode);
228         int rc = 0;
229         ENTRY;
230
231         /* clear group lock, if present */
232         if (unlikely(fd->fd_flags & LL_FILE_GROUP_LOCKED))
233                 ll_put_grouplock(inode, file, fd->fd_grouplock.cg_gid);
234
235         /* Let's see if we have good enough OPEN lock on the file and if
236            we can skip talking to MDS */
237         if (file->f_dentry->d_inode) { /* Can this ever be false? */
238                 int lockmode;
239                 int flags = LDLM_FL_BLOCK_GRANTED | LDLM_FL_TEST_LOCK;
240                 struct lustre_handle lockh;
241                 struct inode *inode = file->f_dentry->d_inode;
242                 ldlm_policy_data_t policy = {.l_inodebits={MDS_INODELOCK_OPEN}};
243
244                 cfs_down(&lli->lli_och_sem);
245                 if (fd->fd_omode & FMODE_WRITE) {
246                         lockmode = LCK_CW;
247                         LASSERT(lli->lli_open_fd_write_count);
248                         lli->lli_open_fd_write_count--;
249                 } else if (fd->fd_omode & FMODE_EXEC) {
250                         lockmode = LCK_PR;
251                         LASSERT(lli->lli_open_fd_exec_count);
252                         lli->lli_open_fd_exec_count--;
253                 } else {
254                         lockmode = LCK_CR;
255                         LASSERT(lli->lli_open_fd_read_count);
256                         lli->lli_open_fd_read_count--;
257                 }
258                 cfs_up(&lli->lli_och_sem);
259
260                 if (!md_lock_match(md_exp, flags, ll_inode2fid(inode),
261                                    LDLM_IBITS, &policy, lockmode,
262                                    &lockh)) {
263                         rc = ll_md_real_close(file->f_dentry->d_inode,
264                                               fd->fd_omode);
265                 }
266         } else {
267                 CERROR("Releasing a file %p with negative dentry %p. Name %s",
268                        file, file->f_dentry, file->f_dentry->d_name.name);
269         }
270
271         LUSTRE_FPRIVATE(file) = NULL;
272         ll_file_data_put(fd);
273         ll_capa_close(inode);
274
275         RETURN(rc);
276 }
277
278 int lov_test_and_clear_async_rc(struct lov_stripe_md *lsm);
279
280 /* While this returns an error code, fput() the caller does not, so we need
281  * to make every effort to clean up all of our state here.  Also, applications
282  * rarely check close errors and even if an error is returned they will not
283  * re-try the close call.
284  */
285 int ll_file_release(struct inode *inode, struct file *file)
286 {
287         struct ll_file_data *fd;
288         struct ll_sb_info *sbi = ll_i2sbi(inode);
289         struct ll_inode_info *lli = ll_i2info(inode);
290         struct lov_stripe_md *lsm = lli->lli_smd;
291         int rc;
292         ENTRY;
293
294         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p)\n", inode->i_ino,
295                inode->i_generation, inode);
296
297 #ifdef CONFIG_FS_POSIX_ACL
298         if (sbi->ll_flags & LL_SBI_RMT_CLIENT &&
299             inode == inode->i_sb->s_root->d_inode) {
300                 struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
301
302                 LASSERT(fd != NULL);
303                 if (unlikely(fd->fd_flags & LL_FILE_RMTACL)) {
304                         fd->fd_flags &= ~LL_FILE_RMTACL;
305                         rct_del(&sbi->ll_rct, cfs_curproc_pid());
306                         et_search_free(&sbi->ll_et, cfs_curproc_pid());
307                 }
308         }
309 #endif
310
311         if (inode->i_sb->s_root != file->f_dentry)
312                 ll_stats_ops_tally(sbi, LPROC_LL_RELEASE, 1);
313         fd = LUSTRE_FPRIVATE(file);
314         LASSERT(fd != NULL);
315
316         /* The last ref on @file, maybe not the the owner pid of statahead.
317          * Different processes can open the same dir, "ll_opendir_key" means:
318          * it is me that should stop the statahead thread. */
319         if (lli->lli_opendir_key == fd && lli->lli_opendir_pid != 0)
320                 ll_stop_statahead(inode, lli->lli_opendir_key);
321
322         if (inode->i_sb->s_root == file->f_dentry) {
323                 LUSTRE_FPRIVATE(file) = NULL;
324                 ll_file_data_put(fd);
325                 RETURN(0);
326         }
327
328         if (lsm)
329                 lov_test_and_clear_async_rc(lsm);
330         lli->lli_async_rc = 0;
331
332         rc = ll_md_close(sbi->ll_md_exp, inode, file);
333
334         if (OBD_FAIL_TIMEOUT_MS(OBD_FAIL_PTLRPC_DUMP_LOG, obd_fail_val))
335                 libcfs_debug_dumplog();
336
337         RETURN(rc);
338 }
339
340 static int ll_intent_file_open(struct file *file, void *lmm,
341                                int lmmsize, struct lookup_intent *itp)
342 {
343         struct ll_sb_info *sbi = ll_i2sbi(file->f_dentry->d_inode);
344         struct dentry *parent = file->f_dentry->d_parent;
345         const char *name = file->f_dentry->d_name.name;
346         const int len = file->f_dentry->d_name.len;
347         struct md_op_data *op_data;
348         struct ptlrpc_request *req;
349         int rc;
350         ENTRY;
351
352         if (!parent)
353                 RETURN(-ENOENT);
354
355         /* Usually we come here only for NFSD, and we want open lock.
356            But we can also get here with pre 2.6.15 patchless kernels, and in
357            that case that lock is also ok */
358         /* We can also get here if there was cached open handle in revalidate_it
359          * but it disappeared while we were getting from there to ll_file_open.
360          * But this means this file was closed and immediatelly opened which
361          * makes a good candidate for using OPEN lock */
362         /* If lmmsize & lmm are not 0, we are just setting stripe info
363          * parameters. No need for the open lock */
364         if (!lmm && !lmmsize)
365                 itp->it_flags |= MDS_OPEN_LOCK;
366
367         op_data  = ll_prep_md_op_data(NULL, parent->d_inode,
368                                       file->f_dentry->d_inode, name, len,
369                                       O_RDWR, LUSTRE_OPC_ANY, NULL);
370         if (IS_ERR(op_data))
371                 RETURN(PTR_ERR(op_data));
372
373         rc = md_intent_lock(sbi->ll_md_exp, op_data, lmm, lmmsize, itp,
374                             0 /*unused */, &req, ll_md_blocking_ast, 0);
375         ll_finish_md_op_data(op_data);
376         if (rc == -ESTALE) {
377                 /* reason for keep own exit path - don`t flood log
378                 * with messages with -ESTALE errors.
379                 */
380                 if (!it_disposition(itp, DISP_OPEN_OPEN) ||
381                      it_open_error(DISP_OPEN_OPEN, itp))
382                         GOTO(out, rc);
383                 ll_release_openhandle(file->f_dentry, itp);
384                 GOTO(out, rc);
385         }
386
387         if (rc != 0 || it_open_error(DISP_OPEN_OPEN, itp)) {
388                 rc = rc ? rc : it_open_error(DISP_OPEN_OPEN, itp);
389                 CDEBUG(D_VFSTRACE, "lock enqueue: err: %d\n", rc);
390                 GOTO(out, rc);
391         }
392
393         rc = ll_prep_inode(&file->f_dentry->d_inode, req, NULL);
394         if (!rc && itp->d.lustre.it_lock_mode)
395                 md_set_lock_data(sbi->ll_md_exp,
396                                  &itp->d.lustre.it_lock_handle,
397                                  file->f_dentry->d_inode, NULL);
398
399 out:
400         ptlrpc_req_finished(itp->d.lustre.it_data);
401         it_clear_disposition(itp, DISP_ENQ_COMPLETE);
402         ll_intent_drop_lock(itp);
403
404         RETURN(rc);
405 }
406
407 /**
408  * Assign an obtained @ioepoch to client's inode. No lock is needed, MDS does
409  * not believe attributes if a few ioepoch holders exist. Attributes for
410  * previous ioepoch if new one is opened are also skipped by MDS.
411  */
412 void ll_ioepoch_open(struct ll_inode_info *lli, __u64 ioepoch)
413 {
414         if (ioepoch && lli->lli_ioepoch != ioepoch) {
415                 lli->lli_ioepoch = ioepoch;
416                 CDEBUG(D_INODE, "Epoch "LPU64" opened on "DFID"\n",
417                        ioepoch, PFID(&lli->lli_fid));
418         }
419 }
420
421 static int ll_och_fill(struct obd_export *md_exp, struct ll_inode_info *lli,
422                        struct lookup_intent *it, struct obd_client_handle *och)
423 {
424         struct ptlrpc_request *req = it->d.lustre.it_data;
425         struct mdt_body *body;
426
427         LASSERT(och);
428
429         body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
430         LASSERT(body != NULL);                      /* reply already checked out */
431
432         memcpy(&och->och_fh, &body->handle, sizeof(body->handle));
433         och->och_magic = OBD_CLIENT_HANDLE_MAGIC;
434         och->och_fid = lli->lli_fid;
435         och->och_flags = it->it_flags;
436         ll_ioepoch_open(lli, body->ioepoch);
437
438         return md_set_open_replay_data(md_exp, och, req);
439 }
440
441 int ll_local_open(struct file *file, struct lookup_intent *it,
442                   struct ll_file_data *fd, struct obd_client_handle *och)
443 {
444         struct inode *inode = file->f_dentry->d_inode;
445         struct ll_inode_info *lli = ll_i2info(inode);
446         ENTRY;
447
448         LASSERT(!LUSTRE_FPRIVATE(file));
449
450         LASSERT(fd != NULL);
451
452         if (och) {
453                 struct ptlrpc_request *req = it->d.lustre.it_data;
454                 struct mdt_body *body;
455                 int rc;
456
457                 rc = ll_och_fill(ll_i2sbi(inode)->ll_md_exp, lli, it, och);
458                 if (rc)
459                         RETURN(rc);
460
461                 body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
462                 if ((it->it_flags & FMODE_WRITE) &&
463                     (body->valid & OBD_MD_FLSIZE))
464                         CDEBUG(D_INODE, "Epoch "LPU64" opened on "DFID"\n",
465                                lli->lli_ioepoch, PFID(&lli->lli_fid));
466         }
467
468         LUSTRE_FPRIVATE(file) = fd;
469         ll_readahead_init(inode, &fd->fd_ras);
470         fd->fd_omode = it->it_flags;
471         RETURN(0);
472 }
473
474 /* Open a file, and (for the very first open) create objects on the OSTs at
475  * this time.  If opened with O_LOV_DELAY_CREATE, then we don't do the object
476  * creation or open until ll_lov_setstripe() ioctl is called.  We grab
477  * lli_open_sem to ensure no other process will create objects, send the
478  * stripe MD to the MDS, or try to destroy the objects if that fails.
479  *
480  * If we already have the stripe MD locally then we don't request it in
481  * md_open(), by passing a lmm_size = 0.
482  *
483  * It is up to the application to ensure no other processes open this file
484  * in the O_LOV_DELAY_CREATE case, or the default striping pattern will be
485  * used.  We might be able to avoid races of that sort by getting lli_open_sem
486  * before returning in the O_LOV_DELAY_CREATE case and dropping it here
487  * or in ll_file_release(), but I'm not sure that is desirable/necessary.
488  */
489 int ll_file_open(struct inode *inode, struct file *file)
490 {
491         struct ll_inode_info *lli = ll_i2info(inode);
492         struct lookup_intent *it, oit = { .it_op = IT_OPEN,
493                                           .it_flags = file->f_flags };
494         struct lov_stripe_md *lsm;
495         struct ptlrpc_request *req = NULL;
496         struct obd_client_handle **och_p;
497         __u64 *och_usecount;
498         struct ll_file_data *fd;
499         int rc = 0, opendir_set = 0;
500         ENTRY;
501
502         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p), flags %o\n", inode->i_ino,
503                inode->i_generation, inode, file->f_flags);
504
505 #ifdef HAVE_VFS_INTENT_PATCHES
506         it = file->f_it;
507 #else
508         it = file->private_data; /* XXX: compat macro */
509         file->private_data = NULL; /* prevent ll_local_open assertion */
510 #endif
511
512         fd = ll_file_data_get();
513         if (fd == NULL)
514                 RETURN(-ENOMEM);
515
516         fd->fd_file = file;
517         if (S_ISDIR(inode->i_mode)) {
518                 cfs_spin_lock(&lli->lli_sa_lock);
519                 if (lli->lli_opendir_key == NULL && lli->lli_opendir_pid == 0) {
520                         LASSERT(lli->lli_sai == NULL);
521                         lli->lli_opendir_key = fd;
522                         lli->lli_opendir_pid = cfs_curproc_pid();
523                         opendir_set = 1;
524                 }
525                 cfs_spin_unlock(&lli->lli_sa_lock);
526         }
527
528         if (inode->i_sb->s_root == file->f_dentry) {
529                 LUSTRE_FPRIVATE(file) = fd;
530                 RETURN(0);
531         }
532
533         if (!it || !it->d.lustre.it_disposition) {
534                 /* Convert f_flags into access mode. We cannot use file->f_mode,
535                  * because everything but O_ACCMODE mask was stripped from
536                  * there */
537                 if ((oit.it_flags + 1) & O_ACCMODE)
538                         oit.it_flags++;
539                 if (file->f_flags & O_TRUNC)
540                         oit.it_flags |= FMODE_WRITE;
541
542                 /* kernel only call f_op->open in dentry_open.  filp_open calls
543                  * dentry_open after call to open_namei that checks permissions.
544                  * Only nfsd_open call dentry_open directly without checking
545                  * permissions and because of that this code below is safe. */
546                 if (oit.it_flags & FMODE_WRITE)
547                         oit.it_flags |= MDS_OPEN_OWNEROVERRIDE;
548
549                 /* We do not want O_EXCL here, presumably we opened the file
550                  * already? XXX - NFS implications? */
551                 oit.it_flags &= ~O_EXCL;
552
553                 /* bug20584, if "it_flags" contains O_CREAT, the file will be
554                  * created if necessary, then "IT_CREAT" should be set to keep
555                  * consistent with it */
556                 if (oit.it_flags & O_CREAT)
557                         oit.it_op |= IT_CREAT;
558
559                 it = &oit;
560         }
561
562 restart:
563         /* Let's see if we have file open on MDS already. */
564         if (it->it_flags & FMODE_WRITE) {
565                 och_p = &lli->lli_mds_write_och;
566                 och_usecount = &lli->lli_open_fd_write_count;
567         } else if (it->it_flags & FMODE_EXEC) {
568                 och_p = &lli->lli_mds_exec_och;
569                 och_usecount = &lli->lli_open_fd_exec_count;
570          } else {
571                 och_p = &lli->lli_mds_read_och;
572                 och_usecount = &lli->lli_open_fd_read_count;
573         }
574
575         cfs_down(&lli->lli_och_sem);
576         if (*och_p) { /* Open handle is present */
577                 if (it_disposition(it, DISP_OPEN_OPEN)) {
578                         /* Well, there's extra open request that we do not need,
579                            let's close it somehow. This will decref request. */
580                         rc = it_open_error(DISP_OPEN_OPEN, it);
581                         if (rc) {
582                                 cfs_up(&lli->lli_och_sem);
583                                 ll_file_data_put(fd);
584                                 GOTO(out_openerr, rc);
585                         }
586                         ll_release_openhandle(file->f_dentry, it);
587                         lprocfs_counter_incr(ll_i2sbi(inode)->ll_stats,
588                                              LPROC_LL_OPEN);
589                 }
590                 (*och_usecount)++;
591
592                 rc = ll_local_open(file, it, fd, NULL);
593                 if (rc) {
594                         (*och_usecount)--;
595                         cfs_up(&lli->lli_och_sem);
596                         ll_file_data_put(fd);
597                         GOTO(out_openerr, rc);
598                 }
599         } else {
600                 LASSERT(*och_usecount == 0);
601                 if (!it->d.lustre.it_disposition) {
602                         /* We cannot just request lock handle now, new ELC code
603                            means that one of other OPEN locks for this file
604                            could be cancelled, and since blocking ast handler
605                            would attempt to grab och_sem as well, that would
606                            result in a deadlock */
607                         cfs_up(&lli->lli_och_sem);
608                         it->it_create_mode |= M_CHECK_STALE;
609                         rc = ll_intent_file_open(file, NULL, 0, it);
610                         it->it_create_mode &= ~M_CHECK_STALE;
611                         if (rc) {
612                                 ll_file_data_put(fd);
613                                 GOTO(out_openerr, rc);
614                         }
615
616                         /* Got some error? Release the request */
617                         if (it->d.lustre.it_status < 0) {
618                                 req = it->d.lustre.it_data;
619                                 ptlrpc_req_finished(req);
620                         }
621                         goto restart;
622                 }
623                 OBD_ALLOC(*och_p, sizeof (struct obd_client_handle));
624                 if (!*och_p) {
625                         ll_file_data_put(fd);
626                         GOTO(out_och_free, rc = -ENOMEM);
627                 }
628                 (*och_usecount)++;
629                 req = it->d.lustre.it_data;
630
631                 /* md_intent_lock() didn't get a request ref if there was an
632                  * open error, so don't do cleanup on the request here
633                  * (bug 3430) */
634                 /* XXX (green): Should not we bail out on any error here, not
635                  * just open error? */
636                 rc = it_open_error(DISP_OPEN_OPEN, it);
637                 if (rc) {
638                         ll_file_data_put(fd);
639                         GOTO(out_och_free, rc);
640                 }
641
642                 ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_OPEN, 1);
643                 rc = ll_local_open(file, it, fd, *och_p);
644                 if (rc) {
645                         ll_file_data_put(fd);
646                         GOTO(out_och_free, rc);
647                 }
648         }
649         cfs_up(&lli->lli_och_sem);
650
651         /* Must do this outside lli_och_sem lock to prevent deadlock where
652            different kind of OPEN lock for this same inode gets cancelled
653            by ldlm_cancel_lru */
654         if (!S_ISREG(inode->i_mode))
655                 GOTO(out, rc);
656
657         ll_capa_open(inode);
658
659         lsm = lli->lli_smd;
660         if (lsm == NULL) {
661                 if (file->f_flags & O_LOV_DELAY_CREATE ||
662                     !(file->f_mode & FMODE_WRITE)) {
663                         CDEBUG(D_INODE, "object creation was delayed\n");
664                         GOTO(out, rc);
665                 }
666         }
667         file->f_flags &= ~O_LOV_DELAY_CREATE;
668         GOTO(out, rc);
669 out:
670         ptlrpc_req_finished(req);
671         if (req)
672                 it_clear_disposition(it, DISP_ENQ_OPEN_REF);
673 out_och_free:
674         if (rc) {
675                 if (*och_p) {
676                         OBD_FREE(*och_p, sizeof (struct obd_client_handle));
677                         *och_p = NULL; /* OBD_FREE writes some magic there */
678                         (*och_usecount)--;
679                 }
680                 cfs_up(&lli->lli_och_sem);
681 out_openerr:
682                 if (opendir_set != 0)
683                         ll_stop_statahead(inode, lli->lli_opendir_key);
684         }
685
686         return rc;
687 }
688
689 /* Fills the obdo with the attributes for the lsm */
690 static int ll_lsm_getattr(struct lov_stripe_md *lsm, struct obd_export *exp,
691                           struct obd_capa *capa, struct obdo *obdo,
692                           __u64 ioepoch, int sync)
693 {
694         struct ptlrpc_request_set *set;
695         struct obd_info            oinfo = { { { 0 } } };
696         int                        rc;
697
698         ENTRY;
699
700         LASSERT(lsm != NULL);
701
702         oinfo.oi_md = lsm;
703         oinfo.oi_oa = obdo;
704         oinfo.oi_oa->o_id = lsm->lsm_object_id;
705         oinfo.oi_oa->o_seq = lsm->lsm_object_seq;
706         oinfo.oi_oa->o_mode = S_IFREG;
707         oinfo.oi_oa->o_ioepoch = ioepoch;
708         oinfo.oi_oa->o_valid = OBD_MD_FLID | OBD_MD_FLTYPE |
709                                OBD_MD_FLSIZE | OBD_MD_FLBLOCKS |
710                                OBD_MD_FLBLKSZ | OBD_MD_FLATIME |
711                                OBD_MD_FLMTIME | OBD_MD_FLCTIME |
712                                OBD_MD_FLGROUP | OBD_MD_FLEPOCH;
713         oinfo.oi_capa = capa;
714         if (sync) {
715                 oinfo.oi_oa->o_valid |= OBD_MD_FLFLAGS;
716                 oinfo.oi_oa->o_flags |= OBD_FL_SRVLOCK;
717         }
718
719         set = ptlrpc_prep_set();
720         if (set == NULL) {
721                 CERROR("can't allocate ptlrpc set\n");
722                 rc = -ENOMEM;
723         } else {
724                 rc = obd_getattr_async(exp, &oinfo, set);
725                 if (rc == 0)
726                         rc = ptlrpc_set_wait(set);
727                 ptlrpc_set_destroy(set);
728         }
729         if (rc == 0)
730                 oinfo.oi_oa->o_valid &= (OBD_MD_FLBLOCKS | OBD_MD_FLBLKSZ |
731                                          OBD_MD_FLATIME | OBD_MD_FLMTIME |
732                                          OBD_MD_FLCTIME | OBD_MD_FLSIZE);
733         RETURN(rc);
734 }
735
736 /**
737   * Performs the getattr on the inode and updates its fields.
738   * If @sync != 0, perform the getattr under the server-side lock.
739   */
740 int ll_inode_getattr(struct inode *inode, struct obdo *obdo,
741                      __u64 ioepoch, int sync)
742 {
743         struct ll_inode_info *lli  = ll_i2info(inode);
744         struct obd_capa      *capa = ll_mdscapa_get(inode);
745         int rc;
746         ENTRY;
747
748         rc = ll_lsm_getattr(lli->lli_smd, ll_i2dtexp(inode),
749                             capa, obdo, ioepoch, sync);
750         capa_put(capa);
751         if (rc == 0) {
752                 obdo_refresh_inode(inode, obdo, obdo->o_valid);
753                 CDEBUG(D_INODE,
754                        "objid "LPX64" size %Lu, blocks %llu, blksize %lu\n",
755                        lli->lli_smd->lsm_object_id, i_size_read(inode),
756                        (unsigned long long)inode->i_blocks,
757                        (unsigned long)ll_inode_blksize(inode));
758         }
759         RETURN(rc);
760 }
761
762 int ll_merge_lvb(struct inode *inode)
763 {
764         struct ll_inode_info *lli = ll_i2info(inode);
765         struct ll_sb_info *sbi = ll_i2sbi(inode);
766         struct ost_lvb lvb;
767         int rc;
768
769         ENTRY;
770
771         ll_inode_size_lock(inode, 1);
772         inode_init_lvb(inode, &lvb);
773
774         /* merge timestamps the most resently obtained from mds with
775            timestamps obtained from osts */
776         lvb.lvb_atime = lli->lli_lvb.lvb_atime;
777         lvb.lvb_mtime = lli->lli_lvb.lvb_mtime;
778         lvb.lvb_ctime = lli->lli_lvb.lvb_ctime;
779         rc = obd_merge_lvb(sbi->ll_dt_exp, lli->lli_smd, &lvb, 0);
780         cl_isize_write_nolock(inode, lvb.lvb_size);
781
782         CDEBUG(D_VFSTRACE, DFID" updating i_size "LPU64"\n",
783                PFID(&lli->lli_fid), lvb.lvb_size);
784         inode->i_blocks = lvb.lvb_blocks;
785
786         LTIME_S(inode->i_mtime) = lvb.lvb_mtime;
787         LTIME_S(inode->i_atime) = lvb.lvb_atime;
788         LTIME_S(inode->i_ctime) = lvb.lvb_ctime;
789         ll_inode_size_unlock(inode, 1);
790
791         RETURN(rc);
792 }
793
794 int ll_glimpse_ioctl(struct ll_sb_info *sbi, struct lov_stripe_md *lsm,
795                      lstat_t *st)
796 {
797         struct obdo obdo = { 0 };
798         int rc;
799
800         rc = ll_lsm_getattr(lsm, sbi->ll_dt_exp, NULL, &obdo, 0, 0);
801         if (rc == 0) {
802                 st->st_size   = obdo.o_size;
803                 st->st_blocks = obdo.o_blocks;
804                 st->st_mtime  = obdo.o_mtime;
805                 st->st_atime  = obdo.o_atime;
806                 st->st_ctime  = obdo.o_ctime;
807         }
808         return rc;
809 }
810
811 void ll_io_init(struct cl_io *io, const struct file *file, int write)
812 {
813         struct inode *inode = file->f_dentry->d_inode;
814
815         memset(io, 0, sizeof *io);
816         io->u.ci_rw.crw_nonblock = file->f_flags & O_NONBLOCK;
817         if (write)
818                 io->u.ci_wr.wr_append = !!(file->f_flags & O_APPEND);
819         io->ci_obj     = ll_i2info(inode)->lli_clob;
820         io->ci_lockreq = CILR_MAYBE;
821         if (ll_file_nolock(file)) {
822                 io->ci_lockreq = CILR_NEVER;
823                 io->ci_no_srvlock = 1;
824         } else if (file->f_flags & O_APPEND) {
825                 io->ci_lockreq = CILR_MANDATORY;
826         }
827 }
828
829 static ssize_t ll_file_io_generic(const struct lu_env *env,
830                 struct vvp_io_args *args, struct file *file,
831                 enum cl_io_type iot, loff_t *ppos, size_t count)
832 {
833         struct cl_io       *io;
834         ssize_t             result;
835         ENTRY;
836
837         io = &ccc_env_info(env)->cti_io;
838         ll_io_init(io, file, iot == CIT_WRITE);
839
840         if (cl_io_rw_init(env, io, iot, *ppos, count) == 0) {
841                 struct vvp_io *vio = vvp_env_io(env);
842                 struct ccc_io *cio = ccc_env_io(env);
843                 struct ll_inode_info *lli = ll_i2info(file->f_dentry->d_inode);
844                 int write_sem_locked = 0;
845
846                 cio->cui_fd  = LUSTRE_FPRIVATE(file);
847                 vio->cui_io_subtype = args->via_io_subtype;
848
849                 switch (vio->cui_io_subtype) {
850                 case IO_NORMAL:
851                         cio->cui_iov = args->u.normal.via_iov;
852                         cio->cui_nrsegs = args->u.normal.via_nrsegs;
853                         cio->cui_tot_nrsegs = cio->cui_nrsegs;
854 #ifndef HAVE_FILE_WRITEV
855                         cio->cui_iocb = args->u.normal.via_iocb;
856 #endif
857                         if ((iot == CIT_WRITE) &&
858                             !(cio->cui_fd->fd_flags & LL_FILE_GROUP_LOCKED)) {
859                                 cfs_down(&lli->lli_write_sem);
860                                 write_sem_locked = 1;
861                         }
862                         break;
863                 case IO_SENDFILE:
864                         vio->u.sendfile.cui_actor = args->u.sendfile.via_actor;
865                         vio->u.sendfile.cui_target = args->u.sendfile.via_target;
866                         break;
867                 case IO_SPLICE:
868                         vio->u.splice.cui_pipe = args->u.splice.via_pipe;
869                         vio->u.splice.cui_flags = args->u.splice.via_flags;
870                         break;
871                 default:
872                         CERROR("Unknow IO type - %u\n", vio->cui_io_subtype);
873                         LBUG();
874                 }
875                 result = cl_io_loop(env, io);
876                 if (write_sem_locked)
877                         cfs_up(&lli->lli_write_sem);
878         } else {
879                 /* cl_io_rw_init() handled IO */
880                 result = io->ci_result;
881         }
882
883         if (io->ci_nob > 0) {
884                 result = io->ci_nob;
885                 *ppos = io->u.ci_wr.wr.crw_pos;
886         }
887         cl_io_fini(env, io);
888         RETURN(result);
889 }
890
891
892 /*
893  * XXX: exact copy from kernel code (__generic_file_aio_write_nolock)
894  */
895 static int ll_file_get_iov_count(const struct iovec *iov,
896                                  unsigned long *nr_segs, size_t *count)
897 {
898         size_t cnt = 0;
899         unsigned long seg;
900
901         for (seg = 0; seg < *nr_segs; seg++) {
902                 const struct iovec *iv = &iov[seg];
903
904                 /*
905                  * If any segment has a negative length, or the cumulative
906                  * length ever wraps negative then return -EINVAL.
907                  */
908                 cnt += iv->iov_len;
909                 if (unlikely((ssize_t)(cnt|iv->iov_len) < 0))
910                         return -EINVAL;
911                 if (access_ok(VERIFY_READ, iv->iov_base, iv->iov_len))
912                         continue;
913                 if (seg == 0)
914                         return -EFAULT;
915                 *nr_segs = seg;
916                 cnt -= iv->iov_len;   /* This segment is no good */
917                 break;
918         }
919         *count = cnt;
920         return 0;
921 }
922
923 #ifdef HAVE_FILE_READV
924 static ssize_t ll_file_readv(struct file *file, const struct iovec *iov,
925                               unsigned long nr_segs, loff_t *ppos)
926 {
927         struct lu_env      *env;
928         struct vvp_io_args *args;
929         size_t              count;
930         ssize_t             result;
931         int                 refcheck;
932         ENTRY;
933
934         result = ll_file_get_iov_count(iov, &nr_segs, &count);
935         if (result)
936                 RETURN(result);
937
938         env = cl_env_get(&refcheck);
939         if (IS_ERR(env))
940                 RETURN(PTR_ERR(env));
941
942         args = vvp_env_args(env, IO_NORMAL);
943         args->u.normal.via_iov = (struct iovec *)iov;
944         args->u.normal.via_nrsegs = nr_segs;
945
946         result = ll_file_io_generic(env, args, file, CIT_READ, ppos, count);
947         cl_env_put(env, &refcheck);
948         RETURN(result);
949 }
950
951 static ssize_t ll_file_read(struct file *file, char *buf, size_t count,
952                             loff_t *ppos)
953 {
954         struct lu_env *env;
955         struct iovec  *local_iov;
956         ssize_t        result;
957         int            refcheck;
958         ENTRY;
959
960         env = cl_env_get(&refcheck);
961         if (IS_ERR(env))
962                 RETURN(PTR_ERR(env));
963
964         local_iov = &vvp_env_info(env)->vti_local_iov;
965         local_iov->iov_base = (void __user *)buf;
966         local_iov->iov_len = count;
967         result = ll_file_readv(file, local_iov, 1, ppos);
968         cl_env_put(env, &refcheck);
969         RETURN(result);
970 }
971
972 #else
973 static ssize_t ll_file_aio_read(struct kiocb *iocb, const struct iovec *iov,
974                                 unsigned long nr_segs, loff_t pos)
975 {
976         struct lu_env      *env;
977         struct vvp_io_args *args;
978         size_t              count;
979         ssize_t             result;
980         int                 refcheck;
981         ENTRY;
982
983         result = ll_file_get_iov_count(iov, &nr_segs, &count);
984         if (result)
985                 RETURN(result);
986
987         env = cl_env_get(&refcheck);
988         if (IS_ERR(env))
989                 RETURN(PTR_ERR(env));
990
991         args = vvp_env_args(env, IO_NORMAL);
992         args->u.normal.via_iov = (struct iovec *)iov;
993         args->u.normal.via_nrsegs = nr_segs;
994         args->u.normal.via_iocb = iocb;
995
996         result = ll_file_io_generic(env, args, iocb->ki_filp, CIT_READ,
997                                     &iocb->ki_pos, count);
998         cl_env_put(env, &refcheck);
999         RETURN(result);
1000 }
1001
1002 static ssize_t ll_file_read(struct file *file, char *buf, size_t count,
1003                             loff_t *ppos)
1004 {
1005         struct lu_env *env;
1006         struct iovec  *local_iov;
1007         struct kiocb  *kiocb;
1008         ssize_t        result;
1009         int            refcheck;
1010         ENTRY;
1011
1012         env = cl_env_get(&refcheck);
1013         if (IS_ERR(env))
1014                 RETURN(PTR_ERR(env));
1015
1016         local_iov = &vvp_env_info(env)->vti_local_iov;
1017         kiocb = &vvp_env_info(env)->vti_kiocb;
1018         local_iov->iov_base = (void __user *)buf;
1019         local_iov->iov_len = count;
1020         init_sync_kiocb(kiocb, file);
1021         kiocb->ki_pos = *ppos;
1022         kiocb->ki_left = count;
1023
1024         result = ll_file_aio_read(kiocb, local_iov, 1, kiocb->ki_pos);
1025         *ppos = kiocb->ki_pos;
1026
1027         cl_env_put(env, &refcheck);
1028         RETURN(result);
1029 }
1030 #endif
1031
1032 /*
1033  * Write to a file (through the page cache).
1034  */
1035 #ifdef HAVE_FILE_WRITEV
1036 static ssize_t ll_file_writev(struct file *file, const struct iovec *iov,
1037                               unsigned long nr_segs, loff_t *ppos)
1038 {
1039         struct lu_env      *env;
1040         struct vvp_io_args *args;
1041         size_t              count;
1042         ssize_t             result;
1043         int                 refcheck;
1044         ENTRY;
1045
1046         result = ll_file_get_iov_count(iov, &nr_segs, &count);
1047         if (result)
1048                 RETURN(result);
1049
1050         env = cl_env_get(&refcheck);
1051         if (IS_ERR(env))
1052                 RETURN(PTR_ERR(env));
1053
1054         args = vvp_env_args(env, IO_NORMAL);
1055         args->u.normal.via_iov = (struct iovec *)iov;
1056         args->u.normal.via_nrsegs = nr_segs;
1057
1058         result = ll_file_io_generic(env, args, file, CIT_WRITE, ppos, count);
1059         cl_env_put(env, &refcheck);
1060         RETURN(result);
1061 }
1062
1063 static ssize_t ll_file_write(struct file *file, const char *buf, size_t count,
1064                              loff_t *ppos)
1065 {
1066         struct lu_env    *env;
1067         struct iovec     *local_iov;
1068         ssize_t           result;
1069         int               refcheck;
1070         ENTRY;
1071
1072         env = cl_env_get(&refcheck);
1073         if (IS_ERR(env))
1074                 RETURN(PTR_ERR(env));
1075
1076         local_iov = &vvp_env_info(env)->vti_local_iov;
1077         local_iov->iov_base = (void __user *)buf;
1078         local_iov->iov_len = count;
1079
1080         result = ll_file_writev(file, local_iov, 1, ppos);
1081         cl_env_put(env, &refcheck);
1082         RETURN(result);
1083 }
1084
1085 #else /* AIO stuff */
1086 static ssize_t ll_file_aio_write(struct kiocb *iocb, const struct iovec *iov,
1087                                  unsigned long nr_segs, loff_t pos)
1088 {
1089         struct lu_env      *env;
1090         struct vvp_io_args *args;
1091         size_t              count;
1092         ssize_t             result;
1093         int                 refcheck;
1094         ENTRY;
1095
1096         result = ll_file_get_iov_count(iov, &nr_segs, &count);
1097         if (result)
1098                 RETURN(result);
1099
1100         env = cl_env_get(&refcheck);
1101         if (IS_ERR(env))
1102                 RETURN(PTR_ERR(env));
1103
1104         args = vvp_env_args(env, IO_NORMAL);
1105         args->u.normal.via_iov = (struct iovec *)iov;
1106         args->u.normal.via_nrsegs = nr_segs;
1107         args->u.normal.via_iocb = iocb;
1108
1109         result = ll_file_io_generic(env, args, iocb->ki_filp, CIT_WRITE,
1110                                   &iocb->ki_pos, count);
1111         cl_env_put(env, &refcheck);
1112         RETURN(result);
1113 }
1114
1115 static ssize_t ll_file_write(struct file *file, const char *buf, size_t count,
1116                              loff_t *ppos)
1117 {
1118         struct lu_env *env;
1119         struct iovec  *local_iov;
1120         struct kiocb  *kiocb;
1121         ssize_t        result;
1122         int            refcheck;
1123         ENTRY;
1124
1125         env = cl_env_get(&refcheck);
1126         if (IS_ERR(env))
1127                 RETURN(PTR_ERR(env));
1128
1129         local_iov = &vvp_env_info(env)->vti_local_iov;
1130         kiocb = &vvp_env_info(env)->vti_kiocb;
1131         local_iov->iov_base = (void __user *)buf;
1132         local_iov->iov_len = count;
1133         init_sync_kiocb(kiocb, file);
1134         kiocb->ki_pos = *ppos;
1135         kiocb->ki_left = count;
1136
1137         result = ll_file_aio_write(kiocb, local_iov, 1, kiocb->ki_pos);
1138         *ppos = kiocb->ki_pos;
1139
1140         cl_env_put(env, &refcheck);
1141         RETURN(result);
1142 }
1143 #endif
1144
1145
1146 #ifdef HAVE_KERNEL_SENDFILE
1147 /*
1148  * Send file content (through pagecache) somewhere with helper
1149  */
1150 static ssize_t ll_file_sendfile(struct file *in_file, loff_t *ppos,size_t count,
1151                                 read_actor_t actor, void *target)
1152 {
1153         struct lu_env      *env;
1154         struct vvp_io_args *args;
1155         ssize_t             result;
1156         int                 refcheck;
1157         ENTRY;
1158
1159         env = cl_env_get(&refcheck);
1160         if (IS_ERR(env))
1161                 RETURN(PTR_ERR(env));
1162
1163         args = vvp_env_args(env, IO_SENDFILE);
1164         args->u.sendfile.via_target = target;
1165         args->u.sendfile.via_actor = actor;
1166
1167         result = ll_file_io_generic(env, args, in_file, CIT_READ, ppos, count);
1168         cl_env_put(env, &refcheck);
1169         RETURN(result);
1170 }
1171 #endif
1172
1173 #ifdef HAVE_KERNEL_SPLICE_READ
1174 /*
1175  * Send file content (through pagecache) somewhere with helper
1176  */
1177 static ssize_t ll_file_splice_read(struct file *in_file, loff_t *ppos,
1178                                    struct pipe_inode_info *pipe, size_t count,
1179                                    unsigned int flags)
1180 {
1181         struct lu_env      *env;
1182         struct vvp_io_args *args;
1183         ssize_t             result;
1184         int                 refcheck;
1185         ENTRY;
1186
1187         env = cl_env_get(&refcheck);
1188         if (IS_ERR(env))
1189                 RETURN(PTR_ERR(env));
1190
1191         args = vvp_env_args(env, IO_SPLICE);
1192         args->u.splice.via_pipe = pipe;
1193         args->u.splice.via_flags = flags;
1194
1195         result = ll_file_io_generic(env, args, in_file, CIT_READ, ppos, count);
1196         cl_env_put(env, &refcheck);
1197         RETURN(result);
1198 }
1199 #endif
1200
1201 static int ll_lov_recreate_obj(struct inode *inode, struct file *file,
1202                                unsigned long arg)
1203 {
1204         struct obd_export *exp = ll_i2dtexp(inode);
1205         struct ll_recreate_obj ucreatp;
1206         struct obd_trans_info oti = { 0 };
1207         struct obdo *oa = NULL;
1208         int lsm_size;
1209         int rc = 0;
1210         struct lov_stripe_md *lsm, *lsm2;
1211         ENTRY;
1212
1213         if (!cfs_capable(CFS_CAP_SYS_ADMIN))
1214                 RETURN(-EPERM);
1215
1216         if (cfs_copy_from_user(&ucreatp, (struct ll_recreate_obj *)arg,
1217                                sizeof(struct ll_recreate_obj)))
1218                 RETURN(-EFAULT);
1219
1220         OBDO_ALLOC(oa);
1221         if (oa == NULL)
1222                 RETURN(-ENOMEM);
1223
1224         ll_inode_size_lock(inode, 0);
1225         lsm = ll_i2info(inode)->lli_smd;
1226         if (lsm == NULL)
1227                 GOTO(out, rc = -ENOENT);
1228         lsm_size = sizeof(*lsm) + (sizeof(struct lov_oinfo) *
1229                    (lsm->lsm_stripe_count));
1230
1231         OBD_ALLOC(lsm2, lsm_size);
1232         if (lsm2 == NULL)
1233                 GOTO(out, rc = -ENOMEM);
1234
1235         oa->o_id = ucreatp.lrc_id;
1236         oa->o_seq = ucreatp.lrc_seq;
1237         oa->o_nlink = ucreatp.lrc_ost_idx;
1238         oa->o_flags |= OBD_FL_RECREATE_OBJS;
1239         oa->o_valid = OBD_MD_FLID | OBD_MD_FLFLAGS | OBD_MD_FLGROUP;
1240         obdo_from_inode(oa, inode, &ll_i2info(inode)->lli_fid, OBD_MD_FLTYPE |
1241                         OBD_MD_FLATIME | OBD_MD_FLMTIME | OBD_MD_FLCTIME);
1242         memcpy(lsm2, lsm, lsm_size);
1243         rc = obd_create(exp, oa, &lsm2, &oti);
1244
1245         OBD_FREE(lsm2, lsm_size);
1246         GOTO(out, rc);
1247 out:
1248         ll_inode_size_unlock(inode, 0);
1249         OBDO_FREE(oa);
1250         return rc;
1251 }
1252
1253 int ll_lov_setstripe_ea_info(struct inode *inode, struct file *file,
1254                              int flags, struct lov_user_md *lum, int lum_size)
1255 {
1256         struct lov_stripe_md *lsm;
1257         struct lookup_intent oit = {.it_op = IT_OPEN, .it_flags = flags};
1258         int rc = 0;
1259         ENTRY;
1260
1261         ll_inode_size_lock(inode, 0);
1262         lsm = ll_i2info(inode)->lli_smd;
1263         if (lsm) {
1264                 ll_inode_size_unlock(inode, 0);
1265                 CDEBUG(D_IOCTL, "stripe already exists for ino %lu\n",
1266                        inode->i_ino);
1267                 RETURN(-EEXIST);
1268         }
1269
1270         rc = ll_intent_file_open(file, lum, lum_size, &oit);
1271         if (rc)
1272                 GOTO(out, rc);
1273         if (it_disposition(&oit, DISP_LOOKUP_NEG))
1274                 GOTO(out_req_free, rc = -ENOENT);
1275         rc = oit.d.lustre.it_status;
1276         if (rc < 0)
1277                 GOTO(out_req_free, rc);
1278
1279         ll_release_openhandle(file->f_dentry, &oit);
1280
1281  out:
1282         ll_inode_size_unlock(inode, 0);
1283         ll_intent_release(&oit);
1284         RETURN(rc);
1285 out_req_free:
1286         ptlrpc_req_finished((struct ptlrpc_request *) oit.d.lustre.it_data);
1287         goto out;
1288 }
1289
1290 int ll_lov_getstripe_ea_info(struct inode *inode, const char *filename,
1291                              struct lov_mds_md **lmmp, int *lmm_size,
1292                              struct ptlrpc_request **request)
1293 {
1294         struct ll_sb_info *sbi = ll_i2sbi(inode);
1295         struct mdt_body  *body;
1296         struct lov_mds_md *lmm = NULL;
1297         struct ptlrpc_request *req = NULL;
1298         struct md_op_data *op_data;
1299         int rc, lmmsize;
1300
1301         rc = ll_get_max_mdsize(sbi, &lmmsize);
1302         if (rc)
1303                 RETURN(rc);
1304
1305         op_data = ll_prep_md_op_data(NULL, inode, NULL, filename,
1306                                      strlen(filename), lmmsize,
1307                                      LUSTRE_OPC_ANY, NULL);
1308         if (op_data == NULL)
1309                 RETURN(-ENOMEM);
1310
1311         op_data->op_valid = OBD_MD_FLEASIZE | OBD_MD_FLDIREA;
1312         rc = md_getattr_name(sbi->ll_md_exp, op_data, &req);
1313         ll_finish_md_op_data(op_data);
1314         if (rc < 0) {
1315                 CDEBUG(D_INFO, "md_getattr_name failed "
1316                        "on %s: rc %d\n", filename, rc);
1317                 GOTO(out, rc);
1318         }
1319
1320         body = req_capsule_server_get(&req->rq_pill, &RMF_MDT_BODY);
1321         LASSERT(body != NULL); /* checked by mdc_getattr_name */
1322
1323         lmmsize = body->eadatasize;
1324
1325         if (!(body->valid & (OBD_MD_FLEASIZE | OBD_MD_FLDIREA)) ||
1326                         lmmsize == 0) {
1327                 GOTO(out, rc = -ENODATA);
1328         }
1329
1330         lmm = req_capsule_server_sized_get(&req->rq_pill, &RMF_MDT_MD, lmmsize);
1331         LASSERT(lmm != NULL);
1332
1333         if ((lmm->lmm_magic != cpu_to_le32(LOV_MAGIC_V1)) &&
1334             (lmm->lmm_magic != cpu_to_le32(LOV_MAGIC_V3))) {
1335                 GOTO(out, rc = -EPROTO);
1336         }
1337
1338         /*
1339          * This is coming from the MDS, so is probably in
1340          * little endian.  We convert it to host endian before
1341          * passing it to userspace.
1342          */
1343         if (LOV_MAGIC != cpu_to_le32(LOV_MAGIC)) {
1344                 /* if function called for directory - we should
1345                  * avoid swab not existent lsm objects */
1346                 if (lmm->lmm_magic == cpu_to_le32(LOV_MAGIC_V1)) {
1347                         lustre_swab_lov_user_md_v1((struct lov_user_md_v1 *)lmm);
1348                         if (S_ISREG(body->mode))
1349                                 lustre_swab_lov_user_md_objects(
1350                                  ((struct lov_user_md_v1 *)lmm)->lmm_objects,
1351                                  ((struct lov_user_md_v1 *)lmm)->lmm_stripe_count);
1352                 } else if (lmm->lmm_magic == cpu_to_le32(LOV_MAGIC_V3)) {
1353                         lustre_swab_lov_user_md_v3((struct lov_user_md_v3 *)lmm);
1354                         if (S_ISREG(body->mode))
1355                                 lustre_swab_lov_user_md_objects(
1356                                  ((struct lov_user_md_v3 *)lmm)->lmm_objects,
1357                                  ((struct lov_user_md_v3 *)lmm)->lmm_stripe_count);
1358                 }
1359         }
1360
1361 out:
1362         *lmmp = lmm;
1363         *lmm_size = lmmsize;
1364         *request = req;
1365         return rc;
1366 }
1367
1368 static int ll_lov_setea(struct inode *inode, struct file *file,
1369                             unsigned long arg)
1370 {
1371         int flags = MDS_OPEN_HAS_OBJS | FMODE_WRITE;
1372         struct lov_user_md  *lump;
1373         int lum_size = sizeof(struct lov_user_md) +
1374                        sizeof(struct lov_user_ost_data);
1375         int rc;
1376         ENTRY;
1377
1378         if (!cfs_capable(CFS_CAP_SYS_ADMIN))
1379                 RETURN(-EPERM);
1380
1381         OBD_ALLOC(lump, lum_size);
1382         if (lump == NULL) {
1383                 RETURN(-ENOMEM);
1384         }
1385         if (cfs_copy_from_user(lump, (struct lov_user_md  *)arg, lum_size)) {
1386                 OBD_FREE(lump, lum_size);
1387                 RETURN(-EFAULT);
1388         }
1389
1390         rc = ll_lov_setstripe_ea_info(inode, file, flags, lump, lum_size);
1391
1392         OBD_FREE(lump, lum_size);
1393         RETURN(rc);
1394 }
1395
1396 static int ll_lov_setstripe(struct inode *inode, struct file *file,
1397                             unsigned long arg)
1398 {
1399         struct lov_user_md_v3 lumv3;
1400         struct lov_user_md_v1 *lumv1 = (struct lov_user_md_v1 *)&lumv3;
1401         struct lov_user_md_v1 *lumv1p = (struct lov_user_md_v1 *)arg;
1402         struct lov_user_md_v3 *lumv3p = (struct lov_user_md_v3 *)arg;
1403         int lum_size;
1404         int rc;
1405         int flags = FMODE_WRITE;
1406         ENTRY;
1407
1408         /* first try with v1 which is smaller than v3 */
1409         lum_size = sizeof(struct lov_user_md_v1);
1410         if (cfs_copy_from_user(lumv1, lumv1p, lum_size))
1411                 RETURN(-EFAULT);
1412
1413         if (lumv1->lmm_magic == LOV_USER_MAGIC_V3) {
1414                 lum_size = sizeof(struct lov_user_md_v3);
1415                 if (cfs_copy_from_user(&lumv3, lumv3p, lum_size))
1416                         RETURN(-EFAULT);
1417         }
1418
1419         rc = ll_lov_setstripe_ea_info(inode, file, flags, lumv1, lum_size);
1420         if (rc == 0) {
1421                  put_user(0, &lumv1p->lmm_stripe_count);
1422                  rc = obd_iocontrol(LL_IOC_LOV_GETSTRIPE, ll_i2dtexp(inode),
1423                                     0, ll_i2info(inode)->lli_smd,
1424                                     (void *)arg);
1425         }
1426         RETURN(rc);
1427 }
1428
1429 static int ll_lov_getstripe(struct inode *inode, unsigned long arg)
1430 {
1431         struct lov_stripe_md *lsm = ll_i2info(inode)->lli_smd;
1432
1433         if (!lsm)
1434                 RETURN(-ENODATA);
1435
1436         return obd_iocontrol(LL_IOC_LOV_GETSTRIPE, ll_i2dtexp(inode), 0, lsm,
1437                             (void *)arg);
1438 }
1439
1440 int ll_get_grouplock(struct inode *inode, struct file *file, unsigned long arg)
1441 {
1442         struct ll_inode_info   *lli = ll_i2info(inode);
1443         struct ll_file_data    *fd = LUSTRE_FPRIVATE(file);
1444         struct ccc_grouplock    grouplock;
1445         int                     rc;
1446         ENTRY;
1447
1448         if (ll_file_nolock(file))
1449                 RETURN(-EOPNOTSUPP);
1450
1451         cfs_spin_lock(&lli->lli_lock);
1452         if (fd->fd_flags & LL_FILE_GROUP_LOCKED) {
1453                 CWARN("group lock already existed with gid %lu\n",
1454                        fd->fd_grouplock.cg_gid);
1455                 cfs_spin_unlock(&lli->lli_lock);
1456                 RETURN(-EINVAL);
1457         }
1458         LASSERT(fd->fd_grouplock.cg_lock == NULL);
1459         cfs_spin_unlock(&lli->lli_lock);
1460
1461         rc = cl_get_grouplock(cl_i2info(inode)->lli_clob,
1462                               arg, (file->f_flags & O_NONBLOCK), &grouplock);
1463         if (rc)
1464                 RETURN(rc);
1465
1466         cfs_spin_lock(&lli->lli_lock);
1467         if (fd->fd_flags & LL_FILE_GROUP_LOCKED) {
1468                 cfs_spin_unlock(&lli->lli_lock);
1469                 CERROR("another thread just won the race\n");
1470                 cl_put_grouplock(&grouplock);
1471                 RETURN(-EINVAL);
1472         }
1473
1474         fd->fd_flags |= LL_FILE_GROUP_LOCKED;
1475         fd->fd_grouplock = grouplock;
1476         cfs_spin_unlock(&lli->lli_lock);
1477
1478         CDEBUG(D_INFO, "group lock %lu obtained\n", arg);
1479         RETURN(0);
1480 }
1481
1482 int ll_put_grouplock(struct inode *inode, struct file *file, unsigned long arg)
1483 {
1484         struct ll_inode_info   *lli = ll_i2info(inode);
1485         struct ll_file_data    *fd = LUSTRE_FPRIVATE(file);
1486         struct ccc_grouplock    grouplock;
1487         ENTRY;
1488
1489         cfs_spin_lock(&lli->lli_lock);
1490         if (!(fd->fd_flags & LL_FILE_GROUP_LOCKED)) {
1491                 cfs_spin_unlock(&lli->lli_lock);
1492                 CWARN("no group lock held\n");
1493                 RETURN(-EINVAL);
1494         }
1495         LASSERT(fd->fd_grouplock.cg_lock != NULL);
1496
1497         if (fd->fd_grouplock.cg_gid != arg) {
1498                 CWARN("group lock %lu doesn't match current id %lu\n",
1499                        arg, fd->fd_grouplock.cg_gid);
1500                 cfs_spin_unlock(&lli->lli_lock);
1501                 RETURN(-EINVAL);
1502         }
1503
1504         grouplock = fd->fd_grouplock;
1505         memset(&fd->fd_grouplock, 0, sizeof(fd->fd_grouplock));
1506         fd->fd_flags &= ~LL_FILE_GROUP_LOCKED;
1507         cfs_spin_unlock(&lli->lli_lock);
1508
1509         cl_put_grouplock(&grouplock);
1510         CDEBUG(D_INFO, "group lock %lu released\n", arg);
1511         RETURN(0);
1512 }
1513
1514 /**
1515  * Close inode open handle
1516  *
1517  * \param dentry [in]     dentry which contains the inode
1518  * \param it     [in,out] intent which contains open info and result
1519  *
1520  * \retval 0     success
1521  * \retval <0    failure
1522  */
1523 int ll_release_openhandle(struct dentry *dentry, struct lookup_intent *it)
1524 {
1525         struct inode *inode = dentry->d_inode;
1526         struct obd_client_handle *och;
1527         int rc;
1528         ENTRY;
1529
1530         LASSERT(inode);
1531
1532         /* Root ? Do nothing. */
1533         if (dentry->d_inode->i_sb->s_root == dentry)
1534                 RETURN(0);
1535
1536         /* No open handle to close? Move away */
1537         if (!it_disposition(it, DISP_OPEN_OPEN))
1538                 RETURN(0);
1539
1540         LASSERT(it_open_error(DISP_OPEN_OPEN, it) == 0);
1541
1542         OBD_ALLOC(och, sizeof(*och));
1543         if (!och)
1544                 GOTO(out, rc = -ENOMEM);
1545
1546         ll_och_fill(ll_i2sbi(inode)->ll_md_exp,
1547                     ll_i2info(inode), it, och);
1548
1549         rc = ll_close_inode_openhandle(ll_i2sbi(inode)->ll_md_exp,
1550                                        inode, och);
1551  out:
1552         /* this one is in place of ll_file_open */
1553         if (it_disposition(it, DISP_ENQ_OPEN_REF))
1554                 ptlrpc_req_finished(it->d.lustre.it_data);
1555         it_clear_disposition(it, DISP_ENQ_OPEN_REF);
1556         RETURN(rc);
1557 }
1558
1559 /**
1560  * Get size for inode for which FIEMAP mapping is requested.
1561  * Make the FIEMAP get_info call and returns the result.
1562  */
1563 int ll_do_fiemap(struct inode *inode, struct ll_user_fiemap *fiemap,
1564               int num_bytes)
1565 {
1566         struct obd_export *exp = ll_i2dtexp(inode);
1567         struct lov_stripe_md *lsm = ll_i2info(inode)->lli_smd;
1568         struct ll_fiemap_info_key fm_key = { .name = KEY_FIEMAP, };
1569         int vallen = num_bytes;
1570         int rc;
1571         ENTRY;
1572
1573         /* Checks for fiemap flags */
1574         if (fiemap->fm_flags & ~LUSTRE_FIEMAP_FLAGS_COMPAT) {
1575                 fiemap->fm_flags &= ~LUSTRE_FIEMAP_FLAGS_COMPAT;
1576                 return -EBADR;
1577         }
1578
1579         /* Check for FIEMAP_FLAG_SYNC */
1580         if (fiemap->fm_flags & FIEMAP_FLAG_SYNC) {
1581                 rc = filemap_fdatawrite(inode->i_mapping);
1582                 if (rc)
1583                         return rc;
1584         }
1585
1586         /* If the stripe_count > 1 and the application does not understand
1587          * DEVICE_ORDER flag, then it cannot interpret the extents correctly.
1588          */
1589         if (lsm->lsm_stripe_count > 1 &&
1590             !(fiemap->fm_flags & FIEMAP_FLAG_DEVICE_ORDER))
1591                 return -EOPNOTSUPP;
1592
1593         fm_key.oa.o_id = lsm->lsm_object_id;
1594         fm_key.oa.o_seq = lsm->lsm_object_seq;
1595         fm_key.oa.o_valid = OBD_MD_FLID | OBD_MD_FLGROUP;
1596
1597         obdo_from_inode(&fm_key.oa, inode, &ll_i2info(inode)->lli_fid,
1598                         OBD_MD_FLSIZE);
1599         /* If filesize is 0, then there would be no objects for mapping */
1600         if (fm_key.oa.o_size == 0) {
1601                 fiemap->fm_mapped_extents = 0;
1602                 RETURN(0);
1603         }
1604
1605         memcpy(&fm_key.fiemap, fiemap, sizeof(*fiemap));
1606
1607         rc = obd_get_info(exp, sizeof(fm_key), &fm_key, &vallen, fiemap, lsm);
1608         if (rc)
1609                 CERROR("obd_get_info failed: rc = %d\n", rc);
1610
1611         RETURN(rc);
1612 }
1613
1614 int ll_fid2path(struct obd_export *exp, void *arg)
1615 {
1616         struct getinfo_fid2path *gfout, *gfin;
1617         int outsize, rc;
1618         ENTRY;
1619
1620         /* Need to get the buflen */
1621         OBD_ALLOC_PTR(gfin);
1622         if (gfin == NULL)
1623                 RETURN(-ENOMEM);
1624         if (cfs_copy_from_user(gfin, arg, sizeof(*gfin))) {
1625                 OBD_FREE_PTR(gfin);
1626                 RETURN(-EFAULT);
1627         }
1628
1629         outsize = sizeof(*gfout) + gfin->gf_pathlen;
1630         OBD_ALLOC(gfout, outsize);
1631         if (gfout == NULL) {
1632                 OBD_FREE_PTR(gfin);
1633                 RETURN(-ENOMEM);
1634         }
1635         memcpy(gfout, gfin, sizeof(*gfout));
1636         OBD_FREE_PTR(gfin);
1637
1638         /* Call mdc_iocontrol */
1639         rc = obd_iocontrol(OBD_IOC_FID2PATH, exp, outsize, gfout, NULL);
1640         if (rc)
1641                 GOTO(gf_free, rc);
1642         if (cfs_copy_to_user(arg, gfout, outsize))
1643                 rc = -EFAULT;
1644
1645 gf_free:
1646         OBD_FREE(gfout, outsize);
1647         RETURN(rc);
1648 }
1649
1650 static int ll_ioctl_fiemap(struct inode *inode, unsigned long arg)
1651 {
1652         struct ll_user_fiemap *fiemap_s;
1653         size_t num_bytes, ret_bytes;
1654         unsigned int extent_count;
1655         int rc = 0;
1656
1657         /* Get the extent count so we can calculate the size of
1658          * required fiemap buffer */
1659         if (get_user(extent_count,
1660             &((struct ll_user_fiemap __user *)arg)->fm_extent_count))
1661                 RETURN(-EFAULT);
1662         num_bytes = sizeof(*fiemap_s) + (extent_count *
1663                                          sizeof(struct ll_fiemap_extent));
1664
1665         OBD_VMALLOC(fiemap_s, num_bytes);
1666         if (fiemap_s == NULL)
1667                 RETURN(-ENOMEM);
1668
1669         /* get the fiemap value */
1670         if (copy_from_user(fiemap_s,(struct ll_user_fiemap __user *)arg,
1671                            sizeof(*fiemap_s)))
1672                 GOTO(error, rc = -EFAULT);
1673
1674         /* If fm_extent_count is non-zero, read the first extent since
1675          * it is used to calculate end_offset and device from previous
1676          * fiemap call. */
1677         if (extent_count) {
1678                 if (copy_from_user(&fiemap_s->fm_extents[0],
1679                     (char __user *)arg + sizeof(*fiemap_s),
1680                     sizeof(struct ll_fiemap_extent)))
1681                         GOTO(error, rc = -EFAULT);
1682         }
1683
1684         rc = ll_do_fiemap(inode, fiemap_s, num_bytes);
1685         if (rc)
1686                 GOTO(error, rc);
1687
1688         ret_bytes = sizeof(struct ll_user_fiemap);
1689
1690         if (extent_count != 0)
1691                 ret_bytes += (fiemap_s->fm_mapped_extents *
1692                                  sizeof(struct ll_fiemap_extent));
1693
1694         if (copy_to_user((void *)arg, fiemap_s, ret_bytes))
1695                 rc = -EFAULT;
1696
1697 error:
1698         OBD_VFREE(fiemap_s, num_bytes);
1699         RETURN(rc);
1700 }
1701
1702 int ll_file_ioctl(struct inode *inode, struct file *file, unsigned int cmd,
1703                   unsigned long arg)
1704 {
1705         struct ll_file_data *fd = LUSTRE_FPRIVATE(file);
1706         int flags;
1707         ENTRY;
1708
1709         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p),cmd=%x\n", inode->i_ino,
1710                inode->i_generation, inode, cmd);
1711         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_IOCTL, 1);
1712
1713         /* asm-ppc{,64} declares TCGETS, et. al. as type 't' not 'T' */
1714         if (_IOC_TYPE(cmd) == 'T' || _IOC_TYPE(cmd) == 't') /* tty ioctls */
1715                 RETURN(-ENOTTY);
1716
1717         switch(cmd) {
1718         case LL_IOC_GETFLAGS:
1719                 /* Get the current value of the file flags */
1720                 return put_user(fd->fd_flags, (int *)arg);
1721         case LL_IOC_SETFLAGS:
1722         case LL_IOC_CLRFLAGS:
1723                 /* Set or clear specific file flags */
1724                 /* XXX This probably needs checks to ensure the flags are
1725                  *     not abused, and to handle any flag side effects.
1726                  */
1727                 if (get_user(flags, (int *) arg))
1728                         RETURN(-EFAULT);
1729
1730                 if (cmd == LL_IOC_SETFLAGS) {
1731                         if ((flags & LL_FILE_IGNORE_LOCK) &&
1732                             !(file->f_flags & O_DIRECT)) {
1733                                 CERROR("%s: unable to disable locking on "
1734                                        "non-O_DIRECT file\n", current->comm);
1735                                 RETURN(-EINVAL);
1736                         }
1737
1738                         fd->fd_flags |= flags;
1739                 } else {
1740                         fd->fd_flags &= ~flags;
1741                 }
1742                 RETURN(0);
1743         case LL_IOC_LOV_SETSTRIPE:
1744                 RETURN(ll_lov_setstripe(inode, file, arg));
1745         case LL_IOC_LOV_SETEA:
1746                 RETURN(ll_lov_setea(inode, file, arg));
1747         case LL_IOC_LOV_GETSTRIPE:
1748                 RETURN(ll_lov_getstripe(inode, arg));
1749         case LL_IOC_RECREATE_OBJ:
1750                 RETURN(ll_lov_recreate_obj(inode, file, arg));
1751         case FSFILT_IOC_FIEMAP:
1752                 RETURN(ll_ioctl_fiemap(inode, arg));
1753         case FSFILT_IOC_GETFLAGS:
1754         case FSFILT_IOC_SETFLAGS:
1755                 RETURN(ll_iocontrol(inode, file, cmd, arg));
1756         case FSFILT_IOC_GETVERSION_OLD:
1757         case FSFILT_IOC_GETVERSION:
1758                 RETURN(put_user(inode->i_generation, (int *)arg));
1759         case LL_IOC_GROUP_LOCK:
1760                 RETURN(ll_get_grouplock(inode, file, arg));
1761         case LL_IOC_GROUP_UNLOCK:
1762                 RETURN(ll_put_grouplock(inode, file, arg));
1763         case IOC_OBD_STATFS:
1764                 RETURN(ll_obd_statfs(inode, (void *)arg));
1765
1766         /* We need to special case any other ioctls we want to handle,
1767          * to send them to the MDS/OST as appropriate and to properly
1768          * network encode the arg field.
1769         case FSFILT_IOC_SETVERSION_OLD:
1770         case FSFILT_IOC_SETVERSION:
1771         */
1772         case LL_IOC_FLUSHCTX:
1773                 RETURN(ll_flush_ctx(inode));
1774         case LL_IOC_PATH2FID: {
1775                 if (cfs_copy_to_user((void *)arg, ll_inode2fid(inode),
1776                                      sizeof(struct lu_fid)))
1777                         RETURN(-EFAULT);
1778
1779                 RETURN(0);
1780         }
1781         case OBD_IOC_FID2PATH:
1782                 RETURN(ll_fid2path(ll_i2mdexp(inode), (void *)arg));
1783
1784         case LL_IOC_GET_MDTIDX: {
1785                 int mdtidx;
1786
1787                 mdtidx = ll_get_mdt_idx(inode);
1788                 if (mdtidx < 0)
1789                         RETURN(mdtidx);
1790
1791                 if (put_user((int)mdtidx, (int*)arg))
1792                         RETURN(-EFAULT);
1793
1794                 RETURN(0);
1795         }
1796
1797         default: {
1798                 int err;
1799
1800                 if (LLIOC_STOP ==
1801                     ll_iocontrol_call(inode, file, cmd, arg, &err))
1802                         RETURN(err);
1803
1804                 RETURN(obd_iocontrol(cmd, ll_i2dtexp(inode), 0, NULL,
1805                                      (void *)arg));
1806         }
1807         }
1808 }
1809
1810 loff_t ll_file_seek(struct file *file, loff_t offset, int origin)
1811 {
1812         struct inode *inode = file->f_dentry->d_inode;
1813         loff_t retval;
1814         ENTRY;
1815         retval = offset + ((origin == 2) ? i_size_read(inode) :
1816                            (origin == 1) ? file->f_pos : 0);
1817         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p), to=%Lu=%#Lx(%s)\n",
1818                inode->i_ino, inode->i_generation, inode, retval, retval,
1819                origin == 2 ? "SEEK_END": origin == 1 ? "SEEK_CUR" : "SEEK_SET");
1820         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_LLSEEK, 1);
1821
1822         if (origin == 2) { /* SEEK_END */
1823                 int nonblock = 0, rc;
1824
1825                 if (file->f_flags & O_NONBLOCK)
1826                         nonblock = LDLM_FL_BLOCK_NOWAIT;
1827
1828                 rc = cl_glimpse_size(inode);
1829                 if (rc != 0)
1830                         RETURN(rc);
1831
1832                 offset += i_size_read(inode);
1833         } else if (origin == 1) { /* SEEK_CUR */
1834                 offset += file->f_pos;
1835         }
1836
1837         retval = -EINVAL;
1838         if (offset >= 0 && offset <= ll_file_maxbytes(inode)) {
1839                 if (offset != file->f_pos) {
1840                         file->f_pos = offset;
1841                 }
1842                 retval = offset;
1843         }
1844
1845         RETURN(retval);
1846 }
1847
1848 int ll_fsync(struct file *file, struct dentry *dentry, int data)
1849 {
1850         struct inode *inode = dentry->d_inode;
1851         struct ll_inode_info *lli = ll_i2info(inode);
1852         struct lov_stripe_md *lsm = lli->lli_smd;
1853         struct ptlrpc_request *req;
1854         struct obd_capa *oc;
1855         int rc, err;
1856         ENTRY;
1857         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p)\n", inode->i_ino,
1858                inode->i_generation, inode);
1859         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_FSYNC, 1);
1860
1861         /* fsync's caller has already called _fdata{sync,write}, we want
1862          * that IO to finish before calling the osc and mdc sync methods */
1863         rc = filemap_fdatawait(inode->i_mapping);
1864
1865         /* catch async errors that were recorded back when async writeback
1866          * failed for pages in this mapping. */
1867         err = lli->lli_async_rc;
1868         lli->lli_async_rc = 0;
1869         if (rc == 0)
1870                 rc = err;
1871         if (lsm) {
1872                 err = lov_test_and_clear_async_rc(lsm);
1873                 if (rc == 0)
1874                         rc = err;
1875         }
1876
1877         oc = ll_mdscapa_get(inode);
1878         err = md_sync(ll_i2sbi(inode)->ll_md_exp, ll_inode2fid(inode), oc,
1879                       &req);
1880         capa_put(oc);
1881         if (!rc)
1882                 rc = err;
1883         if (!err)
1884                 ptlrpc_req_finished(req);
1885
1886         if (data && lsm) {
1887                 struct obdo *oa;
1888
1889                 OBDO_ALLOC(oa);
1890                 if (!oa)
1891                         RETURN(rc ? rc : -ENOMEM);
1892
1893                 oa->o_id = lsm->lsm_object_id;
1894                 oa->o_seq = lsm->lsm_object_seq;
1895                 oa->o_valid = OBD_MD_FLID | OBD_MD_FLGROUP;
1896                 obdo_from_inode(oa, inode, &ll_i2info(inode)->lli_fid,
1897                                 OBD_MD_FLTYPE | OBD_MD_FLATIME |
1898                                 OBD_MD_FLMTIME | OBD_MD_FLCTIME |
1899                                 OBD_MD_FLGROUP);
1900
1901                 oc = ll_osscapa_get(inode, CAPA_OPC_OSS_WRITE);
1902                 err = obd_sync(ll_i2sbi(inode)->ll_dt_exp, oa, lsm,
1903                                0, OBD_OBJECT_EOF, oc);
1904                 capa_put(oc);
1905                 if (!rc)
1906                         rc = err;
1907                 OBDO_FREE(oa);
1908         }
1909
1910         RETURN(rc);
1911 }
1912
1913 int ll_file_flock(struct file *file, int cmd, struct file_lock *file_lock)
1914 {
1915         struct inode *inode = file->f_dentry->d_inode;
1916         struct ll_sb_info *sbi = ll_i2sbi(inode);
1917         struct ldlm_enqueue_info einfo = { .ei_type = LDLM_FLOCK,
1918                                            .ei_cb_cp =ldlm_flock_completion_ast,
1919                                            .ei_cbdata = file_lock };
1920         struct md_op_data *op_data;
1921         struct lustre_handle lockh = {0};
1922         ldlm_policy_data_t flock;
1923         int flags = 0;
1924         int rc;
1925         ENTRY;
1926
1927         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu file_lock=%p\n",
1928                inode->i_ino, file_lock);
1929
1930         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_FLOCK, 1);
1931
1932         if (file_lock->fl_flags & FL_FLOCK) {
1933                 LASSERT((cmd == F_SETLKW) || (cmd == F_SETLK));
1934                 /* set missing params for flock() calls */
1935                 file_lock->fl_end = OFFSET_MAX;
1936                 file_lock->fl_pid = current->tgid;
1937         }
1938         flock.l_flock.pid = file_lock->fl_pid;
1939         flock.l_flock.start = file_lock->fl_start;
1940         flock.l_flock.end = file_lock->fl_end;
1941
1942         switch (file_lock->fl_type) {
1943         case F_RDLCK:
1944                 einfo.ei_mode = LCK_PR;
1945                 break;
1946         case F_UNLCK:
1947                 /* An unlock request may or may not have any relation to
1948                  * existing locks so we may not be able to pass a lock handle
1949                  * via a normal ldlm_lock_cancel() request. The request may even
1950                  * unlock a byte range in the middle of an existing lock. In
1951                  * order to process an unlock request we need all of the same
1952                  * information that is given with a normal read or write record
1953                  * lock request. To avoid creating another ldlm unlock (cancel)
1954                  * message we'll treat a LCK_NL flock request as an unlock. */
1955                 einfo.ei_mode = LCK_NL;
1956                 break;
1957         case F_WRLCK:
1958                 einfo.ei_mode = LCK_PW;
1959                 break;
1960         default:
1961                 CERROR("unknown fcntl lock type: %d\n", file_lock->fl_type);
1962                 RETURN (-EINVAL);
1963         }
1964
1965         switch (cmd) {
1966         case F_SETLKW:
1967 #ifdef F_SETLKW64
1968         case F_SETLKW64:
1969 #endif
1970                 flags = 0;
1971                 break;
1972         case F_SETLK:
1973 #ifdef F_SETLK64
1974         case F_SETLK64:
1975 #endif
1976                 flags = LDLM_FL_BLOCK_NOWAIT;
1977                 break;
1978         case F_GETLK:
1979 #ifdef F_GETLK64
1980         case F_GETLK64:
1981 #endif
1982                 flags = LDLM_FL_TEST_LOCK;
1983                 /* Save the old mode so that if the mode in the lock changes we
1984                  * can decrement the appropriate reader or writer refcount. */
1985                 file_lock->fl_type = einfo.ei_mode;
1986                 break;
1987         default:
1988                 CERROR("unknown fcntl lock command: %d\n", cmd);
1989                 RETURN (-EINVAL);
1990         }
1991
1992         op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL, 0, 0,
1993                                      LUSTRE_OPC_ANY, NULL);
1994         if (IS_ERR(op_data))
1995                 RETURN(PTR_ERR(op_data));
1996
1997         CDEBUG(D_DLMTRACE, "inode=%lu, pid=%u, flags=%#x, mode=%u, "
1998                "start="LPU64", end="LPU64"\n", inode->i_ino, flock.l_flock.pid,
1999                flags, einfo.ei_mode, flock.l_flock.start, flock.l_flock.end);
2000
2001         rc = md_enqueue(sbi->ll_md_exp, &einfo, NULL,
2002                         op_data, &lockh, &flock, 0, NULL /* req */, flags);
2003
2004         ll_finish_md_op_data(op_data);
2005
2006         if ((file_lock->fl_flags & FL_FLOCK) &&
2007             (rc == 0 || file_lock->fl_type == F_UNLCK))
2008                 ll_flock_lock_file_wait(file, file_lock, (cmd == F_SETLKW));
2009 #ifdef HAVE_F_OP_FLOCK
2010         if ((file_lock->fl_flags & FL_POSIX) &&
2011             (rc == 0 || file_lock->fl_type == F_UNLCK) &&
2012             !(flags & LDLM_FL_TEST_LOCK))
2013                 posix_lock_file_wait(file, file_lock);
2014 #endif
2015
2016         RETURN(rc);
2017 }
2018
2019 int ll_file_noflock(struct file *file, int cmd, struct file_lock *file_lock)
2020 {
2021         ENTRY;
2022
2023         RETURN(-ENOSYS);
2024 }
2025
2026 int ll_have_md_lock(struct inode *inode, __u64 bits)
2027 {
2028         struct lustre_handle lockh;
2029         ldlm_policy_data_t policy = { .l_inodebits = {bits}};
2030         struct lu_fid *fid;
2031         int flags;
2032         ENTRY;
2033
2034         if (!inode)
2035                RETURN(0);
2036
2037         fid = &ll_i2info(inode)->lli_fid;
2038         CDEBUG(D_INFO, "trying to match res "DFID"\n", PFID(fid));
2039
2040         flags = LDLM_FL_BLOCK_GRANTED | LDLM_FL_CBPENDING | LDLM_FL_TEST_LOCK;
2041         if (md_lock_match(ll_i2mdexp(inode), flags, fid, LDLM_IBITS, &policy,
2042                           LCK_CR|LCK_CW|LCK_PR|LCK_PW, &lockh)) {
2043                 RETURN(1);
2044         }
2045         RETURN(0);
2046 }
2047
2048 ldlm_mode_t ll_take_md_lock(struct inode *inode, __u64 bits,
2049                             struct lustre_handle *lockh)
2050 {
2051         ldlm_policy_data_t policy = { .l_inodebits = {bits}};
2052         struct lu_fid *fid;
2053         ldlm_mode_t rc;
2054         int flags;
2055         ENTRY;
2056
2057         fid = &ll_i2info(inode)->lli_fid;
2058         CDEBUG(D_INFO, "trying to match res "DFID"\n", PFID(fid));
2059
2060         flags = LDLM_FL_BLOCK_GRANTED | LDLM_FL_CBPENDING;
2061         rc = md_lock_match(ll_i2mdexp(inode), flags, fid, LDLM_IBITS, &policy,
2062                            LCK_CR|LCK_CW|LCK_PR|LCK_PW, lockh);
2063         RETURN(rc);
2064 }
2065
2066 static int ll_inode_revalidate_fini(struct inode *inode, int rc) {
2067         if (rc == -ENOENT) { /* Already unlinked. Just update nlink
2068                               * and return success */
2069                 inode->i_nlink = 0;
2070                 /* This path cannot be hit for regular files unless in
2071                  * case of obscure races, so no need to to validate
2072                  * size. */
2073                 if (!S_ISREG(inode->i_mode) &&
2074                     !S_ISDIR(inode->i_mode))
2075                         return 0;
2076         }
2077
2078         if (rc) {
2079                 CERROR("failure %d inode %lu\n", rc, inode->i_ino);
2080                 return -abs(rc);
2081
2082         }
2083
2084         return 0;
2085 }
2086
2087 int __ll_inode_revalidate_it(struct dentry *dentry, struct lookup_intent *it,
2088                              __u64 ibits)
2089 {
2090         struct inode *inode = dentry->d_inode;
2091         struct ptlrpc_request *req = NULL;
2092         struct ll_sb_info *sbi;
2093         struct obd_export *exp;
2094         int rc = 0;
2095         ENTRY;
2096
2097         if (!inode) {
2098                 CERROR("REPORT THIS LINE TO PETER\n");
2099                 RETURN(0);
2100         }
2101         sbi = ll_i2sbi(inode);
2102
2103         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p),name=%s\n",
2104                inode->i_ino, inode->i_generation, inode, dentry->d_name.name);
2105
2106         exp = ll_i2mdexp(inode);
2107
2108         if (exp->exp_connect_flags & OBD_CONNECT_ATTRFID) {
2109                 struct lookup_intent oit = { .it_op = IT_GETATTR };
2110                 struct md_op_data *op_data;
2111
2112                 /* Call getattr by fid, so do not provide name at all. */
2113                 op_data = ll_prep_md_op_data(NULL, dentry->d_parent->d_inode,
2114                                              dentry->d_inode, NULL, 0, 0,
2115                                              LUSTRE_OPC_ANY, NULL);
2116                 if (IS_ERR(op_data))
2117                         RETURN(PTR_ERR(op_data));
2118
2119                 oit.it_create_mode |= M_CHECK_STALE;
2120                 rc = md_intent_lock(exp, op_data, NULL, 0,
2121                                     /* we are not interested in name
2122                                        based lookup */
2123                                     &oit, 0, &req,
2124                                     ll_md_blocking_ast, 0);
2125                 ll_finish_md_op_data(op_data);
2126                 oit.it_create_mode &= ~M_CHECK_STALE;
2127                 if (rc < 0) {
2128                         rc = ll_inode_revalidate_fini(inode, rc);
2129                         GOTO (out, rc);
2130                 }
2131
2132                 rc = ll_revalidate_it_finish(req, &oit, dentry);
2133                 if (rc != 0) {
2134                         ll_intent_release(&oit);
2135                         GOTO(out, rc);
2136                 }
2137
2138                 /* Unlinked? Unhash dentry, so it is not picked up later by
2139                    do_lookup() -> ll_revalidate_it(). We cannot use d_drop
2140                    here to preserve get_cwd functionality on 2.6.
2141                    Bug 10503 */
2142                 if (!dentry->d_inode->i_nlink) {
2143                         cfs_spin_lock(&ll_lookup_lock);
2144                         spin_lock(&dcache_lock);
2145                         ll_drop_dentry(dentry);
2146                         spin_unlock(&dcache_lock);
2147                         cfs_spin_unlock(&ll_lookup_lock);
2148                 }
2149
2150                 ll_lookup_finish_locks(&oit, dentry);
2151         } else if (!ll_have_md_lock(dentry->d_inode, ibits)) {
2152                 struct ll_sb_info *sbi = ll_i2sbi(dentry->d_inode);
2153                 obd_valid valid = OBD_MD_FLGETATTR;
2154                 struct md_op_data *op_data;
2155                 int ealen = 0;
2156
2157                 if (S_ISREG(inode->i_mode)) {
2158                         rc = ll_get_max_mdsize(sbi, &ealen);
2159                         if (rc)
2160                                 RETURN(rc);
2161                         valid |= OBD_MD_FLEASIZE | OBD_MD_FLMODEASIZE;
2162                 }
2163
2164                 op_data = ll_prep_md_op_data(NULL, inode, NULL, NULL,
2165                                              0, ealen, LUSTRE_OPC_ANY,
2166                                              NULL);
2167                 if (op_data == NULL)
2168                         RETURN(-ENOMEM);
2169
2170                 op_data->op_valid = valid;
2171                 /* Once OBD_CONNECT_ATTRFID is not supported, we can't find one
2172                  * capa for this inode. Because we only keep capas of dirs
2173                  * fresh. */
2174                 rc = md_getattr(sbi->ll_md_exp, op_data, &req);
2175                 ll_finish_md_op_data(op_data);
2176                 if (rc) {
2177                         rc = ll_inode_revalidate_fini(inode, rc);
2178                         RETURN(rc);
2179                 }
2180
2181                 rc = ll_prep_inode(&inode, req, NULL);
2182         }
2183 out:
2184         ptlrpc_req_finished(req);
2185         return rc;
2186 }
2187
2188 int ll_inode_revalidate_it(struct dentry *dentry, struct lookup_intent *it)
2189 {
2190         struct inode *inode = dentry->d_inode;
2191         int rc;
2192         ENTRY;
2193
2194         rc = __ll_inode_revalidate_it(dentry, it, MDS_INODELOCK_UPDATE |
2195                                                   MDS_INODELOCK_LOOKUP);
2196
2197         /* if object not yet allocated, don't validate size */
2198         if (rc == 0 && ll_i2info(dentry->d_inode)->lli_smd == NULL) {
2199                 LTIME_S(inode->i_atime) = ll_i2info(inode)->lli_lvb.lvb_atime;
2200                 LTIME_S(inode->i_mtime) = ll_i2info(inode)->lli_lvb.lvb_mtime;
2201                 LTIME_S(inode->i_ctime) = ll_i2info(inode)->lli_lvb.lvb_ctime;
2202                 RETURN(0);
2203         }
2204
2205         /* cl_glimpse_size will prefer locally cached writes if they extend
2206          * the file */
2207
2208         if (rc == 0)
2209                 rc = cl_glimpse_size(inode);
2210
2211         RETURN(rc);
2212 }
2213
2214 int ll_getattr_it(struct vfsmount *mnt, struct dentry *de,
2215                   struct lookup_intent *it, struct kstat *stat)
2216 {
2217         struct inode *inode = de->d_inode;
2218         struct ll_inode_info *lli = ll_i2info(inode);
2219         int res = 0;
2220
2221         res = ll_inode_revalidate_it(de, it);
2222         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_GETATTR, 1);
2223
2224         if (res)
2225                 return res;
2226
2227         stat->dev = inode->i_sb->s_dev;
2228         if (cfs_curproc_is_32bit())
2229                 stat->ino = cl_fid_build_ino32(&lli->lli_fid);
2230         else
2231                 stat->ino = inode->i_ino;
2232
2233         stat->mode = inode->i_mode;
2234         stat->nlink = inode->i_nlink;
2235         stat->uid = inode->i_uid;
2236         stat->gid = inode->i_gid;
2237         stat->rdev = kdev_t_to_nr(inode->i_rdev);
2238         stat->atime = inode->i_atime;
2239         stat->mtime = inode->i_mtime;
2240         stat->ctime = inode->i_ctime;
2241 #ifdef HAVE_INODE_BLKSIZE
2242         stat->blksize = inode->i_blksize;
2243 #else
2244         stat->blksize = 1 << inode->i_blkbits;
2245 #endif
2246
2247         stat->size = i_size_read(inode);
2248         stat->blocks = inode->i_blocks;
2249
2250         return 0;
2251 }
2252 int ll_getattr(struct vfsmount *mnt, struct dentry *de, struct kstat *stat)
2253 {
2254         struct lookup_intent it = { .it_op = IT_GETATTR };
2255
2256         return ll_getattr_it(mnt, de, &it, stat);
2257 }
2258
2259 #ifdef HAVE_LINUX_FIEMAP_H
2260 int ll_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
2261                 __u64 start, __u64 len)
2262 {
2263         int rc;
2264         size_t num_bytes;
2265         struct ll_user_fiemap *fiemap;
2266         unsigned int extent_count = fieinfo->fi_extents_max;
2267
2268         num_bytes = sizeof(*fiemap) + (extent_count *
2269                                        sizeof(struct ll_fiemap_extent));
2270         OBD_VMALLOC(fiemap, num_bytes);
2271
2272         if (fiemap == NULL)
2273                 RETURN(-ENOMEM);
2274
2275         fiemap->fm_flags = fieinfo->fi_flags;
2276         fiemap->fm_extent_count = fieinfo->fi_extents_max;
2277         fiemap->fm_start = start;
2278         fiemap->fm_length = len;
2279         memcpy(&fiemap->fm_extents[0], fieinfo->fi_extents_start,
2280                sizeof(struct ll_fiemap_extent));
2281
2282         rc = ll_do_fiemap(inode, fiemap, num_bytes);
2283
2284         fieinfo->fi_flags = fiemap->fm_flags;
2285         fieinfo->fi_extents_mapped = fiemap->fm_mapped_extents;
2286         memcpy(fieinfo->fi_extents_start, &fiemap->fm_extents[0],
2287                fiemap->fm_mapped_extents * sizeof(struct ll_fiemap_extent));
2288
2289         OBD_VFREE(fiemap, num_bytes);
2290         return rc;
2291 }
2292 #endif
2293
2294
2295 static
2296 int lustre_check_acl(struct inode *inode, int mask)
2297 {
2298 #ifdef CONFIG_FS_POSIX_ACL
2299         struct ll_inode_info *lli = ll_i2info(inode);
2300         struct posix_acl *acl;
2301         int rc;
2302         ENTRY;
2303
2304         cfs_spin_lock(&lli->lli_lock);
2305         acl = posix_acl_dup(lli->lli_posix_acl);
2306         cfs_spin_unlock(&lli->lli_lock);
2307
2308         if (!acl)
2309                 RETURN(-EAGAIN);
2310
2311         rc = posix_acl_permission(inode, acl, mask);
2312         posix_acl_release(acl);
2313
2314         RETURN(rc);
2315 #else
2316         return -EAGAIN;
2317 #endif
2318 }
2319
2320 #if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,10))
2321 #ifndef HAVE_INODE_PERMISION_2ARGS
2322 int ll_inode_permission(struct inode *inode, int mask, struct nameidata *nd)
2323 #else
2324 int ll_inode_permission(struct inode *inode, int mask)
2325 #endif
2326 {
2327         int rc = 0;
2328         ENTRY;
2329
2330        /* as root inode are NOT getting validated in lookup operation,
2331         * need to do it before permission check. */
2332
2333         if (inode == inode->i_sb->s_root->d_inode) {
2334                 struct lookup_intent it = { .it_op = IT_LOOKUP };
2335
2336                 rc = __ll_inode_revalidate_it(inode->i_sb->s_root, &it,
2337                                               MDS_INODELOCK_LOOKUP);
2338                 if (rc)
2339                         RETURN(rc);
2340         }
2341
2342         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p), inode mode %x mask %o\n",
2343                inode->i_ino, inode->i_generation, inode, inode->i_mode, mask);
2344
2345         if (ll_i2sbi(inode)->ll_flags & LL_SBI_RMT_CLIENT)
2346                 return lustre_check_remote_perm(inode, mask);
2347
2348         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_INODE_PERM, 1);
2349         rc = generic_permission(inode, mask, lustre_check_acl);
2350
2351         RETURN(rc);
2352 }
2353 #else
2354 int ll_inode_permission(struct inode *inode, int mask, struct nameidata *nd)
2355 {
2356         int mode = inode->i_mode;
2357         int rc;
2358
2359         CDEBUG(D_VFSTRACE, "VFS Op:inode=%lu/%u(%p), mask %o\n",
2360                inode->i_ino, inode->i_generation, inode, mask);
2361
2362         if (ll_i2sbi(inode)->ll_flags & LL_SBI_RMT_CLIENT)
2363                 return lustre_check_remote_perm(inode, mask);
2364
2365         ll_stats_ops_tally(ll_i2sbi(inode), LPROC_LL_INODE_PERM, 1);
2366
2367         if ((mask & MAY_WRITE) && IS_RDONLY(inode) &&
2368             (S_ISREG(mode) || S_ISDIR(mode) || S_ISLNK(mode)))
2369                 return -EROFS;
2370         if ((mask & MAY_WRITE) && IS_IMMUTABLE(inode))
2371                 return -EACCES;
2372         if (current->fsuid == inode->i_uid) {
2373                 mode >>= 6;
2374         } else if (1) {
2375                 if (((mode >> 3) & mask & S_IRWXO) != mask)
2376                         goto check_groups;
2377                 rc = lustre_check_acl(inode, mask);
2378                 if (rc == -EAGAIN)
2379                         goto check_groups;
2380                 if (rc == -EACCES)
2381                         goto check_capabilities;
2382                 return rc;
2383         } else {
2384 check_groups:
2385                 if (cfs_curproc_is_in_groups(inode->i_gid))
2386                         mode >>= 3;
2387         }
2388         if ((mode & mask & S_IRWXO) == mask)
2389                 return 0;
2390
2391 check_capabilities:
2392         if (!(mask & MAY_EXEC) ||
2393             (inode->i_mode & S_IXUGO) || S_ISDIR(inode->i_mode))
2394                 if (cfs_capable(CFS_CAP_DAC_OVERRIDE))
2395                         return 0;
2396
2397         if (cfs_capable(CFS_CAP_DAC_READ_SEARCH) && ((mask == MAY_READ) ||
2398             (S_ISDIR(inode->i_mode) && !(mask & MAY_WRITE))))
2399                 return 0;
2400
2401         return -EACCES;
2402 }
2403 #endif
2404
2405 #ifdef HAVE_FILE_READV
2406 #define READ_METHOD readv
2407 #define READ_FUNCTION ll_file_readv
2408 #define WRITE_METHOD writev
2409 #define WRITE_FUNCTION ll_file_writev
2410 #else
2411 #define READ_METHOD aio_read
2412 #define READ_FUNCTION ll_file_aio_read
2413 #define WRITE_METHOD aio_write
2414 #define WRITE_FUNCTION ll_file_aio_write
2415 #endif
2416
2417 /* -o localflock - only provides locally consistent flock locks */
2418 struct file_operations ll_file_operations = {
2419         .read           = ll_file_read,
2420         .READ_METHOD    = READ_FUNCTION,
2421         .write          = ll_file_write,
2422         .WRITE_METHOD   = WRITE_FUNCTION,
2423         .ioctl          = ll_file_ioctl,
2424         .open           = ll_file_open,
2425         .release        = ll_file_release,
2426         .mmap           = ll_file_mmap,
2427         .llseek         = ll_file_seek,
2428 #ifdef HAVE_KERNEL_SENDFILE
2429         .sendfile       = ll_file_sendfile,
2430 #endif
2431 #ifdef HAVE_KERNEL_SPLICE_READ
2432         .splice_read    = ll_file_splice_read,
2433 #endif
2434         .fsync          = ll_fsync,
2435 };
2436
2437 struct file_operations ll_file_operations_flock = {
2438         .read           = ll_file_read,
2439         .READ_METHOD    = READ_FUNCTION,
2440         .write          = ll_file_write,
2441         .WRITE_METHOD   = WRITE_FUNCTION,
2442         .ioctl          = ll_file_ioctl,
2443         .open           = ll_file_open,
2444         .release        = ll_file_release,
2445         .mmap           = ll_file_mmap,
2446         .llseek         = ll_file_seek,
2447 #ifdef HAVE_KERNEL_SENDFILE
2448         .sendfile       = ll_file_sendfile,
2449 #endif
2450 #ifdef HAVE_KERNEL_SPLICE_READ
2451         .splice_read    = ll_file_splice_read,
2452 #endif
2453         .fsync          = ll_fsync,
2454 #ifdef HAVE_F_OP_FLOCK
2455         .flock          = ll_file_flock,
2456 #endif
2457         .lock           = ll_file_flock
2458 };
2459
2460 /* These are for -o noflock - to return ENOSYS on flock calls */
2461 struct file_operations ll_file_operations_noflock = {
2462         .read           = ll_file_read,
2463         .READ_METHOD    = READ_FUNCTION,
2464         .write          = ll_file_write,
2465         .WRITE_METHOD   = WRITE_FUNCTION,
2466         .ioctl          = ll_file_ioctl,
2467         .open           = ll_file_open,
2468         .release        = ll_file_release,
2469         .mmap           = ll_file_mmap,
2470         .llseek         = ll_file_seek,
2471 #ifdef HAVE_KERNEL_SENDFILE
2472         .sendfile       = ll_file_sendfile,
2473 #endif
2474 #ifdef HAVE_KERNEL_SPLICE_READ
2475         .splice_read    = ll_file_splice_read,
2476 #endif
2477         .fsync          = ll_fsync,
2478 #ifdef HAVE_F_OP_FLOCK
2479         .flock          = ll_file_noflock,
2480 #endif
2481         .lock           = ll_file_noflock
2482 };
2483
2484 struct inode_operations ll_file_inode_operations = {
2485 #ifdef HAVE_VFS_INTENT_PATCHES
2486         .setattr_raw    = ll_setattr_raw,
2487 #endif
2488         .setattr        = ll_setattr,
2489         .truncate       = ll_truncate,
2490         .getattr        = ll_getattr,
2491         .permission     = ll_inode_permission,
2492         .setxattr       = ll_setxattr,
2493         .getxattr       = ll_getxattr,
2494         .listxattr      = ll_listxattr,
2495         .removexattr    = ll_removexattr,
2496 #ifdef  HAVE_LINUX_FIEMAP_H
2497         .fiemap         = ll_fiemap,
2498 #endif
2499 };
2500
2501 /* dynamic ioctl number support routins */
2502 static struct llioc_ctl_data {
2503         cfs_rw_semaphore_t      ioc_sem;
2504         cfs_list_t              ioc_head;
2505 } llioc = {
2506         __RWSEM_INITIALIZER(llioc.ioc_sem),
2507         CFS_LIST_HEAD_INIT(llioc.ioc_head)
2508 };
2509
2510
2511 struct llioc_data {
2512         cfs_list_t              iocd_list;
2513         unsigned int            iocd_size;
2514         llioc_callback_t        iocd_cb;
2515         unsigned int            iocd_count;
2516         unsigned int            iocd_cmd[0];
2517 };
2518
2519 void *ll_iocontrol_register(llioc_callback_t cb, int count, unsigned int *cmd)
2520 {
2521         unsigned int size;
2522         struct llioc_data *in_data = NULL;
2523         ENTRY;
2524
2525         if (cb == NULL || cmd == NULL ||
2526             count > LLIOC_MAX_CMD || count < 0)
2527                 RETURN(NULL);
2528
2529         size = sizeof(*in_data) + count * sizeof(unsigned int);
2530         OBD_ALLOC(in_data, size);
2531         if (in_data == NULL)
2532                 RETURN(NULL);
2533
2534         memset(in_data, 0, sizeof(*in_data));
2535         in_data->iocd_size = size;
2536         in_data->iocd_cb = cb;
2537         in_data->iocd_count = count;
2538         memcpy(in_data->iocd_cmd, cmd, sizeof(unsigned int) * count);
2539
2540         cfs_down_write(&llioc.ioc_sem);
2541         cfs_list_add_tail(&in_data->iocd_list, &llioc.ioc_head);
2542         cfs_up_write(&llioc.ioc_sem);
2543
2544         RETURN(in_data);
2545 }
2546
2547 void ll_iocontrol_unregister(void *magic)
2548 {
2549         struct llioc_data *tmp;
2550
2551         if (magic == NULL)
2552                 return;
2553
2554         cfs_down_write(&llioc.ioc_sem);
2555         cfs_list_for_each_entry(tmp, &llioc.ioc_head, iocd_list) {
2556                 if (tmp == magic) {
2557                         unsigned int size = tmp->iocd_size;
2558
2559                         cfs_list_del(&tmp->iocd_list);
2560                         cfs_up_write(&llioc.ioc_sem);
2561
2562                         OBD_FREE(tmp, size);
2563                         return;
2564                 }
2565         }
2566         cfs_up_write(&llioc.ioc_sem);
2567
2568         CWARN("didn't find iocontrol register block with magic: %p\n", magic);
2569 }
2570
2571 EXPORT_SYMBOL(ll_iocontrol_register);
2572 EXPORT_SYMBOL(ll_iocontrol_unregister);
2573
2574 enum llioc_iter ll_iocontrol_call(struct inode *inode, struct file *file,
2575                         unsigned int cmd, unsigned long arg, int *rcp)
2576 {
2577         enum llioc_iter ret = LLIOC_CONT;
2578         struct llioc_data *data;
2579         int rc = -EINVAL, i;
2580
2581         cfs_down_read(&llioc.ioc_sem);
2582         cfs_list_for_each_entry(data, &llioc.ioc_head, iocd_list) {
2583                 for (i = 0; i < data->iocd_count; i++) {
2584                         if (cmd != data->iocd_cmd[i])
2585                                 continue;
2586
2587                         ret = data->iocd_cb(inode, file, cmd, arg, data, &rc);
2588                         break;
2589                 }
2590
2591                 if (ret == LLIOC_STOP)
2592                         break;
2593         }
2594         cfs_up_read(&llioc.ioc_sem);
2595
2596         if (rcp)
2597                 *rcp = rc;
2598         return ret;
2599 }