Commit 67d8f3d0 authored by Stephen Rothwell's avatar Stephen Rothwell Committed by David Mosberger

[PATCH] ia64: [COMPAT] compat_sys_[f]statfs

parent 68f9116b
......@@ -297,8 +297,8 @@ ia32_syscall_table:
data8 sys_getpriority
data8 sys_setpriority
data8 sys32_ni_syscall /* old profil syscall holder */
data8 sys32_statfs
data8 sys32_fstatfs /* 100 */
data8 compat_sys_statfs
data8 compat_sys_fstatfs /* 100 */
data8 sys32_ioperm
data8 sys32_socketcall
data8 sys_syslog
......
......@@ -609,61 +609,6 @@ sys32_pipe (int *fd)
return retval;
}
static inline int
put_statfs (struct statfs32 *ubuf, struct statfs *kbuf)
{
int err;
if (!access_ok(VERIFY_WRITE, ubuf, sizeof(*ubuf)))
return -EFAULT;
err = __put_user(kbuf->f_type, &ubuf->f_type);
err |= __put_user(kbuf->f_bsize, &ubuf->f_bsize);
err |= __put_user(kbuf->f_blocks, &ubuf->f_blocks);
err |= __put_user(kbuf->f_bfree, &ubuf->f_bfree);
err |= __put_user(kbuf->f_bavail, &ubuf->f_bavail);
err |= __put_user(kbuf->f_files, &ubuf->f_files);
err |= __put_user(kbuf->f_ffree, &ubuf->f_ffree);
err |= __put_user(kbuf->f_namelen, &ubuf->f_namelen);
err |= __put_user(kbuf->f_fsid.val[0], &ubuf->f_fsid.val[0]);
err |= __put_user(kbuf->f_fsid.val[1], &ubuf->f_fsid.val[1]);
return err;
}
extern asmlinkage long sys_statfs(const char * path, struct statfs * buf);
asmlinkage long
sys32_statfs (const char *path, struct statfs32 *buf)
{
int ret;
struct statfs s;
mm_segment_t old_fs = get_fs();
set_fs(KERNEL_DS);
ret = sys_statfs(path, &s);
set_fs(old_fs);
if (put_statfs(buf, &s))
return -EFAULT;
return ret;
}
extern asmlinkage long sys_fstatfs(unsigned int fd, struct statfs * buf);
asmlinkage long
sys32_fstatfs (unsigned int fd, struct statfs32 *buf)
{
int ret;
struct statfs s;
mm_segment_t old_fs = get_fs();
set_fs(KERNEL_DS);
ret = sys_fstatfs(fd, &s);
set_fs(old_fs);
if (put_statfs(buf, &s))
return -EFAULT;
return ret;
}
static inline long
get_tv32 (struct timeval *o, struct compat_timeval *i)
{
......
......@@ -61,11 +61,24 @@ struct compat_stat {
};
struct compat_flock {
short l_type;
short l_whence;
compat_off_t l_start;
compat_off_t l_len;
compat_pid_t l_pid;
short l_type;
short l_whence;
compat_off_t l_start;
compat_off_t l_len;
compat_pid_t l_pid;
};
struct compat_statfs {
int f_type;
int f_bsize;
int f_blocks;
int f_bfree;
int f_bavail;
int f_files;
int f_ffree;
compat_fsid_t f_fsid;
int f_namelen; /* SunOS ignores this field. */
int f_spare[6];
};
typedef u32 compat_old_sigset_t; /* at least 32 bits */
......
......@@ -193,19 +193,6 @@ struct stat64 {
unsigned int st_ino_hi;
};
struct statfs32 {
int f_type;
int f_bsize;
int f_blocks;
int f_bfree;
int f_bavail;
int f_files;
int f_ffree;
compat_fsid_t f_fsid;
int f_namelen; /* SunOS ignores this field. */
int f_spare[6];
};
typedef union sigval32 {
int sival_int;
unsigned int sival_ptr;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment