# endif
#endif
+#ifndef HAVE_LINUX_FILE_DENTRY
+#define file_dentry(file) ((file)->f_dentry)
+#endif
+
#if defined(HAVE_LINUX_LOCKS_LOCK_FILE_WAIT)
# define flock_lock_file_wait locks_lock_file_wait
#endif
afs_linux_key_alloc(struct key_type *type, const char *desc, afs_kuid_t uid,
afs_kgid_t gid, key_perm_t perm, unsigned long flags)
{
-# if defined(KEY_ALLOC_NEEDS_STRUCT_TASK)
+# if defined(KEY_ALLOC_BYPASS_RESTRICTION)
+ return key_alloc(type, desc, uid, gid, current_cred(), perm, flags, NULL);
+# elif defined(KEY_ALLOC_NEEDS_STRUCT_TASK)
return key_alloc(type, desc, uid, gid, current, perm, flags);
# elif defined(KEY_ALLOC_NEEDS_CRED)
return key_alloc(type, desc, uid, gid, current_cred(), perm, flags);
#endif
}
+#if defined(HAVE_LINUX___VFS_WRITE)
+# define AFS_FILE_NEEDS_SET_FS 1
+#elif defined(HAVE_LINUX_KERNEL_WRITE)
+/* #undef AFS_FILE_NEEDS_SET_FS */
+#else
+# define AFS_FILE_NEEDS_SET_FS 1
+#endif
+
static inline int
afs_file_read(struct file *filp, char __user *buf, size_t len, loff_t *pos)
{
-#if defined(HAVE_LINUX___VFS_READ)
+#if defined(HAVE_LINUX___VFS_WRITE)
return __vfs_read(filp, buf, len, pos);
+#elif defined(HAVE_LINUX_KERNEL_WRITE)
+# if defined(LINUX_KERNEL_READ_OFFSET_IS_LAST)
+ return kernel_read(filp, buf, len, pos);
+# else
+ return kernel_read(filp, *pos, buf, len);
+# endif
#else
return filp->f_op->read(filp, buf, len, pos);
#endif
static inline int
afs_file_write(struct file *filp, char __user *buf, size_t len, loff_t *pos)
{
-#if defined(HAVE_LINUX___VFS_READ)
+#if defined(HAVE_LINUX___VFS_WRITE)
return __vfs_write(filp, buf, len, pos);
+#elif defined(HAVE_LINUX_KERNEL_WRITE)
+# if defined(LINUX_KERNEL_READ_OFFSET_IS_LAST)
+ return kernel_write(filp, buf, len, pos);
+# else
+ return kernel_write(filp, buf, len, *pos);
+# endif
#else
return filp->f_op->write(filp, buf, len, pos);
#endif