diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-03-27 19:23:12 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-03-27 19:23:12 -0400 |
| commit | 3ae5080f4c2e293229508dabe7c8a90af4e4c460 (patch) | |
| tree | 9cb11f26905a82b7fac9d3b8f9d61d58bc5c94b0 /include | |
| parent | 2c9e15a011c55ff96b2b8d2b126d1b9a96abba20 (diff) | |
| parent | aabb8fdb41128705fd1627f56fdd571e45fdbcdb (diff) | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6: (37 commits)
fs: avoid I_NEW inodes
Merge code for single and multiple-instance mounts
Remove get_init_pts_sb()
Move common mknod_ptmx() calls into caller
Parse mount options just once and copy them to super block
Unroll essentials of do_remount_sb() into devpts
vfs: simple_set_mnt() should return void
fs: move bdev code out of buffer.c
constify dentry_operations: rest
constify dentry_operations: configfs
constify dentry_operations: sysfs
constify dentry_operations: JFS
constify dentry_operations: OCFS2
constify dentry_operations: GFS2
constify dentry_operations: FAT
constify dentry_operations: FUSE
constify dentry_operations: procfs
constify dentry_operations: ecryptfs
constify dentry_operations: CIFS
constify dentry_operations: AFS
...
Diffstat (limited to 'include')
| -rw-r--r-- | include/linux/buffer_head.h | 7 | ||||
| -rw-r--r-- | include/linux/compat.h | 8 | ||||
| -rw-r--r-- | include/linux/dcache.h | 2 | ||||
| -rw-r--r-- | include/linux/fs.h | 220 | ||||
| -rw-r--r-- | include/linux/ncp_fs.h | 2 | ||||
| -rw-r--r-- | include/linux/nfs_fs.h | 2 | ||||
| -rw-r--r-- | include/linux/nfs_xdr.h | 2 |
7 files changed, 197 insertions, 46 deletions
diff --git a/include/linux/buffer_head.h b/include/linux/buffer_head.h index bd7ac793be19..f19fd9045ea0 100644 --- a/include/linux/buffer_head.h +++ b/include/linux/buffer_head.h | |||
| @@ -165,15 +165,8 @@ int sync_mapping_buffers(struct address_space *mapping); | |||
| 165 | void unmap_underlying_metadata(struct block_device *bdev, sector_t block); | 165 | void unmap_underlying_metadata(struct block_device *bdev, sector_t block); |
| 166 | 166 | ||
| 167 | void mark_buffer_async_write(struct buffer_head *bh); | 167 | void mark_buffer_async_write(struct buffer_head *bh); |
| 168 | void invalidate_bdev(struct block_device *); | ||
| 169 | int sync_blockdev(struct block_device *bdev); | ||
| 170 | void __wait_on_buffer(struct buffer_head *); | 168 | void __wait_on_buffer(struct buffer_head *); |
| 171 | wait_queue_head_t *bh_waitq_head(struct buffer_head *bh); | 169 | wait_queue_head_t *bh_waitq_head(struct buffer_head *bh); |
| 172 | int fsync_bdev(struct block_device *); | ||
| 173 | struct super_block *freeze_bdev(struct block_device *); | ||
| 174 | int thaw_bdev(struct block_device *, struct super_block *); | ||
| 175 | int fsync_super(struct super_block *); | ||
| 176 | int fsync_no_super(struct block_device *); | ||
| 177 | struct buffer_head *__find_get_block(struct block_device *bdev, sector_t block, | 170 | struct buffer_head *__find_get_block(struct block_device *bdev, sector_t block, |
| 178 | unsigned size); | 171 | unsigned size); |
| 179 | struct buffer_head *__getblk(struct block_device *bdev, sector_t block, | 172 | struct buffer_head *__getblk(struct block_device *bdev, sector_t block, |
diff --git a/include/linux/compat.h b/include/linux/compat.h index 3fd2194ff573..b880864672de 100644 --- a/include/linux/compat.h +++ b/include/linux/compat.h | |||
| @@ -125,6 +125,13 @@ struct compat_dirent { | |||
| 125 | char d_name[256]; | 125 | char d_name[256]; |
| 126 | }; | 126 | }; |
| 127 | 127 | ||
| 128 | struct compat_ustat { | ||
| 129 | compat_daddr_t f_tfree; | ||
| 130 | compat_ino_t f_tinode; | ||
| 131 | char f_fname[6]; | ||
| 132 | char f_fpack[6]; | ||
| 133 | }; | ||
| 134 | |||
| 128 | typedef union compat_sigval { | 135 | typedef union compat_sigval { |
| 129 | compat_int_t sival_int; | 136 | compat_int_t sival_int; |
| 130 | compat_uptr_t sival_ptr; | 137 | compat_uptr_t sival_ptr; |
| @@ -178,6 +185,7 @@ long compat_sys_semtimedop(int semid, struct sembuf __user *tsems, | |||
| 178 | unsigned nsems, const struct compat_timespec __user *timeout); | 185 | unsigned nsems, const struct compat_timespec __user *timeout); |
| 179 | asmlinkage long compat_sys_keyctl(u32 option, | 186 | asmlinkage long compat_sys_keyctl(u32 option, |
| 180 | u32 arg2, u32 arg3, u32 arg4, u32 arg5); | 187 | u32 arg2, u32 arg3, u32 arg4, u32 arg5); |
| 188 | asmlinkage long compat_sys_ustat(unsigned dev, struct compat_ustat __user *u32); | ||
| 181 | 189 | ||
| 182 | asmlinkage ssize_t compat_sys_readv(unsigned long fd, | 190 | asmlinkage ssize_t compat_sys_readv(unsigned long fd, |
| 183 | const struct compat_iovec __user *vec, unsigned long vlen); | 191 | const struct compat_iovec __user *vec, unsigned long vlen); |
diff --git a/include/linux/dcache.h b/include/linux/dcache.h index c66d22487bf8..15156364d196 100644 --- a/include/linux/dcache.h +++ b/include/linux/dcache.h | |||
| @@ -112,7 +112,7 @@ struct dentry { | |||
| 112 | struct list_head d_subdirs; /* our children */ | 112 | struct list_head d_subdirs; /* our children */ |
| 113 | struct list_head d_alias; /* inode alias list */ | 113 | struct list_head d_alias; /* inode alias list */ |
| 114 | unsigned long d_time; /* used by d_revalidate */ | 114 | unsigned long d_time; /* used by d_revalidate */ |
| 115 | struct dentry_operations *d_op; | 115 | const struct dentry_operations *d_op; |
| 116 | struct super_block *d_sb; /* The root of the dentry tree */ | 116 | struct super_block *d_sb; /* The root of the dentry tree */ |
| 117 | void *d_fsdata; /* fs-specific data */ | 117 | void *d_fsdata; /* fs-specific data */ |
| 118 | 118 | ||
diff --git a/include/linux/fs.h b/include/linux/fs.h index 1cd44f727dac..42436ae42f70 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
| @@ -1064,34 +1064,147 @@ extern int lease_modify(struct file_lock **, int); | |||
| 1064 | extern int lock_may_read(struct inode *, loff_t start, unsigned long count); | 1064 | extern int lock_may_read(struct inode *, loff_t start, unsigned long count); |
| 1065 | extern int lock_may_write(struct inode *, loff_t start, unsigned long count); | 1065 | extern int lock_may_write(struct inode *, loff_t start, unsigned long count); |
| 1066 | #else /* !CONFIG_FILE_LOCKING */ | 1066 | #else /* !CONFIG_FILE_LOCKING */ |
| 1067 | #define fcntl_getlk(a, b) ({ -EINVAL; }) | 1067 | static inline int fcntl_getlk(struct file *file, struct flock __user *user) |
| 1068 | #define fcntl_setlk(a, b, c, d) ({ -EACCES; }) | 1068 | { |
| 1069 | return -EINVAL; | ||
| 1070 | } | ||
| 1071 | |||
| 1072 | static inline int fcntl_setlk(unsigned int fd, struct file *file, | ||
| 1073 | unsigned int cmd, struct flock __user *user) | ||
| 1074 | { | ||
| 1075 | return -EACCES; | ||
| 1076 | } | ||
| 1077 | |||
| 1069 | #if BITS_PER_LONG == 32 | 1078 | #if BITS_PER_LONG == 32 |
| 1070 | #define fcntl_getlk64(a, b) ({ -EINVAL; }) | 1079 | static inline int fcntl_getlk64(struct file *file, struct flock64 __user *user) |
| 1071 | #define fcntl_setlk64(a, b, c, d) ({ -EACCES; }) | 1080 | { |
| 1081 | return -EINVAL; | ||
| 1082 | } | ||
| 1083 | |||
| 1084 | static inline int fcntl_setlk64(unsigned int fd, struct file *file, | ||
| 1085 | unsigned int cmd, struct flock64 __user *user) | ||
| 1086 | { | ||
| 1087 | return -EACCES; | ||
| 1088 | } | ||
| 1072 | #endif | 1089 | #endif |
| 1073 | #define fcntl_setlease(a, b, c) ({ 0; }) | 1090 | static inline int fcntl_setlease(unsigned int fd, struct file *filp, long arg) |
| 1074 | #define fcntl_getlease(a) ({ 0; }) | 1091 | { |
| 1075 | #define locks_init_lock(a) ({ }) | 1092 | return 0; |
| 1076 | #define __locks_copy_lock(a, b) ({ }) | 1093 | } |
| 1077 | #define locks_copy_lock(a, b) ({ }) | 1094 | |
| 1078 | #define locks_remove_posix(a, b) ({ }) | 1095 | static inline int fcntl_getlease(struct file *filp) |
| 1079 | #define locks_remove_flock(a) ({ }) | 1096 | { |
| 1080 | #define posix_test_lock(a, b) ({ 0; }) | 1097 | return 0; |
| 1081 | #define posix_lock_file(a, b, c) ({ -ENOLCK; }) | 1098 | } |
| 1082 | #define posix_lock_file_wait(a, b) ({ -ENOLCK; }) | 1099 | |
| 1083 | #define posix_unblock_lock(a, b) (-ENOENT) | 1100 | static inline void locks_init_lock(struct file_lock *fl) |
| 1084 | #define vfs_test_lock(a, b) ({ 0; }) | 1101 | { |
| 1085 | #define vfs_lock_file(a, b, c, d) (-ENOLCK) | 1102 | return; |
| 1086 | #define vfs_cancel_lock(a, b) ({ 0; }) | 1103 | } |
| 1087 | #define flock_lock_file_wait(a, b) ({ -ENOLCK; }) | 1104 | |
| 1088 | #define __break_lease(a, b) ({ 0; }) | 1105 | static inline void __locks_copy_lock(struct file_lock *new, struct file_lock *fl) |
| 1089 | #define lease_get_mtime(a, b) ({ }) | 1106 | { |
| 1090 | #define generic_setlease(a, b, c) ({ -EINVAL; }) | 1107 | return; |
| 1091 | #define vfs_setlease(a, b, c) ({ -EINVAL; }) | 1108 | } |
| 1092 | #define lease_modify(a, b) ({ -EINVAL; }) | 1109 | |
| 1093 | #define lock_may_read(a, b, c) ({ 1; }) | 1110 | static inline void locks_copy_lock(struct file_lock *new, struct file_lock *fl) |
| 1094 | #define lock_may_write(a, b, c) ({ 1; }) | 1111 | { |
| 1112 | return; | ||
| 1113 | } | ||
| 1114 | |||
| 1115 | static inline void locks_remove_posix(struct file *filp, fl_owner_t owner) | ||
| 1116 | { | ||
| 1117 | return; | ||
| 1118 | } | ||
| 1119 | |||
| 1120 | static inline void locks_remove_flock(struct file *filp) | ||
| 1121 | { | ||
| 1122 | return; | ||
| 1123 | } | ||
| 1124 | |||
| 1125 | static inline void posix_test_lock(struct file *filp, struct file_lock *fl) | ||
| 1126 | { | ||
| 1127 | return; | ||
| 1128 | } | ||
| 1129 | |||
| 1130 | static inline int posix_lock_file(struct file *filp, struct file_lock *fl, | ||
| 1131 | struct file_lock *conflock) | ||
| 1132 | { | ||
| 1133 | return -ENOLCK; | ||
| 1134 | } | ||
| 1135 | |||
| 1136 | static inline int posix_lock_file_wait(struct file *filp, struct file_lock *fl) | ||
| 1137 | { | ||
| 1138 | return -ENOLCK; | ||
| 1139 | } | ||
| 1140 | |||
| 1141 | static inline int posix_unblock_lock(struct file *filp, | ||
| 1142 | struct file_lock *waiter) | ||
| 1143 | { | ||
| 1144 | return -ENOENT; | ||
| 1145 | } | ||
| 1146 | |||
| 1147 | static inline int vfs_test_lock(struct file *filp, struct file_lock *fl) | ||
| 1148 | { | ||
| 1149 | return 0; | ||
| 1150 | } | ||
| 1151 | |||
| 1152 | static inline int vfs_lock_file(struct file *filp, unsigned int cmd, | ||
| 1153 | struct file_lock *fl, struct file_lock *conf) | ||
| 1154 | { | ||
| 1155 | return -ENOLCK; | ||
| 1156 | } | ||
| 1157 | |||
| 1158 | static inline int vfs_cancel_lock(struct file *filp, struct file_lock *fl) | ||
| 1159 | { | ||
| 1160 | return 0; | ||
| 1161 | } | ||
| 1162 | |||
| 1163 | static inline int flock_lock_file_wait(struct file *filp, | ||
| 1164 | struct file_lock *request) | ||
| 1165 | { | ||
| 1166 | return -ENOLCK; | ||
| 1167 | } | ||
| 1168 | |||
| 1169 | static inline int __break_lease(struct inode *inode, unsigned int mode) | ||
| 1170 | { | ||
| 1171 | return 0; | ||
| 1172 | } | ||
| 1173 | |||
| 1174 | static inline void lease_get_mtime(struct inode *inode, struct timespec *time) | ||
| 1175 | { | ||
| 1176 | return; | ||
| 1177 | } | ||
| 1178 | |||
| 1179 | static inline int generic_setlease(struct file *filp, long arg, | ||
| 1180 | struct file_lock **flp) | ||
| 1181 | { | ||
| 1182 | return -EINVAL; | ||
| 1183 | } | ||
| 1184 | |||
| 1185 | static inline int vfs_setlease(struct file *filp, long arg, | ||
| 1186 | struct file_lock **lease) | ||
| 1187 | { | ||
| 1188 | return -EINVAL; | ||
| 1189 | } | ||
| 1190 | |||
| 1191 | static inline int lease_modify(struct file_lock **before, int arg) | ||
| 1192 | { | ||
| 1193 | return -EINVAL; | ||
| 1194 | } | ||
| 1195 | |||
| 1196 | static inline int lock_may_read(struct inode *inode, loff_t start, | ||
| 1197 | unsigned long len) | ||
| 1198 | { | ||
| 1199 | return 1; | ||
| 1200 | } | ||
| 1201 | |||
| 1202 | static inline int lock_may_write(struct inode *inode, loff_t start, | ||
| 1203 | unsigned long len) | ||
| 1204 | { | ||
| 1205 | return 1; | ||
| 1206 | } | ||
| 1207 | |||
| 1095 | #endif /* !CONFIG_FILE_LOCKING */ | 1208 | #endif /* !CONFIG_FILE_LOCKING */ |
| 1096 | 1209 | ||
| 1097 | 1210 | ||
| @@ -1607,7 +1720,7 @@ struct super_block *sget(struct file_system_type *type, | |||
| 1607 | extern int get_sb_pseudo(struct file_system_type *, char *, | 1720 | extern int get_sb_pseudo(struct file_system_type *, char *, |
| 1608 | const struct super_operations *ops, unsigned long, | 1721 | const struct super_operations *ops, unsigned long, |
| 1609 | struct vfsmount *mnt); | 1722 | struct vfsmount *mnt); |
| 1610 | extern int simple_set_mnt(struct vfsmount *mnt, struct super_block *sb); | 1723 | extern void simple_set_mnt(struct vfsmount *mnt, struct super_block *sb); |
| 1611 | int __put_super_and_need_restart(struct super_block *sb); | 1724 | int __put_super_and_need_restart(struct super_block *sb); |
| 1612 | 1725 | ||
| 1613 | /* Alas, no aliases. Too much hassle with bringing module.h everywhere */ | 1726 | /* Alas, no aliases. Too much hassle with bringing module.h everywhere */ |
| @@ -1688,13 +1801,44 @@ static inline int break_lease(struct inode *inode, unsigned int mode) | |||
| 1688 | return 0; | 1801 | return 0; |
| 1689 | } | 1802 | } |
| 1690 | #else /* !CONFIG_FILE_LOCKING */ | 1803 | #else /* !CONFIG_FILE_LOCKING */ |
| 1691 | #define locks_mandatory_locked(a) ({ 0; }) | 1804 | static inline int locks_mandatory_locked(struct inode *inode) |
| 1692 | #define locks_mandatory_area(a, b, c, d, e) ({ 0; }) | 1805 | { |
| 1693 | #define __mandatory_lock(a) ({ 0; }) | 1806 | return 0; |
| 1694 | #define mandatory_lock(a) ({ 0; }) | 1807 | } |
| 1695 | #define locks_verify_locked(a) ({ 0; }) | 1808 | |
| 1696 | #define locks_verify_truncate(a, b, c) ({ 0; }) | 1809 | static inline int locks_mandatory_area(int rw, struct inode *inode, |
| 1697 | #define break_lease(a, b) ({ 0; }) | 1810 | struct file *filp, loff_t offset, |
| 1811 | size_t count) | ||
| 1812 | { | ||
| 1813 | return 0; | ||
| 1814 | } | ||
| 1815 | |||
| 1816 | static inline int __mandatory_lock(struct inode *inode) | ||
| 1817 | { | ||
| 1818 | return 0; | ||
| 1819 | } | ||
| 1820 | |||
| 1821 | static inline int mandatory_lock(struct inode *inode) | ||
| 1822 | { | ||
| 1823 | return 0; | ||
| 1824 | } | ||
| 1825 | |||
| 1826 | static inline int locks_verify_locked(struct inode *inode) | ||
| 1827 | { | ||
| 1828 | return 0; | ||
| 1829 | } | ||
| 1830 | |||
| 1831 | static inline int locks_verify_truncate(struct inode *inode, struct file *filp, | ||
| 1832 | size_t size) | ||
| 1833 | { | ||
| 1834 | return 0; | ||
| 1835 | } | ||
| 1836 | |||
| 1837 | static inline int break_lease(struct inode *inode, unsigned int mode) | ||
| 1838 | { | ||
| 1839 | return 0; | ||
| 1840 | } | ||
| 1841 | |||
| 1698 | #endif /* CONFIG_FILE_LOCKING */ | 1842 | #endif /* CONFIG_FILE_LOCKING */ |
| 1699 | 1843 | ||
| 1700 | /* fs/open.c */ | 1844 | /* fs/open.c */ |
| @@ -1731,6 +1875,13 @@ extern void bd_set_size(struct block_device *, loff_t size); | |||
| 1731 | extern void bd_forget(struct inode *inode); | 1875 | extern void bd_forget(struct inode *inode); |
| 1732 | extern void bdput(struct block_device *); | 1876 | extern void bdput(struct block_device *); |
| 1733 | extern struct block_device *open_by_devnum(dev_t, fmode_t); | 1877 | extern struct block_device *open_by_devnum(dev_t, fmode_t); |
| 1878 | extern void invalidate_bdev(struct block_device *); | ||
| 1879 | extern int sync_blockdev(struct block_device *bdev); | ||
| 1880 | extern struct super_block *freeze_bdev(struct block_device *); | ||
| 1881 | extern int thaw_bdev(struct block_device *bdev, struct super_block *sb); | ||
| 1882 | extern int fsync_bdev(struct block_device *); | ||
| 1883 | extern int fsync_super(struct super_block *); | ||
| 1884 | extern int fsync_no_super(struct block_device *); | ||
| 1734 | #else | 1885 | #else |
| 1735 | static inline void bd_forget(struct inode *inode) {} | 1886 | static inline void bd_forget(struct inode *inode) {} |
| 1736 | #endif | 1887 | #endif |
| @@ -1882,7 +2033,6 @@ static inline void allow_write_access(struct file *file) | |||
| 1882 | if (file) | 2033 | if (file) |
| 1883 | atomic_inc(&file->f_path.dentry->d_inode->i_writecount); | 2034 | atomic_inc(&file->f_path.dentry->d_inode->i_writecount); |
| 1884 | } | 2035 | } |
| 1885 | extern int do_pipe(int *); | ||
| 1886 | extern int do_pipe_flags(int *, int); | 2036 | extern int do_pipe_flags(int *, int); |
| 1887 | extern struct file *create_read_pipe(struct file *f, int flags); | 2037 | extern struct file *create_read_pipe(struct file *f, int flags); |
| 1888 | extern struct file *create_write_pipe(int flags); | 2038 | extern struct file *create_write_pipe(int flags); |
diff --git a/include/linux/ncp_fs.h b/include/linux/ncp_fs.h index f69e66d151cc..30b06c893944 100644 --- a/include/linux/ncp_fs.h +++ b/include/linux/ncp_fs.h | |||
| @@ -204,7 +204,7 @@ void ncp_update_inode2(struct inode *, struct ncp_entry_info *); | |||
| 204 | /* linux/fs/ncpfs/dir.c */ | 204 | /* linux/fs/ncpfs/dir.c */ |
| 205 | extern const struct inode_operations ncp_dir_inode_operations; | 205 | extern const struct inode_operations ncp_dir_inode_operations; |
| 206 | extern const struct file_operations ncp_dir_operations; | 206 | extern const struct file_operations ncp_dir_operations; |
| 207 | extern struct dentry_operations ncp_root_dentry_operations; | 207 | extern const struct dentry_operations ncp_root_dentry_operations; |
| 208 | int ncp_conn_logged_in(struct super_block *); | 208 | int ncp_conn_logged_in(struct super_block *); |
| 209 | int ncp_date_dos2unix(__le16 time, __le16 date); | 209 | int ncp_date_dos2unix(__le16 time, __le16 date); |
| 210 | void ncp_date_unix2dos(int unix_date, __le16 * time, __le16 * date); | 210 | void ncp_date_unix2dos(int unix_date, __le16 * time, __le16 * date); |
diff --git a/include/linux/nfs_fs.h b/include/linux/nfs_fs.h index db867b04ac3c..8cc8807f77d6 100644 --- a/include/linux/nfs_fs.h +++ b/include/linux/nfs_fs.h | |||
| @@ -415,7 +415,7 @@ extern const struct inode_operations nfs_dir_inode_operations; | |||
| 415 | extern const struct inode_operations nfs3_dir_inode_operations; | 415 | extern const struct inode_operations nfs3_dir_inode_operations; |
| 416 | #endif /* CONFIG_NFS_V3 */ | 416 | #endif /* CONFIG_NFS_V3 */ |
| 417 | extern const struct file_operations nfs_dir_operations; | 417 | extern const struct file_operations nfs_dir_operations; |
| 418 | extern struct dentry_operations nfs_dentry_operations; | 418 | extern const struct dentry_operations nfs_dentry_operations; |
| 419 | 419 | ||
| 420 | extern void nfs_force_lookup_revalidate(struct inode *dir); | 420 | extern void nfs_force_lookup_revalidate(struct inode *dir); |
| 421 | extern int nfs_instantiate(struct dentry *dentry, struct nfs_fh *fh, struct nfs_fattr *fattr); | 421 | extern int nfs_instantiate(struct dentry *dentry, struct nfs_fh *fh, struct nfs_fattr *fattr); |
diff --git a/include/linux/nfs_xdr.h b/include/linux/nfs_xdr.h index 2e5f00066afd..43a713fce11c 100644 --- a/include/linux/nfs_xdr.h +++ b/include/linux/nfs_xdr.h | |||
| @@ -785,7 +785,7 @@ struct nfs_access_entry; | |||
| 785 | */ | 785 | */ |
| 786 | struct nfs_rpc_ops { | 786 | struct nfs_rpc_ops { |
| 787 | u32 version; /* Protocol version */ | 787 | u32 version; /* Protocol version */ |
| 788 | struct dentry_operations *dentry_ops; | 788 | const struct dentry_operations *dentry_ops; |
| 789 | const struct inode_operations *dir_inode_ops; | 789 | const struct inode_operations *dir_inode_ops; |
| 790 | const struct inode_operations *file_inode_ops; | 790 | const struct inode_operations *file_inode_ops; |
| 791 | 791 | ||
