Home | History | Annotate | Line # | Download | only in netbsd32
      1  1.20    simonb /*	$NetBSD: netbsd32_compat_09.c,v 1.20 2021/01/19 03:20:13 simonb Exp $	*/
      2   1.1       mrg 
      3   1.1       mrg /*
      4   1.1       mrg  * Copyright (c) 1998 Matthew R. Green
      5   1.1       mrg  * All rights reserved.
      6   1.1       mrg  *
      7   1.1       mrg  * Redistribution and use in source and binary forms, with or without
      8   1.1       mrg  * modification, are permitted provided that the following conditions
      9   1.1       mrg  * are met:
     10   1.1       mrg  * 1. Redistributions of source code must retain the above copyright
     11   1.1       mrg  *    notice, this list of conditions and the following disclaimer.
     12   1.1       mrg  * 2. Redistributions in binary form must reproduce the above copyright
     13   1.1       mrg  *    notice, this list of conditions and the following disclaimer in the
     14   1.1       mrg  *    documentation and/or other materials provided with the distribution.
     15   1.1       mrg  *
     16   1.1       mrg  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     17   1.1       mrg  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     18   1.1       mrg  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     19   1.1       mrg  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     20   1.1       mrg  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
     21   1.1       mrg  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
     22   1.1       mrg  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
     23   1.1       mrg  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
     24   1.1       mrg  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     25   1.1       mrg  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     26   1.1       mrg  * SUCH DAMAGE.
     27   1.1       mrg  */
     28   1.7     lukem 
     29   1.7     lukem #include <sys/cdefs.h>
     30  1.20    simonb __KERNEL_RCSID(0, "$NetBSD: netbsd32_compat_09.c,v 1.20 2021/01/19 03:20:13 simonb Exp $");
     31   1.1       mrg 
     32   1.1       mrg #include <sys/param.h>
     33   1.1       mrg #include <sys/systm.h>
     34  1.19  pgoyette #include <sys/module.h>
     35   1.1       mrg #include <sys/mount.h>
     36  1.19  pgoyette #include <sys/syscallvar.h>
     37   1.1       mrg #include <sys/syscallargs.h>
     38   1.1       mrg 
     39   1.1       mrg #include <sys/time.h>
     40   1.5       mrg #include <uvm/uvm_extern.h>
     41   1.1       mrg #include <sys/sysctl.h>
     42   1.1       mrg 
     43  1.19  pgoyette #include <compat/sys/siginfo.h>
     44  1.19  pgoyette 
     45   1.2       mrg #include <compat/netbsd32/netbsd32.h>
     46  1.19  pgoyette #include <compat/netbsd32/netbsd32_syscall.h>
     47   1.2       mrg #include <compat/netbsd32/netbsd32_syscallargs.h>
     48   1.1       mrg 
     49   1.1       mrg int
     50  1.17       dsl compat_09_netbsd32_ogetdomainname(struct lwp *l, const struct compat_09_netbsd32_ogetdomainname_args *uap, register_t *retval)
     51   1.1       mrg {
     52  1.17       dsl 	/* {
     53   1.2       mrg 		syscallarg(netbsd32_charp) domainname;
     54   1.1       mrg 		syscallarg(int) len;
     55  1.17       dsl 	} */
     56  1.12    atatat 	int name[2];
     57   1.1       mrg 	size_t sz;
     58   1.1       mrg 
     59  1.12    atatat 	name[0] = CTL_KERN;
     60  1.12    atatat 	name[1] = KERN_DOMAINNAME;
     61   1.1       mrg 	sz = SCARG(uap, len);
     62  1.20    simonb 	return old_sysctl(&name[0], 2,
     63  1.20    simonb 	    (char *)SCARG_P32(uap, domainname), &sz, 0, 0, l);
     64   1.1       mrg }
     65   1.1       mrg 
     66   1.1       mrg int
     67  1.17       dsl compat_09_netbsd32_osetdomainname(struct lwp *l, const struct compat_09_netbsd32_osetdomainname_args *uap, register_t *retval)
     68   1.1       mrg {
     69  1.17       dsl 	/* {
     70   1.2       mrg 		syscallarg(netbsd32_charp) domainname;
     71   1.1       mrg 		syscallarg(int) len;
     72  1.17       dsl 	} */
     73  1.12    atatat 	int name[2];
     74  1.12    atatat 
     75  1.12    atatat 	name[0] = CTL_KERN;
     76  1.12    atatat 	name[1] = KERN_DOMAINNAME;
     77  1.20    simonb 	return old_sysctl(&name[0], 2, 0, 0,
     78  1.20    simonb 	    (char *)SCARG_P32(uap, domainname), SCARG(uap, len), l);
     79   1.1       mrg }
     80   1.1       mrg 
     81   1.1       mrg int
     82  1.17       dsl compat_09_netbsd32_uname(struct lwp *l, const struct compat_09_netbsd32_uname_args *uap, register_t *retval)
     83   1.1       mrg {
     84  1.17       dsl 	/* {
     85   1.2       mrg 		syscallarg(netbsd32_outsnamep_t) name;
     86  1.17       dsl 	} */
     87   1.1       mrg 	struct compat_09_sys_uname_args ua;
     88   1.1       mrg 
     89   1.3       mrg 	NETBSD32TOP_UAP(name, struct outsname);
     90  1.20    simonb 	return compat_09_sys_uname(l, &ua, retval);
     91   1.1       mrg }
     92  1.19  pgoyette 
     93  1.19  pgoyette static struct syscall_package compat_netbsd32_09_syscalls[] = {
     94  1.19  pgoyette         { NETBSD32_SYS_compat_09_netbsd32_ogetdomainname, 0,
     95  1.19  pgoyette             (sy_call_t *)compat_09_netbsd32_ogetdomainname },
     96  1.19  pgoyette         { NETBSD32_SYS_compat_09_netbsd32_osetdomainname, 0,
     97  1.19  pgoyette             (sy_call_t *)compat_09_netbsd32_osetdomainname },
     98  1.19  pgoyette         { NETBSD32_SYS_compat_09_netbsd32_uname, 0,
     99  1.19  pgoyette 	    (sy_call_t *)compat_09_netbsd32_uname },
    100  1.19  pgoyette         { 0, 0, NULL }
    101  1.19  pgoyette };
    102  1.19  pgoyette 
    103  1.19  pgoyette MODULE(MODULE_CLASS_EXEC, compat_netbsd32_09, "compat_netbsd32_12,compat_09");
    104  1.19  pgoyette 
    105  1.19  pgoyette static int
    106  1.19  pgoyette compat_netbsd32_09_modcmd(modcmd_t cmd, void *arg)
    107  1.19  pgoyette {
    108  1.19  pgoyette 
    109  1.19  pgoyette 	switch (cmd) {
    110  1.19  pgoyette 	case MODULE_CMD_INIT:
    111  1.19  pgoyette 		return syscall_establish(&emul_netbsd32,
    112  1.19  pgoyette 		    compat_netbsd32_09_syscalls);
    113  1.19  pgoyette 
    114  1.19  pgoyette 	case MODULE_CMD_FINI:
    115  1.19  pgoyette 		return syscall_disestablish(&emul_netbsd32,
    116  1.19  pgoyette 		    compat_netbsd32_09_syscalls);
    117  1.19  pgoyette 
    118  1.19  pgoyette 	default:
    119  1.19  pgoyette 		return ENOTTY;
    120  1.19  pgoyette 	}
    121  1.19  pgoyette }
    122