Home | History | Annotate | Line # | Download | only in include
cpu.h revision 1.10.48.2
      1  1.10.48.2    martin /* $NetBSD: cpu.h,v 1.10.48.2 2020/04/08 14:07:56 martin 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.10.48.1  christos extern void kgdb_port_init(void);
     50        1.1  jmcneill 
     51        1.1  jmcneill struct cpu_info {
     52       1.10   reinoud 	struct cpu_data	ci_data;		/* MI per-cpu data */
     53       1.10   reinoud 	device_t	ci_dev;			/* pointer to our device */
     54        1.1  jmcneill 	struct cpu_info	*ci_self;
     55        1.1  jmcneill 	struct cpu_info	*ci_next;
     56        1.1  jmcneill 	u_int		ci_cpuid;
     57        1.1  jmcneill 	int		ci_want_resched;
     58        1.6  jmcneill 	int		ci_idepth;
     59        1.1  jmcneill 	volatile int	ci_mtx_count;
     60        1.1  jmcneill 	volatile int	ci_mtx_oldspl;
     61  1.10.48.2    martin 	lwp_t		*ci_onproc;		/* current user LWP / kthread */
     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