summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/compat/svr4/svr4_fcntl.c11
-rw-r--r--sys/compat/svr4/svr4_misc.c36
-rw-r--r--sys/compat/svr4/syscalls.master8
3 files changed, 50 insertions, 5 deletions
diff --git a/sys/compat/svr4/svr4_fcntl.c b/sys/compat/svr4/svr4_fcntl.c
index 0257f231fd1..0cd95f3661b 100644
--- a/sys/compat/svr4/svr4_fcntl.c
+++ b/sys/compat/svr4/svr4_fcntl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: svr4_fcntl.c,v 1.15 2000/04/21 15:50:21 millert Exp $ */
+/* $OpenBSD: svr4_fcntl.c,v 1.16 2000/06/28 23:48:15 fgsch Exp $ */
/* $NetBSD: svr4_fcntl.c,v 1.14 1995/10/14 20:24:24 christos Exp $ */
/*
@@ -302,6 +302,15 @@ svr4_sys_creat(p, v, retval)
return sys_open(p, &cup, retval);
}
+int
+svr4_sys_creat64(p, v, retval)
+ register struct proc *p;
+ void *v;
+ register_t *retval;
+{
+ return (svr4_sys_creat(p, v, retval));
+}
+
int
svr4_sys_llseek(p, v, retval)
register struct proc *p;
diff --git a/sys/compat/svr4/svr4_misc.c b/sys/compat/svr4/svr4_misc.c
index 855db9cc971..b4ecc81c64f 100644
--- a/sys/compat/svr4/svr4_misc.c
+++ b/sys/compat/svr4/svr4_misc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: svr4_misc.c,v 1.26 2000/06/24 21:00:30 fgsch Exp $ */
+/* $OpenBSD: svr4_misc.c,v 1.27 2000/06/28 23:48:15 fgsch Exp $ */
/* $NetBSD: svr4_misc.c,v 1.42 1996/12/06 03:22:34 christos Exp $ */
/*
@@ -492,6 +492,40 @@ svr4_sys_mmap(p, v, retval)
}
int
+svr4_sys_mmap64(p, v, retval)
+ register struct proc *p;
+ void *v;
+ register_t *retval;
+{
+ struct svr4_sys_mmap64_args *uap = v;
+ struct sys_mmap_args mm;
+ void *rp;
+#define _MAP_NEW 0x80000000
+ /*
+ * Verify the arguments.
+ */
+ if (SCARG(uap, prot) & ~(PROT_READ | PROT_WRITE | PROT_EXEC))
+ return EINVAL; /* XXX still needed? */
+
+ if (SCARG(uap, len) == 0)
+ return EINVAL;
+
+ SCARG(&mm, prot) = SCARG(uap, prot);
+ SCARG(&mm, len) = SCARG(uap, len);
+ SCARG(&mm, flags) = SCARG(uap, flags) & ~_MAP_NEW;
+ SCARG(&mm, fd) = SCARG(uap, fd);
+ SCARG(&mm, addr) = SCARG(uap, addr);
+ SCARG(&mm, pos) = SCARG(uap, pos);
+
+ rp = (void *) round_page(p->p_vmspace->vm_daddr + MAXDSIZ);
+ if ((SCARG(&mm, flags) & MAP_FIXED) == 0 &&
+ SCARG(&mm, addr) != 0 && SCARG(&mm, addr) < rp)
+ SCARG(&mm, addr) = rp;
+
+ return sys_mmap(p, &mm, retval);
+}
+
+int
svr4_sys_fchroot(p, v, retval)
register struct proc *p;
void *v;
diff --git a/sys/compat/svr4/syscalls.master b/sys/compat/svr4/syscalls.master
index 2a1f6ade88d..e33d99da96c 100644
--- a/sys/compat/svr4/syscalls.master
+++ b/sys/compat/svr4/syscalls.master
@@ -1,4 +1,4 @@
- $OpenBSD: syscalls.master,v 1.28 2000/06/24 21:00:30 fgsch Exp $
+ $OpenBSD: syscalls.master,v 1.29 2000/06/28 23:48:15 fgsch Exp $
; $NetBSD: syscalls.master,v 1.17 1996/02/10 17:12:51 christos Exp $
; @(#)syscalls.master 8.1 (Berkeley) 7/19/93
@@ -325,7 +325,9 @@
213 STD { int svr4_sys_getdents64(int fd, \
struct svr4_dirent64 *dp, \
int nbytes); }
-214 UNIMPL mmap64
+214 STD { int svr4_sys_mmap64(svr4_caddr_t addr, \
+ svr4_size_t len, int prot, int flags, int fd, \
+ svr4_off64_t pos); }
215 STD { int svr4_sys_stat64(const char *path, \
struct svr4_stat64 *sb); }
216 STD { int svr4_sys_lstat64(const char *path, \
@@ -339,7 +341,7 @@
221 UNIMPL getrlimit64
222 UNIMPL pread64
223 UNIMPL pwrite64
-224 UNIMPL creat64
+224 STD { int svr4_sys_creat64(char *path, int mode); }
225 STD { int svr4_sys_open64(char *path, int flags, \
int mode); }
226 UNIMPL rpcsys