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