diff options
Diffstat (limited to 'fs/dcookies.c')
| -rw-r--r-- | fs/dcookies.c | 20 | 
1 files changed, 14 insertions, 6 deletions
diff --git a/fs/dcookies.c b/fs/dcookies.c index a21cabdbd87..ac44a69fbea 100644 --- a/fs/dcookies.c +++ b/fs/dcookies.c @@ -13,7 +13,7 @@   */  #include <linux/syscalls.h> -#include <linux/module.h> +#include <linux/export.h>  #include <linux/slab.h>  #include <linux/list.h>  #include <linux/mount.h> @@ -25,6 +25,7 @@  #include <linux/dcookies.h>  #include <linux/mutex.h>  #include <linux/path.h> +#include <linux/compat.h>  #include <asm/uaccess.h>  /* The dcookies are allocated from a kmem_cache and @@ -145,7 +146,7 @@ out:  /* And here is where the userspace process can look up the cookie value   * to retrieve the path.   */ -SYSCALL_DEFINE(lookup_dcookie)(u64 cookie64, char __user * buf, size_t len) +SYSCALL_DEFINE3(lookup_dcookie, u64, cookie64, char __user *, buf, size_t, len)  {  	unsigned long cookie = (unsigned long)cookie64;  	int err = -EINVAL; @@ -178,6 +179,8 @@ SYSCALL_DEFINE(lookup_dcookie)(u64 cookie64, char __user * buf, size_t len)  	/* FIXME: (deleted) ? */  	path = d_path(&dcs->path, kbuf, PAGE_SIZE); +	mutex_unlock(&dcookie_mutex); +  	if (IS_ERR(path)) {  		err = PTR_ERR(path);  		goto out_free; @@ -194,16 +197,21 @@ SYSCALL_DEFINE(lookup_dcookie)(u64 cookie64, char __user * buf, size_t len)  out_free:  	kfree(kbuf); +	return err;  out:  	mutex_unlock(&dcookie_mutex);  	return err;  } -#ifdef CONFIG_HAVE_SYSCALL_WRAPPERS -asmlinkage long SyS_lookup_dcookie(u64 cookie64, long buf, long len) + +#ifdef CONFIG_COMPAT +COMPAT_SYSCALL_DEFINE4(lookup_dcookie, u32, w0, u32, w1, char __user *, buf, compat_size_t, len)  { -	return SYSC_lookup_dcookie(cookie64, (char __user *) buf, (size_t) len); +#ifdef __BIG_ENDIAN +	return sys_lookup_dcookie(((u64)w0 << 32) | w1, buf, len); +#else +	return sys_lookup_dcookie(((u64)w1 << 32) | w0, buf, len); +#endif  } -SYSCALL_ALIAS(sys_lookup_dcookie, SyS_lookup_dcookie);  #endif  static int dcookie_init(void)  | 
