rumpuser_component.c revision 1.6 1 1.6 pooka /* $NetBSD: rumpuser_component.c,v 1.6 2013/05/07 15:18:35 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.6 pooka __RCSID("$NetBSD: rumpuser_component.c,v 1.6 2013/05/07 15:18:35 pooka Exp $");
32 1.1 pooka #endif /* !lint */
33 1.1 pooka
34 1.6 pooka #include <stdint.h>
35 1.6 pooka
36 1.1 pooka /*
37 1.1 pooka * These interfaces affect the shlib major/minor; they can be called from
38 1.1 pooka * any program when applicable. The rest of the interfaces provided
39 1.1 pooka * by rumpuser are part of the rump kernel/hypervisor contract and
40 1.1 pooka * are versioned by RUMPUSER_VERSION.
41 1.1 pooka */
42 1.1 pooka
43 1.1 pooka #include <rump/rumpuser_component.h>
44 1.1 pooka
45 1.1 pooka #include "rumpuser_int.h"
46 1.1 pooka
47 1.1 pooka void *
48 1.1 pooka rumpuser_component_unschedule(void)
49 1.1 pooka {
50 1.1 pooka int nlocks;
51 1.1 pooka
52 1.3 pooka rumpkern_unsched(&nlocks, NULL);
53 1.1 pooka return (void *)(intptr_t)nlocks;
54 1.1 pooka }
55 1.1 pooka
56 1.1 pooka void
57 1.1 pooka rumpuser_component_schedule(void *cookie)
58 1.1 pooka {
59 1.1 pooka int nlocks = (int)(intptr_t)cookie;
60 1.1 pooka
61 1.3 pooka rumpkern_sched(nlocks, NULL);
62 1.1 pooka }
63 1.4 pooka
64 1.4 pooka void
65 1.4 pooka rumpuser_component_kthread(void)
66 1.4 pooka {
67 1.4 pooka
68 1.4 pooka rumpuser__hyp.hyp_schedule();
69 1.4 pooka rumpuser__hyp.hyp_lwproc_newlwp(0);
70 1.4 pooka rumpuser__hyp.hyp_unschedule();
71 1.4 pooka }
72 1.4 pooka
73 1.4 pooka struct lwp *
74 1.4 pooka rumpuser_component_curlwp(void)
75 1.4 pooka {
76 1.4 pooka struct lwp *l;
77 1.4 pooka
78 1.4 pooka rumpuser__hyp.hyp_schedule();
79 1.4 pooka l = rumpuser__hyp.hyp_lwproc_curlwp();
80 1.4 pooka rumpuser__hyp.hyp_unschedule();
81 1.4 pooka
82 1.4 pooka return l;
83 1.4 pooka }
84 1.4 pooka
85 1.4 pooka void
86 1.4 pooka rumpuser_component_switchlwp(struct lwp *l)
87 1.4 pooka {
88 1.4 pooka
89 1.4 pooka rumpuser__hyp.hyp_schedule();
90 1.4 pooka rumpuser__hyp.hyp_lwproc_switch(l);
91 1.4 pooka rumpuser__hyp.hyp_unschedule();
92 1.4 pooka }
93 1.4 pooka
94 1.4 pooka void
95 1.4 pooka rumpuser_component_kthread_release(void)
96 1.4 pooka {
97 1.4 pooka
98 1.4 pooka rumpuser__hyp.hyp_schedule();
99 1.4 pooka rumpuser__hyp.hyp_lwproc_release();
100 1.4 pooka rumpuser__hyp.hyp_unschedule();
101 1.4 pooka }
102 1.5 pooka
103 1.5 pooka int
104 1.5 pooka rumpuser_component_errtrans(int hosterr)
105 1.5 pooka {
106 1.5 pooka
107 1.5 pooka return rumpuser__errtrans(hosterr);
108 1.5 pooka }
109