Home | History | Annotate | Line # | Download | only in librumpuser
rumpuser_component.c revision 1.5
      1  1.5  pooka /*	$NetBSD: rumpuser_component.c,v 1.5 2013/04/30 12:39:20 pooka Exp $	*/
      2  1.1  pooka 
      3  1.1  pooka /*
      4  1.1  pooka  * Copyright (c) 2013 Antti Kantee.  All Rights Reserved.
      5  1.1  pooka  *
      6  1.1  pooka  * Redistribution and use in source and binary forms, with or without
      7  1.1  pooka  * modification, are permitted provided that the following conditions
      8  1.1  pooka  * are met:
      9  1.1  pooka  * 1. Redistributions of source code must retain the above copyright
     10  1.1  pooka  *    notice, this list of conditions and the following disclaimer.
     11  1.1  pooka  * 2. Redistributions in binary form must reproduce the above copyright
     12  1.1  pooka  *    notice, this list of conditions and the following disclaimer in the
     13  1.1  pooka  *    documentation and/or other materials provided with the distribution.
     14  1.1  pooka  *
     15  1.1  pooka  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
     16  1.1  pooka  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
     17  1.1  pooka  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
     18  1.1  pooka  * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
     19  1.1  pooka  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     20  1.1  pooka  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
     21  1.1  pooka  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     22  1.1  pooka  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     23  1.1  pooka  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     24  1.1  pooka  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     25  1.1  pooka  * SUCH DAMAGE.
     26  1.1  pooka  */
     27  1.1  pooka 
     28  1.1  pooka #include "rumpuser_port.h"
     29  1.1  pooka 
     30  1.1  pooka #if !defined(lint)
     31  1.5  pooka __RCSID("$NetBSD: rumpuser_component.c,v 1.5 2013/04/30 12:39:20 pooka Exp $");
     32  1.1  pooka #endif /* !lint */
     33  1.1  pooka 
     34  1.1  pooka /*
     35  1.1  pooka  * These interfaces affect the shlib major/minor; they can be called from
     36  1.1  pooka  * any program when applicable.  The rest of the interfaces provided
     37  1.1  pooka  * by rumpuser are part of the rump kernel/hypervisor contract and
     38  1.1  pooka  * are versioned by RUMPUSER_VERSION.
     39  1.1  pooka  */
     40  1.1  pooka 
     41  1.1  pooka #include <rump/rumpuser_component.h>
     42  1.1  pooka 
     43  1.1  pooka #include "rumpuser_int.h"
     44  1.1  pooka 
     45  1.1  pooka void *
     46  1.1  pooka rumpuser_component_unschedule(void)
     47  1.1  pooka {
     48  1.1  pooka 	int nlocks;
     49  1.1  pooka 
     50  1.3  pooka 	rumpkern_unsched(&nlocks, NULL);
     51  1.1  pooka 	return (void *)(intptr_t)nlocks;
     52  1.1  pooka }
     53  1.1  pooka 
     54  1.1  pooka void
     55  1.1  pooka rumpuser_component_schedule(void *cookie)
     56  1.1  pooka {
     57  1.1  pooka 	int nlocks = (int)(intptr_t)cookie;
     58  1.1  pooka 
     59  1.3  pooka 	rumpkern_sched(nlocks, NULL);
     60  1.1  pooka }
     61  1.4  pooka 
     62  1.4  pooka void
     63  1.4  pooka rumpuser_component_kthread(void)
     64  1.4  pooka {
     65  1.4  pooka 
     66  1.4  pooka 	rumpuser__hyp.hyp_schedule();
     67  1.4  pooka 	rumpuser__hyp.hyp_lwproc_newlwp(0);
     68  1.4  pooka 	rumpuser__hyp.hyp_unschedule();
     69  1.4  pooka }
     70  1.4  pooka 
     71  1.4  pooka struct lwp *
     72  1.4  pooka rumpuser_component_curlwp(void)
     73  1.4  pooka {
     74  1.4  pooka 	struct lwp *l;
     75  1.4  pooka 
     76  1.4  pooka 	rumpuser__hyp.hyp_schedule();
     77  1.4  pooka 	l = rumpuser__hyp.hyp_lwproc_curlwp();
     78  1.4  pooka 	rumpuser__hyp.hyp_unschedule();
     79  1.4  pooka 
     80  1.4  pooka 	return l;
     81  1.4  pooka }
     82  1.4  pooka 
     83  1.4  pooka void
     84  1.4  pooka rumpuser_component_switchlwp(struct lwp *l)
     85  1.4  pooka {
     86  1.4  pooka 
     87  1.4  pooka 	rumpuser__hyp.hyp_schedule();
     88  1.4  pooka 	rumpuser__hyp.hyp_lwproc_switch(l);
     89  1.4  pooka 	rumpuser__hyp.hyp_unschedule();
     90  1.4  pooka }
     91  1.4  pooka 
     92  1.4  pooka void
     93  1.4  pooka rumpuser_component_kthread_release(void)
     94  1.4  pooka {
     95  1.4  pooka 
     96  1.4  pooka 	rumpuser__hyp.hyp_schedule();
     97  1.4  pooka 	rumpuser__hyp.hyp_lwproc_release();
     98  1.4  pooka 	rumpuser__hyp.hyp_unschedule();
     99  1.4  pooka }
    100  1.5  pooka 
    101  1.5  pooka int
    102  1.5  pooka rumpuser_component_errtrans(int hosterr)
    103  1.5  pooka {
    104  1.5  pooka 
    105  1.5  pooka 	return rumpuser__errtrans(hosterr);
    106  1.5  pooka }
    107