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