console.c revision 1.7 1 1.7 chuck /* $NetBSD: console.c,v 1.7 2011/02/02 17:53:41 chuck Exp $ */
2 1.3 perry
3 1.1 chuck /*
4 1.1 chuck * Copyright (c) 1995 Charles D. Cranor and Seth Widoff
5 1.1 chuck * All rights reserved.
6 1.1 chuck *
7 1.1 chuck * Redistribution and use in source and binary forms, with or without
8 1.1 chuck * modification, are permitted provided that the following conditions
9 1.1 chuck * are met:
10 1.1 chuck * 1. Redistributions of source code must retain the above copyright
11 1.1 chuck * notice, this list of conditions and the following disclaimer.
12 1.1 chuck * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 chuck * notice, this list of conditions and the following disclaimer in the
14 1.1 chuck * documentation and/or other materials provided with the distribution.
15 1.1 chuck *
16 1.1 chuck * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.1 chuck * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.1 chuck * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.1 chuck * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.1 chuck * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.1 chuck * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.1 chuck * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.1 chuck * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.1 chuck * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.1 chuck * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 1.1 chuck */
27 1.1 chuck /*
28 1.1 chuck * console i/o
29 1.1 chuck */
30 1.1 chuck
31 1.1 chuck #include "sboot.h"
32 1.1 chuck
33 1.1 chuck /*
34 1.1 chuck * hardware
35 1.1 chuck */
36 1.1 chuck
37 1.1 chuck struct zs_hw {
38 1.6 tsutsui volatile u_char ctl;
39 1.6 tsutsui volatile u_char data;
40 1.1 chuck };
41 1.1 chuck
42 1.1 chuck struct zs_hw *zs = (struct zs_hw *)CONS_ZS_ADDR;
43 1.1 chuck
44 1.1 chuck /*
45 1.1 chuck * consinit: init console
46 1.1 chuck */
47 1.1 chuck
48 1.5 jdolecek void
49 1.6 tsutsui consinit(void)
50 1.1 chuck {
51 1.6 tsutsui int mark = time();
52 1.6 tsutsui int rr1;
53 1.6 tsutsui for (;;) {
54 1.6 tsutsui if (time() > mark + 5) break;
55 1.6 tsutsui zs->ctl = 1; rr1 = zs->ctl;
56 1.6 tsutsui zs->ctl = 0;
57 1.6 tsutsui if ((rr1 & 0x1) == 1 && (zs->ctl & 0x4) == 4)
58 1.6 tsutsui break; /* zs_drain! */
59 1.6 tsutsui }
60 1.6 tsutsui zs->ctl = 9;
61 1.6 tsutsui zs->ctl = 0x00; /* clear interrupt */
62 1.6 tsutsui zs->ctl = 4;
63 1.6 tsutsui zs->ctl = 0x44; /* 16x clk, 1 stop bit */
64 1.6 tsutsui zs->ctl = 5;
65 1.6 tsutsui zs->ctl = 0xea; /* DTR on, 8 bit xmit, xmit on, RTS on */
66 1.6 tsutsui zs->ctl = 3;
67 1.6 tsutsui zs->ctl = 0xc1; /* 8 bit recv, auto cd_cts, recv on */
68 1.6 tsutsui zs->ctl = 1;
69 1.6 tsutsui zs->ctl = 0x00; /* no intrs */
70 1.6 tsutsui zs->ctl = 2;
71 1.6 tsutsui zs->ctl = 0x00; /* no vector */
72 1.6 tsutsui zs->ctl = 10;
73 1.6 tsutsui zs->ctl = 0x00; /* */
74 1.6 tsutsui zs->ctl = 11;
75 1.6 tsutsui zs->ctl = 0x50; /* clocking options */
76 1.6 tsutsui zs->ctl = 12;
77 1.6 tsutsui zs->ctl = 0x0e; /* 9600 baud, part 1 */
78 1.6 tsutsui zs->ctl = 13;
79 1.6 tsutsui zs->ctl = 0x00; /* 9600 baud, part 2 */
80 1.6 tsutsui zs->ctl = 14;
81 1.6 tsutsui zs->ctl = 0x03; /* more clocking options */
82 1.6 tsutsui zs->ctl = 15;
83 1.6 tsutsui zs->ctl = 0x00; /* clear intrs */
84 1.1 chuck }
85 1.1 chuck
86 1.1 chuck /*
87 1.1 chuck * putchar: put char to console
88 1.1 chuck */
89 1.1 chuck
90 1.5 jdolecek void putchar(int c)
91 1.1 chuck {
92 1.6 tsutsui if (c == '\n')
93 1.6 tsutsui putchar('\r'); /* avoid the need for \r\n in printf */
94 1.6 tsutsui zs->ctl = 0;
95 1.6 tsutsui while ((zs->ctl & 0x04) == 0) {
96 1.6 tsutsui zs->ctl = 0;
97 1.6 tsutsui }
98 1.6 tsutsui zs->ctl = 8;
99 1.6 tsutsui zs->ctl = (char)c;
100 1.1 chuck }
101 1.1 chuck
102 1.1 chuck /*
103 1.1 chuck * cngetc: get 1 char from console
104 1.1 chuck */
105 1.1 chuck
106 1.6 tsutsui char cngetc(void)
107 1.1 chuck {
108 1.6 tsutsui
109 1.6 tsutsui zs->ctl = 0;
110 1.6 tsutsui while ((zs->ctl & 0x1) == 0) {
111 1.6 tsutsui zs->ctl = 0;
112 1.6 tsutsui }
113 1.6 tsutsui zs->ctl = 8;
114 1.6 tsutsui return zs->ctl;
115 1.1 chuck }
116 1.1 chuck
117 1.1 chuck /*
118 1.1 chuck * puts: put string to console
119 1.1 chuck */
120 1.1 chuck
121 1.6 tsutsui void
122 1.6 tsutsui puts(char *str)
123 1.1 chuck {
124 1.6 tsutsui
125 1.6 tsutsui while (*str != '\0') {
126 1.6 tsutsui putchar(*str);
127 1.6 tsutsui str++;
128 1.6 tsutsui }
129 1.1 chuck }
130 1.1 chuck
131 1.1 chuck /*
132 1.1 chuck * ngets: get string from console
133 1.1 chuck */
134 1.1 chuck
135 1.6 tsutsui char *
136 1.6 tsutsui ngets(char *str, int size)
137 1.1 chuck {
138 1.6 tsutsui
139 1.6 tsutsui int i = 0;
140 1.6 tsutsui while ((i < size - 1) && (str[i] = cngetc()) != '\r') {
141 1.6 tsutsui if (str[i] == '\b' || str[i] == 0x7F) {
142 1.6 tsutsui if (i == 0)
143 1.6 tsutsui continue;
144 1.6 tsutsui i--;
145 1.6 tsutsui puts("\b \b");
146 1.6 tsutsui continue;
147 1.6 tsutsui }
148 1.6 tsutsui putchar(str[i]);
149 1.6 tsutsui i++;
150 1.6 tsutsui }
151 1.6 tsutsui puts("\n");
152 1.6 tsutsui str[i] = '\0';
153 1.6 tsutsui return &str[i];
154 1.1 chuck }
155