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