prom.c revision 1.4 1 1.4 ross /* $NetBSD: prom.c,v 1.4 1998/09/22 00:41:13 ross Exp $ */
2 1.1 cgd
3 1.1 cgd /*
4 1.1 cgd * Mach Operating System
5 1.1 cgd * Copyright (c) 1992 Carnegie Mellon University
6 1.1 cgd * All Rights Reserved.
7 1.1 cgd *
8 1.1 cgd * Permission to use, copy, modify and distribute this software and its
9 1.1 cgd * documentation is hereby granted, provided that both the copyright
10 1.1 cgd * notice and this permission notice appear in all copies of the
11 1.1 cgd * software, derivative works or modified versions, and any portions
12 1.1 cgd * thereof, and that both notices appear in supporting documentation.
13 1.1 cgd *
14 1.1 cgd * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
15 1.1 cgd * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
16 1.1 cgd * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
17 1.1 cgd *
18 1.1 cgd * Carnegie Mellon requests users of this software to return to
19 1.1 cgd *
20 1.1 cgd * Software Distribution Coordinator or Software.Distribution (at) CS.CMU.EDU
21 1.1 cgd * School of Computer Science
22 1.1 cgd * Carnegie Mellon University
23 1.1 cgd * Pittsburgh PA 15213-3890
24 1.1 cgd *
25 1.1 cgd * any improvements or extensions that they make and grant Carnegie Mellon
26 1.1 cgd * the rights to redistribute these changes.
27 1.1 cgd */
28 1.1 cgd
29 1.1 cgd #include <sys/types.h>
30 1.1 cgd
31 1.1 cgd #include <machine/prom.h>
32 1.1 cgd #include <machine/rpb.h>
33 1.3 drochner
34 1.3 drochner #include "common.h"
35 1.1 cgd
36 1.1 cgd int console;
37 1.1 cgd
38 1.4 ross static int test_getchar(prom_return_t *, int *);
39 1.4 ross
40 1.1 cgd void
41 1.1 cgd init_prom_calls()
42 1.1 cgd {
43 1.1 cgd extern struct prom_vec prom_dispatch_v;
44 1.1 cgd struct rpb *r;
45 1.1 cgd struct crb *c;
46 1.1 cgd char buf[4];
47 1.1 cgd
48 1.1 cgd r = (struct rpb *)HWRPB_ADDR;
49 1.1 cgd c = (struct crb *)((u_int8_t *)r + r->rpb_crb_off);
50 1.1 cgd
51 1.1 cgd prom_dispatch_v.routine_arg = c->crb_v_dispatch;
52 1.1 cgd prom_dispatch_v.routine = c->crb_v_dispatch->entry_va;
53 1.1 cgd
54 1.1 cgd /* Look for console tty. */
55 1.1 cgd prom_getenv(PROM_E_TTY_DEV, buf, 4);
56 1.1 cgd console = buf[0] - '0';
57 1.1 cgd }
58 1.1 cgd
59 1.4 ross static int
60 1.4 ross test_getchar(xret, xc)
61 1.4 ross prom_return_t *xret;
62 1.4 ross int *xc;
63 1.4 ross {
64 1.4 ross xret->bits = prom_dispatch(PROM_R_GETC, console);
65 1.4 ross *xc = xret->u.retval;
66 1.4 ross return xret->u.status == 0 || xret->u.status == 1;
67 1.4 ross }
68 1.4 ross
69 1.1 cgd int
70 1.1 cgd getchar()
71 1.1 cgd {
72 1.4 ross int c;
73 1.1 cgd prom_return_t ret;
74 1.1 cgd
75 1.1 cgd for (;;) {
76 1.4 ross if (test_getchar(&ret, &c)) {
77 1.4 ross if (c == 3)
78 1.4 ross halt();
79 1.4 ross return c;
80 1.4 ross }
81 1.1 cgd }
82 1.1 cgd }
83 1.1 cgd
84 1.1 cgd void
85 1.1 cgd putchar(c)
86 1.1 cgd int c;
87 1.1 cgd {
88 1.1 cgd prom_return_t ret;
89 1.1 cgd char cbuf;
90 1.4 ross int typed_c;
91 1.1 cgd
92 1.1 cgd if (c == '\r' || c == '\n') {
93 1.1 cgd cbuf = '\r';
94 1.1 cgd do {
95 1.1 cgd ret.bits = prom_dispatch(PROM_R_PUTS, console,
96 1.1 cgd &cbuf, 1);
97 1.1 cgd } while ((ret.u.retval & 1) == 0);
98 1.1 cgd cbuf = '\n';
99 1.1 cgd } else
100 1.1 cgd cbuf = c;
101 1.1 cgd do {
102 1.1 cgd ret.bits = prom_dispatch(PROM_R_PUTS, console, &cbuf, 1);
103 1.1 cgd } while ((ret.u.retval & 1) == 0);
104 1.4 ross ret.bits = prom_dispatch(PROM_R_GETC, console);
105 1.4 ross if (ret.u.status == 0 || ret.u.status == 1)
106 1.4 ross if (ret.u.retval == 3)
107 1.4 ross halt();
108 1.4 ross if (test_getchar(&ret, &typed_c))
109 1.4 ross if (typed_c == 3)
110 1.4 ross halt();
111 1.1 cgd }
112 1.1 cgd
113 1.1 cgd int
114 1.1 cgd prom_getenv(id, buf, len)
115 1.1 cgd int id, len;
116 1.1 cgd char *buf;
117 1.1 cgd {
118 1.1 cgd prom_return_t ret;
119 1.1 cgd
120 1.1 cgd ret.bits = prom_dispatch(PROM_R_GETENV, id, buf, len-1);
121 1.1 cgd if (ret.u.status & 0x4)
122 1.1 cgd ret.u.retval = 0;
123 1.1 cgd buf[ret.u.retval] = '\0';
124 1.1 cgd
125 1.1 cgd return (ret.u.retval);
126 1.1 cgd }
127 1.1 cgd
128 1.1 cgd int
129 1.1 cgd prom_open(dev, len)
130 1.1 cgd char *dev;
131 1.1 cgd int len;
132 1.1 cgd {
133 1.1 cgd prom_return_t ret;
134 1.1 cgd
135 1.1 cgd ret.bits = prom_dispatch(PROM_R_OPEN, dev, len);
136 1.1 cgd if (ret.u.status & 0x4)
137 1.1 cgd return (-1);
138 1.1 cgd else
139 1.1 cgd return (ret.u.retval);
140 1.1 cgd }
141