Whamcloud - gitweb
Updated parameters for obdfs_writepage() to use struct *dentry instead of
[fs/lustre-release.git] / lustre / obdfs / file.c
1 /*
2  *  linux/fs/ext2/file.c
3  *
4  * Copyright (C) 1992, 1993, 1994, 1995
5  * Remy Card (card@masi.ibp.fr)
6  * Laboratoire MASI - Institut Blaise Pascal
7  * Universite Pierre et Marie Curie (Paris VI)
8  *
9  *  from
10  *
11  *  linux/fs/minix/file.c
12  *
13  *  Copyright (C) 1991, 1992  Linus Torvalds
14  *
15  *  ext2 fs regular file handling primitives
16  *
17  *  64-bit file support on 64-bit platforms by Jakub Jelinek
18  *      (jj@sunsite.ms.mff.cuni.cz)
19  */
20
21 #include <asm/uaccess.h>
22 #include <asm/system.h>
23
24 #include <linux/errno.h>
25 #include <linux/fs.h>
26 #include <linux/ext2_fs.h>
27 #include <linux/fcntl.h>
28 #include <linux/sched.h>
29 #include <linux/stat.h>
30 #include <linux/locks.h>
31 #include <linux/mm.h>
32 #include <linux/pagemap.h>
33 #include <linux/smp_lock.h>
34
35 #include <linux/obd_support.h>
36 #include <linux/obdfs.h>
37
38 static inline void remove_suid(struct inode *inode)
39 {
40         unsigned int mode;
41
42         /* set S_IGID if S_IXGRP is set, and always set S_ISUID */
43         mode = (inode->i_mode & S_IXGRP)*(S_ISGID/S_IXGRP) | S_ISUID;
44
45         /* was any of the uid bits set? */
46         mode &= inode->i_mode;
47         if (mode && !capable(CAP_FSETID)) {
48                 inode->i_mode &= ~mode;
49                 mark_inode_dirty(inode);
50         }
51 }
52
53 /*
54  * Write to a file (through the page cache).
55  */
56 ssize_t obdfs_file_write(struct file *file, const char *buf, size_t count, loff_t *ppos)
57 {
58         ssize_t retval;
59         CDEBUG(D_INODE, "Writing inode %ld, %d bytes, offset %ld\n", file->f_dentry->d_inode->i_ino, count, (long)*ppos);
60
61         retval = generic_file_write(file, buf, count,
62                                     ppos, obdfs_write_one_page);
63         CDEBUG(D_INODE, "Wrote %d\n", retval);
64         if (retval > 0) {
65                 struct inode *inode = file->f_dentry->d_inode;
66                 remove_suid(inode);
67                 inode->i_ctime = inode->i_mtime = CURRENT_TIME;
68                 mark_inode_dirty(inode);
69         }
70         EXIT;
71         return retval;
72 }