Home | History | Annotate | Line # | Download | only in netbsd32
netbsd32_compat_09.c revision 1.18.12.2
      1  1.18.12.2  mrg /*	$NetBSD: netbsd32_compat_09.c,v 1.18.12.2 2008/05/29 14:51:27 mrg Exp $	*/
      2  1.18.12.2  mrg 
      3  1.18.12.2  mrg /*
      4  1.18.12.2  mrg  * Copyright (c) 1998 Matthew R. Green
      5  1.18.12.2  mrg  * All rights reserved.
      6  1.18.12.2  mrg  *
      7  1.18.12.2  mrg  * Redistribution and use in source and binary forms, with or without
      8  1.18.12.2  mrg  * modification, are permitted provided that the following conditions
      9  1.18.12.2  mrg  * are met:
     10  1.18.12.2  mrg  * 1. Redistributions of source code must retain the above copyright
     11  1.18.12.2  mrg  *    notice, this list of conditions and the following disclaimer.
     12  1.18.12.2  mrg  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.18.12.2  mrg  *    notice, this list of conditions and the following disclaimer in the
     14  1.18.12.2  mrg  *    documentation and/or other materials provided with the distribution.
     15  1.18.12.2  mrg  *
     16  1.18.12.2  mrg  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     17  1.18.12.2  mrg  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     18  1.18.12.2  mrg  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     19  1.18.12.2  mrg  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     20  1.18.12.2  mrg  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
     21  1.18.12.2  mrg  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
     22  1.18.12.2  mrg  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
     23  1.18.12.2  mrg  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
     24  1.18.12.2  mrg  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25  1.18.12.2  mrg  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26  1.18.12.2  mrg  * SUCH DAMAGE.
     27  1.18.12.2  mrg  */
     28  1.18.12.2  mrg 
     29  1.18.12.2  mrg #include <sys/cdefs.h>
     30  1.18.12.2  mrg __KERNEL_RCSID(0, "$NetBSD: netbsd32_compat_09.c,v 1.18.12.2 2008/05/29 14:51:27 mrg Exp $");
     31  1.18.12.2  mrg 
     32  1.18.12.2  mrg #include <sys/param.h>
     33  1.18.12.2  mrg #include <sys/systm.h>
     34  1.18.12.2  mrg #include <sys/mount.h>
     35  1.18.12.2  mrg #include <sys/syscallargs.h>
     36  1.18.12.2  mrg 
     37  1.18.12.2  mrg #include <sys/time.h>
     38  1.18.12.2  mrg #include <uvm/uvm_extern.h>
     39  1.18.12.2  mrg #include <sys/sysctl.h>
     40  1.18.12.2  mrg 
     41  1.18.12.2  mrg #include <compat/netbsd32/netbsd32.h>
     42  1.18.12.2  mrg #include <compat/netbsd32/netbsd32_syscallargs.h>
     43  1.18.12.2  mrg 
     44  1.18.12.2  mrg int
     45  1.18.12.2  mrg compat_09_netbsd32_ogetdomainname(struct lwp *l, const struct compat_09_netbsd32_ogetdomainname_args *uap, register_t *retval)
     46  1.18.12.2  mrg {
     47  1.18.12.2  mrg 	/* {
     48  1.18.12.2  mrg 		syscallarg(netbsd32_charp) domainname;
     49  1.18.12.2  mrg 		syscallarg(int) len;
     50  1.18.12.2  mrg 	} */
     51  1.18.12.2  mrg 	int name[2];
     52  1.18.12.2  mrg 	size_t sz;
     53  1.18.12.2  mrg 
     54  1.18.12.2  mrg 	name[0] = CTL_KERN;
     55  1.18.12.2  mrg 	name[1] = KERN_DOMAINNAME;
     56  1.18.12.2  mrg 	sz = SCARG(uap, len);
     57  1.18.12.2  mrg 	return (old_sysctl(&name[0], 2,
     58  1.18.12.2  mrg 	    (char *)SCARG_P32(uap, domainname), &sz, 0, 0, l));
     59  1.18.12.2  mrg }
     60  1.18.12.2  mrg 
     61  1.18.12.2  mrg int
     62  1.18.12.2  mrg compat_09_netbsd32_osetdomainname(struct lwp *l, const struct compat_09_netbsd32_osetdomainname_args *uap, register_t *retval)
     63  1.18.12.2  mrg {
     64  1.18.12.2  mrg 	/* {
     65  1.18.12.2  mrg 		syscallarg(netbsd32_charp) domainname;
     66  1.18.12.2  mrg 		syscallarg(int) len;
     67  1.18.12.2  mrg 	} */
     68  1.18.12.2  mrg 	int name[2];
     69  1.18.12.2  mrg 
     70  1.18.12.2  mrg 	name[0] = CTL_KERN;
     71  1.18.12.2  mrg 	name[1] = KERN_DOMAINNAME;
     72  1.18.12.2  mrg 	return (old_sysctl(&name[0], 2, 0, 0,
     73  1.18.12.2  mrg 	    (char *)SCARG_P32(uap, domainname), SCARG(uap, len), l));
     74  1.18.12.2  mrg }
     75  1.18.12.2  mrg 
     76  1.18.12.2  mrg int
     77  1.18.12.2  mrg compat_09_netbsd32_uname(struct lwp *l, const struct compat_09_netbsd32_uname_args *uap, register_t *retval)
     78  1.18.12.2  mrg {
     79  1.18.12.2  mrg 	/* {
     80  1.18.12.2  mrg 		syscallarg(netbsd32_outsnamep_t) name;
     81  1.18.12.2  mrg 	} */
     82  1.18.12.2  mrg 	struct compat_09_sys_uname_args ua;
     83  1.18.12.2  mrg 
     84  1.18.12.2  mrg 	NETBSD32TOP_UAP(name, struct outsname);
     85  1.18.12.2  mrg 	return (compat_09_sys_uname(l, &ua, retval));
     86  1.18.12.2  mrg }
     87