1*58a2b000SEvgeniy Ivanov /* $NetBSD: stand_user.c,v 1.6 2008/12/14 18:46:33 christos Exp $ */
2*58a2b000SEvgeniy Ivanov
3*58a2b000SEvgeniy Ivanov /*
4*58a2b000SEvgeniy Ivanov * Copyright (c) 1998
5*58a2b000SEvgeniy Ivanov * Matthias Drochner. All rights reserved.
6*58a2b000SEvgeniy Ivanov *
7*58a2b000SEvgeniy Ivanov * Redistribution and use in source and binary forms, with or without
8*58a2b000SEvgeniy Ivanov * modification, are permitted provided that the following conditions
9*58a2b000SEvgeniy Ivanov * are met:
10*58a2b000SEvgeniy Ivanov * 1. Redistributions of source code must retain the above copyright
11*58a2b000SEvgeniy Ivanov * notice, this list of conditions and the following disclaimer.
12*58a2b000SEvgeniy Ivanov * 2. Redistributions in binary form must reproduce the above copyright
13*58a2b000SEvgeniy Ivanov * notice, this list of conditions and the following disclaimer in the
14*58a2b000SEvgeniy Ivanov * documentation and/or other materials provided with the distribution.
15*58a2b000SEvgeniy Ivanov *
16*58a2b000SEvgeniy Ivanov * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17*58a2b000SEvgeniy Ivanov * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18*58a2b000SEvgeniy Ivanov * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19*58a2b000SEvgeniy Ivanov * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20*58a2b000SEvgeniy Ivanov * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21*58a2b000SEvgeniy Ivanov * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22*58a2b000SEvgeniy Ivanov * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23*58a2b000SEvgeniy Ivanov * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24*58a2b000SEvgeniy Ivanov * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25*58a2b000SEvgeniy Ivanov * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*58a2b000SEvgeniy Ivanov *
27*58a2b000SEvgeniy Ivanov */
28*58a2b000SEvgeniy Ivanov
29*58a2b000SEvgeniy Ivanov #include <lib/libsa/stand.h>
30*58a2b000SEvgeniy Ivanov
31*58a2b000SEvgeniy Ivanov #include "sanamespace.h"
32*58a2b000SEvgeniy Ivanov
33*58a2b000SEvgeniy Ivanov #include <stdio.h>
34*58a2b000SEvgeniy Ivanov #include <unistd.h>
35*58a2b000SEvgeniy Ivanov #include <stdlib.h>
36*58a2b000SEvgeniy Ivanov #include <stdarg.h>
37*58a2b000SEvgeniy Ivanov #include <sys/time.h>
38*58a2b000SEvgeniy Ivanov #include <fcntl.h>
39*58a2b000SEvgeniy Ivanov #include <sys/mman.h>
40*58a2b000SEvgeniy Ivanov #include <machine/sysarch.h>
41*58a2b000SEvgeniy Ivanov #include <err.h>
42*58a2b000SEvgeniy Ivanov
43*58a2b000SEvgeniy Ivanov /*
44*58a2b000SEvgeniy Ivanov * Harness for test of standalone code in user space.
45*58a2b000SEvgeniy Ivanov * XXX Requires silly namespace games.
46*58a2b000SEvgeniy Ivanov */
47*58a2b000SEvgeniy Ivanov
48*58a2b000SEvgeniy Ivanov #ifndef HEAPSIZE
49*58a2b000SEvgeniy Ivanov #define HEAPSIZE (128*1024)
50*58a2b000SEvgeniy Ivanov #endif
51*58a2b000SEvgeniy Ivanov
52*58a2b000SEvgeniy Ivanov int samain(void);
53*58a2b000SEvgeniy Ivanov
54*58a2b000SEvgeniy Ivanov int
main(void)55*58a2b000SEvgeniy Ivanov main(void)
56*58a2b000SEvgeniy Ivanov {
57*58a2b000SEvgeniy Ivanov char *h = malloc(HEAPSIZE);
58*58a2b000SEvgeniy Ivanov setheap(h, h + HEAPSIZE);
59*58a2b000SEvgeniy Ivanov
60*58a2b000SEvgeniy Ivanov return samain();
61*58a2b000SEvgeniy Ivanov }
62*58a2b000SEvgeniy Ivanov
63*58a2b000SEvgeniy Ivanov void
_rtt(void)64*58a2b000SEvgeniy Ivanov _rtt(void)
65*58a2b000SEvgeniy Ivanov {
66*58a2b000SEvgeniy Ivanov warnx("_rtt called");
67*58a2b000SEvgeniy Ivanov _exit(1);
68*58a2b000SEvgeniy Ivanov }
69*58a2b000SEvgeniy Ivanov
70*58a2b000SEvgeniy Ivanov int
getsecs(void)71*58a2b000SEvgeniy Ivanov getsecs(void)
72*58a2b000SEvgeniy Ivanov {
73*58a2b000SEvgeniy Ivanov struct timeval t;
74*58a2b000SEvgeniy Ivanov gettimeofday(&t, 0);
75*58a2b000SEvgeniy Ivanov return t.tv_sec;
76*58a2b000SEvgeniy Ivanov }
77*58a2b000SEvgeniy Ivanov
78*58a2b000SEvgeniy Ivanov void
delay(int t)79*58a2b000SEvgeniy Ivanov delay(int t)
80*58a2b000SEvgeniy Ivanov {
81*58a2b000SEvgeniy Ivanov struct timeval to;
82*58a2b000SEvgeniy Ivanov to.tv_sec = 0;
83*58a2b000SEvgeniy Ivanov to.tv_usec = t;
84*58a2b000SEvgeniy Ivanov select(0, 0, 0, 0, &to);
85*58a2b000SEvgeniy Ivanov }
86*58a2b000SEvgeniy Ivanov
87*58a2b000SEvgeniy Ivanov /* make output appear unbuffered */
88*58a2b000SEvgeniy Ivanov void
saputchar(int c)89*58a2b000SEvgeniy Ivanov saputchar(int c)
90*58a2b000SEvgeniy Ivanov {
91*58a2b000SEvgeniy Ivanov putchar(c);
92*58a2b000SEvgeniy Ivanov fflush(stdout);
93*58a2b000SEvgeniy Ivanov }
94*58a2b000SEvgeniy Ivanov
95*58a2b000SEvgeniy Ivanov /*
96*58a2b000SEvgeniy Ivanov * some functions to get access to the hardware
97*58a2b000SEvgeniy Ivanov */
98*58a2b000SEvgeniy Ivanov
99*58a2b000SEvgeniy Ivanov static int memfd, memcnt;
100*58a2b000SEvgeniy Ivanov
101*58a2b000SEvgeniy Ivanov void *
mapmem(int offset,int len)102*58a2b000SEvgeniy Ivanov mapmem(int offset, int len)
103*58a2b000SEvgeniy Ivanov {
104*58a2b000SEvgeniy Ivanov void *base;
105*58a2b000SEvgeniy Ivanov
106*58a2b000SEvgeniy Ivanov if (memcnt == 0)
107*58a2b000SEvgeniy Ivanov memfd = open("/dev/mem", O_RDWR, 0);
108*58a2b000SEvgeniy Ivanov if (memfd < 0) {
109*58a2b000SEvgeniy Ivanov warn("open /dev/mem");
110*58a2b000SEvgeniy Ivanov return 0;
111*58a2b000SEvgeniy Ivanov }
112*58a2b000SEvgeniy Ivanov base = mmap(0, len, PROT_READ | PROT_WRITE, MAP_SHARED,
113*58a2b000SEvgeniy Ivanov memfd, offset);
114*58a2b000SEvgeniy Ivanov if (base == (void *)-1) {
115*58a2b000SEvgeniy Ivanov warn("mmap %x-%x", offset, offset + len - 1);
116*58a2b000SEvgeniy Ivanov return 0;
117*58a2b000SEvgeniy Ivanov }
118*58a2b000SEvgeniy Ivanov memcnt++;
119*58a2b000SEvgeniy Ivanov return base;
120*58a2b000SEvgeniy Ivanov }
121*58a2b000SEvgeniy Ivanov
122*58a2b000SEvgeniy Ivanov void
unmapmem(void * addr,int len)123*58a2b000SEvgeniy Ivanov unmapmem(void *addr, int len)
124*58a2b000SEvgeniy Ivanov {
125*58a2b000SEvgeniy Ivanov
126*58a2b000SEvgeniy Ivanov munmap(addr, len);
127*58a2b000SEvgeniy Ivanov memcnt--;
128*58a2b000SEvgeniy Ivanov if (memcnt == 0)
129*58a2b000SEvgeniy Ivanov close(memfd);
130*58a2b000SEvgeniy Ivanov }
131*58a2b000SEvgeniy Ivanov
132*58a2b000SEvgeniy Ivanov int
mapio(void)133*58a2b000SEvgeniy Ivanov mapio(void)
134*58a2b000SEvgeniy Ivanov {
135*58a2b000SEvgeniy Ivanov int res;
136*58a2b000SEvgeniy Ivanov
137*58a2b000SEvgeniy Ivanov res = i386_iopl(1);
138*58a2b000SEvgeniy Ivanov if (res)
139*58a2b000SEvgeniy Ivanov warn("i386_iopl");
140*58a2b000SEvgeniy Ivanov return res;
141*58a2b000SEvgeniy Ivanov }
142*58a2b000SEvgeniy Ivanov
143*58a2b000SEvgeniy Ivanov int ourseg = 12345;
144