Home | History | Annotate | Line # | Download | only in rumpkern
rump_private.h revision 1.8.10.4
      1  1.8.10.4   yamt /*	$NetBSD: rump_private.h,v 1.8.10.4 2010/10/09 03:32:43 yamt Exp $	*/
      2       1.1  pooka 
      3       1.1  pooka /*
      4       1.1  pooka  * Copyright (c) 2007 Antti Kantee.  All Rights Reserved.
      5       1.1  pooka  *
      6       1.1  pooka  * Development of this software was supported by Google Summer of Code.
      7       1.1  pooka  *
      8       1.1  pooka  * Redistribution and use in source and binary forms, with or without
      9       1.1  pooka  * modification, are permitted provided that the following conditions
     10       1.1  pooka  * are met:
     11       1.1  pooka  * 1. Redistributions of source code must retain the above copyright
     12       1.1  pooka  *    notice, this list of conditions and the following disclaimer.
     13       1.1  pooka  * 2. Redistributions in binary form must reproduce the above copyright
     14       1.1  pooka  *    notice, this list of conditions and the following disclaimer in the
     15       1.1  pooka  *    documentation and/or other materials provided with the distribution.
     16       1.1  pooka  *
     17       1.1  pooka  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
     18       1.1  pooka  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
     19       1.1  pooka  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
     20       1.1  pooka  * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     21       1.1  pooka  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     22       1.1  pooka  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
     23       1.1  pooka  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     24       1.1  pooka  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     25       1.1  pooka  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     26       1.1  pooka  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     27       1.1  pooka  * SUCH DAMAGE.
     28       1.1  pooka  */
     29       1.1  pooka 
     30       1.1  pooka #ifndef _SYS_RUMP_PRIVATE_H_
     31       1.1  pooka #define _SYS_RUMP_PRIVATE_H_
     32       1.1  pooka 
     33       1.1  pooka #include <sys/param.h>
     34  1.8.10.2   yamt #include <sys/cpu.h>
     35  1.8.10.2   yamt #include <sys/device.h>
     36  1.8.10.1   yamt #include <sys/lwp.h>
     37  1.8.10.1   yamt #include <sys/proc.h>
     38  1.8.10.1   yamt #include <sys/systm.h>
     39       1.1  pooka #include <sys/types.h>
     40       1.1  pooka 
     41       1.1  pooka #include <uvm/uvm.h>
     42       1.1  pooka #include <uvm/uvm_object.h>
     43       1.1  pooka #include <uvm/uvm_page.h>
     44       1.1  pooka 
     45  1.8.10.1   yamt #include <rump/rump.h>
     46  1.8.10.1   yamt #include <rump/rumpuser.h>
     47       1.3  pooka 
     48  1.8.10.2   yamt #include "rumpkern_if_priv.h"
     49  1.8.10.2   yamt 
     50       1.1  pooka extern kauth_cred_t rump_cred;
     51       1.1  pooka 
     52  1.8.10.1   yamt extern struct rumpuser_mtx *rump_giantlock;
     53       1.6  pooka 
     54  1.8.10.3   yamt #define UIO_VMSPACE_SYS (&vmspace0)
     55       1.1  pooka 
     56  1.8.10.1   yamt extern int rump_threads;
     57  1.8.10.2   yamt extern struct device rump_rootdev;
     58       1.1  pooka 
     59  1.8.10.1   yamt extern struct sysent rump_sysent[];
     60       1.1  pooka 
     61  1.8.10.3   yamt extern struct vmspace vmspace0;
     62  1.8.10.3   yamt 
     63  1.8.10.2   yamt enum rump_component_type {
     64  1.8.10.2   yamt 	RUMP_COMPONENT_DEV,
     65  1.8.10.2   yamt 	RUMP_COMPONENT_NET, RUMP_COMPONENT_NET_ROUTE, RUMP_COMPONENT_NET_IF,
     66  1.8.10.2   yamt 	RUMP_COMPONENT_VFS,
     67  1.8.10.3   yamt 	RUMP_COMPONENT_KERN, RUMP_COMPONENT_KERN_VFS,
     68  1.8.10.2   yamt 	RUMP_COMPONENT_MAX,
     69  1.8.10.2   yamt };
     70  1.8.10.2   yamt struct rump_component {
     71  1.8.10.2   yamt 	enum rump_component_type rc_type;
     72  1.8.10.2   yamt 	void (*rc_init)(void);
     73  1.8.10.2   yamt };
     74  1.8.10.2   yamt #define RUMP_COMPONENT(type)				\
     75  1.8.10.2   yamt static void rumpcompinit(void);				\
     76  1.8.10.2   yamt static const struct rump_component rumpcomp = {		\
     77  1.8.10.2   yamt 	.rc_type = type,				\
     78  1.8.10.2   yamt 	.rc_init = rumpcompinit,			\
     79  1.8.10.2   yamt };							\
     80  1.8.10.2   yamt __link_set_add_rodata(rump_components, rumpcomp);	\
     81  1.8.10.2   yamt static void rumpcompinit(void)
     82  1.8.10.2   yamt 
     83  1.8.10.3   yamt #define FLAWLESSCALL(call)						\
     84  1.8.10.3   yamt do {									\
     85  1.8.10.3   yamt 	int att_error;							\
     86  1.8.10.3   yamt 	if ((att_error = call) != 0)					\
     87  1.8.10.3   yamt 		panic("\"%s\" failed", #call);				\
     88  1.8.10.3   yamt } while (/*CONSTCOND*/0)
     89  1.8.10.3   yamt 
     90  1.8.10.4   yamt #define RUMPMEM_UNLIMITED ((unsigned long)-1)
     91  1.8.10.4   yamt extern unsigned long rump_physmemlimit;
     92  1.8.10.4   yamt 
     93  1.8.10.2   yamt void		rump_component_init(enum rump_component_type);
     94  1.8.10.2   yamt int		rump_component_count(enum rump_component_type);
     95  1.8.10.2   yamt 
     96  1.8.10.1   yamt void		rump_gettime(struct timespec *);
     97  1.8.10.1   yamt void		rump_getuptime(struct timespec *);
     98  1.8.10.1   yamt 
     99  1.8.10.1   yamt void		rump_set_vmspace(struct vmspace *);
    100  1.8.10.1   yamt 
    101  1.8.10.1   yamt typedef void	(*rump_proc_vfs_init_fn)(struct proc *);
    102  1.8.10.1   yamt typedef void	(*rump_proc_vfs_release_fn)(struct proc *);
    103  1.8.10.2   yamt extern rump_proc_vfs_init_fn rump_proc_vfs_init;
    104  1.8.10.2   yamt extern rump_proc_vfs_release_fn rump_proc_vfs_release;
    105  1.8.10.1   yamt 
    106  1.8.10.2   yamt extern struct cpu_info *rump_cpu;
    107  1.8.10.1   yamt 
    108  1.8.10.1   yamt extern rump_sysproxy_t rump_sysproxy;
    109  1.8.10.1   yamt extern void *rump_sysproxy_arg;
    110  1.8.10.1   yamt 
    111  1.8.10.1   yamt int		rump_sysproxy_copyout(const void *, void *, size_t);
    112  1.8.10.1   yamt int		rump_sysproxy_copyin(const void *, void *, size_t);
    113       1.2  pooka 
    114  1.8.10.4   yamt struct lwp *	rump__lwproc_allockernlwp(void);
    115  1.8.10.4   yamt 
    116  1.8.10.3   yamt void	rump_cpus_bootstrap(int);
    117  1.8.10.4   yamt void	rump_scheduler_init(int);
    118  1.8.10.2   yamt void	rump_schedule(void);
    119  1.8.10.2   yamt void	rump_unschedule(void);
    120  1.8.10.2   yamt void 	rump_schedule_cpu(struct lwp *);
    121  1.8.10.3   yamt void 	rump_schedule_cpu_interlock(struct lwp *, void *);
    122  1.8.10.2   yamt void	rump_unschedule_cpu(struct lwp *);
    123  1.8.10.3   yamt void	rump_unschedule_cpu_interlock(struct lwp *, void *);
    124  1.8.10.3   yamt void	rump_unschedule_cpu1(struct lwp *, void *);
    125  1.8.10.2   yamt 
    126  1.8.10.3   yamt void	rump_schedlock_cv_wait(struct rumpuser_cv *);
    127  1.8.10.3   yamt int	rump_schedlock_cv_timedwait(struct rumpuser_cv *,
    128  1.8.10.3   yamt 				    const struct timespec *);
    129  1.8.10.2   yamt 
    130  1.8.10.3   yamt void	rump_user_schedule(int, void *);
    131  1.8.10.3   yamt void	rump_user_unschedule(int, int *, void *);
    132  1.8.10.2   yamt 
    133  1.8.10.3   yamt void	rump_cpu_attach(struct cpu_info *);
    134  1.8.10.3   yamt 
    135  1.8.10.3   yamt bool	rump_kernel_isbiglocked(void);
    136  1.8.10.3   yamt void	rump_kernel_unlock_allbutone(int *);
    137  1.8.10.3   yamt void	rump_kernel_ununlock_allbutone(int);
    138  1.8.10.3   yamt 
    139  1.8.10.3   yamt void	rump_tsleep_init(void);
    140  1.8.10.2   yamt 
    141  1.8.10.4   yamt void	rump_intr_init(int);
    142  1.8.10.2   yamt void	rump_softint_run(struct cpu_info *);
    143  1.8.10.2   yamt 
    144  1.8.10.3   yamt void	*rump_hypermalloc(size_t, int, bool, const char *);
    145  1.8.10.3   yamt void	rump_hyperfree(void *, size_t);
    146  1.8.10.3   yamt 
    147       1.1  pooka #endif /* _SYS_RUMP_PRIVATE_H_ */
    148