diff options
author | luoqi <luoqi@FreeBSD.org> | 1999-09-22 22:01:51 +0000 |
---|---|---|
committer | luoqi <luoqi@FreeBSD.org> | 1999-09-22 22:01:51 +0000 |
commit | c07e4cb2e048ac5fa6fca0817404bd5d4978b6b8 (patch) | |
tree | daf85e9cd1148343fe68eb4df62cfac218bfae99 /sys | |
parent | 1388d0402c14dc63c832d6ead5f3fbe2d0d16a55 (diff) | |
download | FreeBSD-src-c07e4cb2e048ac5fa6fca0817404bd5d4978b6b8.zip FreeBSD-src-c07e4cb2e048ac5fa6fca0817404bd5d4978b6b8.tar.gz |
Implement linux_ioperm() syscall. Fix linux_iopl() to use the level argument.
SVGAlib should now work.
Reviewed by: marcel
Diffstat (limited to 'sys')
-rw-r--r-- | sys/alpha/linux/linux_dummy.c | 1 | ||||
-rw-r--r-- | sys/alpha/linux/syscalls.master | 4 | ||||
-rw-r--r-- | sys/compat/linux/linux_misc.c | 31 | ||||
-rw-r--r-- | sys/i386/linux/linux_dummy.c | 1 | ||||
-rw-r--r-- | sys/i386/linux/linux_misc.c | 31 | ||||
-rw-r--r-- | sys/i386/linux/syscalls.master | 4 |
6 files changed, 54 insertions, 18 deletions
diff --git a/sys/alpha/linux/linux_dummy.c b/sys/alpha/linux/linux_dummy.c index 67e3a1a..018446d 100644 --- a/sys/alpha/linux/linux_dummy.c +++ b/sys/alpha/linux/linux_dummy.c @@ -69,7 +69,6 @@ DUMMY(mpx); DUMMY(ulimit); DUMMY(olduname); DUMMY(ustat); -DUMMY(ioperm); DUMMY(ksyslog); DUMMY(uname); DUMMY(vhangup); diff --git a/sys/alpha/linux/syscalls.master b/sys/alpha/linux/syscalls.master index 5e6ce07..ab7c209 100644 --- a/sys/alpha/linux/syscalls.master +++ b/sys/alpha/linux/syscalls.master @@ -150,8 +150,8 @@ struct linux_statfs_buf *buf); } 100 STD LINUX { int linux_fstatfs(int fd, \ struct linux_statfs_buf *buf); } -101 STD LINUX { int linux_ioperm(unsigned int lo, \ - unsigned int hi, int val); } +101 STD LINUX { int linux_ioperm(unsigned int start, \ + unsigned int length, int enable); } 102 STD LINUX { int linux_socketcall(int what, void *args); } 103 STD LINUX { int linux_ksyslog(int what); } 104 STD LINUX { int linux_setitimer(u_int which, \ diff --git a/sys/compat/linux/linux_misc.c b/sys/compat/linux/linux_misc.c index 3bca8cf..919a5e7 100644 --- a/sys/compat/linux/linux_misc.c +++ b/sys/compat/linux/linux_misc.c @@ -1122,17 +1122,36 @@ linux_getitimer(struct proc *p, struct linux_getitimer_args *args) } int +linux_ioperm(struct proc *p, struct linux_ioperm_args *args) +{ + struct sysarch_args sa; + struct i386_ioperm_args *iia; + caddr_t sg; + + sg = stackgap_init(); + iia = stackgap_alloc(&sg, sizeof(struct i386_ioperm_args)); + iia->start = args->start; + iia->length = args->length; + iia->enable = args->enable; + sa.op = I386_SET_IOPERM; + sa.parms = (char *)iia; + return sysarch(p, &sa); +} + +int linux_iopl(struct proc *p, struct linux_iopl_args *args) { int error; - error = suser(p); - if (error != 0) - return error; + if (args->level < 0 || args->level > 3) + return (EINVAL); + if ((error = suser(p)) != 0) + return (error); if (securelevel > 0) - return EPERM; - p->p_md.md_regs->tf_eflags |= PSL_IOPL; - return 0; + return (EPERM); + p->p_md.md_regs->tf_eflags = (p->p_md.md_regs->tf_eflags & ~PSL_IOPL) | + (args->level * (PSL_IOPL / 3)); + return (0); } int diff --git a/sys/i386/linux/linux_dummy.c b/sys/i386/linux/linux_dummy.c index 67e3a1a..018446d 100644 --- a/sys/i386/linux/linux_dummy.c +++ b/sys/i386/linux/linux_dummy.c @@ -69,7 +69,6 @@ DUMMY(mpx); DUMMY(ulimit); DUMMY(olduname); DUMMY(ustat); -DUMMY(ioperm); DUMMY(ksyslog); DUMMY(uname); DUMMY(vhangup); diff --git a/sys/i386/linux/linux_misc.c b/sys/i386/linux/linux_misc.c index 3bca8cf..919a5e7 100644 --- a/sys/i386/linux/linux_misc.c +++ b/sys/i386/linux/linux_misc.c @@ -1122,17 +1122,36 @@ linux_getitimer(struct proc *p, struct linux_getitimer_args *args) } int +linux_ioperm(struct proc *p, struct linux_ioperm_args *args) +{ + struct sysarch_args sa; + struct i386_ioperm_args *iia; + caddr_t sg; + + sg = stackgap_init(); + iia = stackgap_alloc(&sg, sizeof(struct i386_ioperm_args)); + iia->start = args->start; + iia->length = args->length; + iia->enable = args->enable; + sa.op = I386_SET_IOPERM; + sa.parms = (char *)iia; + return sysarch(p, &sa); +} + +int linux_iopl(struct proc *p, struct linux_iopl_args *args) { int error; - error = suser(p); - if (error != 0) - return error; + if (args->level < 0 || args->level > 3) + return (EINVAL); + if ((error = suser(p)) != 0) + return (error); if (securelevel > 0) - return EPERM; - p->p_md.md_regs->tf_eflags |= PSL_IOPL; - return 0; + return (EPERM); + p->p_md.md_regs->tf_eflags = (p->p_md.md_regs->tf_eflags & ~PSL_IOPL) | + (args->level * (PSL_IOPL / 3)); + return (0); } int diff --git a/sys/i386/linux/syscalls.master b/sys/i386/linux/syscalls.master index 5e6ce07..ab7c209 100644 --- a/sys/i386/linux/syscalls.master +++ b/sys/i386/linux/syscalls.master @@ -150,8 +150,8 @@ struct linux_statfs_buf *buf); } 100 STD LINUX { int linux_fstatfs(int fd, \ struct linux_statfs_buf *buf); } -101 STD LINUX { int linux_ioperm(unsigned int lo, \ - unsigned int hi, int val); } +101 STD LINUX { int linux_ioperm(unsigned int start, \ + unsigned int length, int enable); } 102 STD LINUX { int linux_socketcall(int what, void *args); } 103 STD LINUX { int linux_ksyslog(int what); } 104 STD LINUX { int linux_setitimer(u_int which, \ |