cpu.h revision 1.10 1 1.10 reinoud /* $NetBSD: cpu.h,v 1.10 2012/02/08 17:55:21 reinoud Exp $ */
2 1.1 jmcneill
3 1.1 jmcneill /*-
4 1.1 jmcneill * Copyright (c) 2007 Jared D. McNeill <jmcneill (at) invisible.ca>
5 1.1 jmcneill * All rights reserved.
6 1.1 jmcneill *
7 1.1 jmcneill * Redistribution and use in source and binary forms, with or without
8 1.1 jmcneill * modification, are permitted provided that the following conditions
9 1.1 jmcneill * are met:
10 1.1 jmcneill * 1. Redistributions of source code must retain the above copyright
11 1.1 jmcneill * notice, this list of conditions and the following disclaimer.
12 1.1 jmcneill * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 jmcneill * notice, this list of conditions and the following disclaimer in the
14 1.1 jmcneill * documentation and/or other materials provided with the distribution.
15 1.1 jmcneill *
16 1.1 jmcneill * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
17 1.1 jmcneill * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
18 1.1 jmcneill * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 1.1 jmcneill * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
20 1.1 jmcneill * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 1.1 jmcneill * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 1.1 jmcneill * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23 1.1 jmcneill * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24 1.1 jmcneill * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25 1.1 jmcneill * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26 1.1 jmcneill * POSSIBILITY OF SUCH DAMAGE.
27 1.1 jmcneill */
28 1.1 jmcneill
29 1.1 jmcneill #ifndef _ARCH_USERMODE_INCLUDE_CPU_H
30 1.1 jmcneill #define _ARCH_USERMODE_INCLUDE_CPU_H
31 1.1 jmcneill
32 1.1 jmcneill #include <sys/device.h>
33 1.1 jmcneill #include <sys/cpu_data.h>
34 1.1 jmcneill
35 1.1 jmcneill #include <machine/intrdefs.h>
36 1.1 jmcneill
37 1.1 jmcneill extern void cpu_signotify(struct lwp *);
38 1.1 jmcneill extern void cpu_need_proftick(struct lwp *);
39 1.7 reinoud extern void userret(struct lwp *);
40 1.7 reinoud
41 1.7 reinoud #define curcpu() usermode_curcpu()
42 1.7 reinoud #define cpu_number() 0
43 1.7 reinoud
44 1.7 reinoud #define cpu_proc_fork(p1, p2)
45 1.7 reinoud
46 1.9 reinoud struct cpu_info;
47 1.7 reinoud extern int astpending;
48 1.7 reinoud #define aston(ci) (astpending++)
49 1.9 reinoud extern void cpu_need_resched(struct cpu_info *ci, int flags);
50 1.7 reinoud
51 1.1 jmcneill
52 1.1 jmcneill struct cpu_info {
53 1.10 reinoud struct cpu_data ci_data; /* MI per-cpu data */
54 1.10 reinoud device_t ci_dev; /* pointer to our device */
55 1.1 jmcneill struct cpu_info *ci_self;
56 1.1 jmcneill struct cpu_info *ci_next;
57 1.1 jmcneill u_int ci_cpuid;
58 1.1 jmcneill int ci_want_resched;
59 1.6 jmcneill int ci_idepth;
60 1.1 jmcneill volatile int ci_mtx_count;
61 1.1 jmcneill volatile int ci_mtx_oldspl;
62 1.1 jmcneill lwp_t *ci_curlwp;
63 1.1 jmcneill lwp_t *ci_stash;
64 1.1 jmcneill };
65 1.1 jmcneill
66 1.1 jmcneill __inline static struct cpu_info * __attribute__((__unused__))
67 1.1 jmcneill usermode_curcpu(void)
68 1.1 jmcneill {
69 1.1 jmcneill extern struct cpu_info cpu_info_primary;
70 1.1 jmcneill
71 1.1 jmcneill return &cpu_info_primary;
72 1.1 jmcneill }
73 1.1 jmcneill
74 1.1 jmcneill __inline static void
75 1.1 jmcneill usermode_delay(unsigned int ms)
76 1.1 jmcneill {
77 1.6 jmcneill extern int thunk_usleep(unsigned int);
78 1.5 jmcneill thunk_usleep(ms);
79 1.1 jmcneill }
80 1.1 jmcneill
81 1.1 jmcneill #define delay(ms) usermode_delay(ms)
82 1.1 jmcneill #define DELAY(ms) usermode_delay(ms)
83 1.1 jmcneill
84 1.1 jmcneill /* XXXJDM */
85 1.1 jmcneill struct clockframe {
86 1.1 jmcneill uint8_t cf_dummy;
87 1.1 jmcneill };
88 1.1 jmcneill
89 1.1 jmcneill #define CLKF_USERMODE(frame) 0
90 1.1 jmcneill #define CLKF_PC(frame) 0
91 1.1 jmcneill #define CLKF_INTR(frame) 0
92 1.1 jmcneill
93 1.1 jmcneill #endif /* !_ARCH_USERMODE_INCLUDE_CPU_H */
94