1 1.12 isaki /* $NetBSD: consio.c,v 1.12 2024/01/07 07:58:34 isaki Exp $ */ 2 1.1 minoura 3 1.1 minoura /* 4 1.1 minoura * Copyright (c) 2001 MINOURA Makoto. 5 1.1 minoura * All rights reserved. 6 1.1 minoura * 7 1.1 minoura * Redistribution and use in source and binary forms, with or without 8 1.1 minoura * modification, are permitted provided that the following conditions 9 1.1 minoura * are met: 10 1.1 minoura * 1. Redistributions of source code must retain the above copyright 11 1.1 minoura * notice, this list of conditions and the following disclaimer. 12 1.1 minoura * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 minoura * notice, this list of conditions and the following disclaimer in the 14 1.1 minoura * documentation and/or other materials provided with the distribution. 15 1.1 minoura * 16 1.1 minoura * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17 1.1 minoura * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 18 1.1 minoura * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 19 1.1 minoura * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 20 1.1 minoura * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 21 1.1 minoura * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 22 1.1 minoura * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23 1.1 minoura * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24 1.1 minoura * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 25 1.1 minoura * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26 1.1 minoura */ 27 1.1 minoura 28 1.3 minoura #include <lib/libkern/libkern.h> 29 1.1 minoura #include <lib/libsa/stand.h> 30 1.1 minoura 31 1.1 minoura #include "libx68k.h" 32 1.1 minoura 33 1.1 minoura #include "iocs.h" 34 1.1 minoura #include "consio.h" 35 1.1 minoura 36 1.1 minoura enum { 37 1.1 minoura ITE = 0, 38 1.1 minoura SERIAL = 1, 39 1.1 minoura } x68k_console_device; 40 1.1 minoura 41 1.1 minoura int 42 1.1 minoura consio_init(int device) 43 1.1 minoura { 44 1.7 tsutsui 45 1.11 snj if (device < 0) { /* undetermined yet */ 46 1.1 minoura if (KEYCTRL & 8) 47 1.1 minoura device = ITE; 48 1.1 minoura else { 49 1.7 tsutsui IOCS_B_PRINT("No keyboard; " 50 1.7 tsutsui "switching to serial console..."); 51 1.1 minoura device = SERIAL; 52 1.1 minoura } 53 1.1 minoura } 54 1.1 minoura 55 1.1 minoura switch (device) { 56 1.1 minoura case ITE: 57 1.1 minoura x68k_console_device = ITE; 58 1.1 minoura /* set palette here */ 59 1.7 tsutsui IOCS_OS_CURON(); 60 1.1 minoura break; 61 1.1 minoura case SERIAL: 62 1.1 minoura x68k_console_device = SERIAL; 63 1.7 tsutsui IOCS_OS_CUROF(); 64 1.7 tsutsui IOCS_SET232C(SERPARAM); 65 1.1 minoura } 66 1.1 minoura 67 1.1 minoura return x68k_console_device; 68 1.1 minoura } 69 1.1 minoura 70 1.1 minoura int 71 1.5 isaki getchar(void) 72 1.1 minoura { 73 1.1 minoura int r; 74 1.1 minoura 75 1.1 minoura switch (x68k_console_device) { 76 1.1 minoura case ITE: 77 1.7 tsutsui while ((r = IOCS_B_KEYINP() & 0xff) == 0); 78 1.1 minoura return r; 79 1.1 minoura case SERIAL: 80 1.7 tsutsui while ((r = IOCS_INP232C() & 0xff) == 0); 81 1.1 minoura return r; 82 1.1 minoura } 83 1.1 minoura 84 1.1 minoura return -1; 85 1.1 minoura } 86 1.1 minoura 87 1.1 minoura void 88 1.5 isaki putchar(int c) 89 1.1 minoura { 90 1.7 tsutsui 91 1.1 minoura if (c == '\n') 92 1.1 minoura putchar('\r'); 93 1.1 minoura switch (x68k_console_device) { 94 1.1 minoura case ITE: 95 1.7 tsutsui IOCS_B_PUTC(c); 96 1.6 tsutsui break; 97 1.1 minoura case SERIAL: 98 1.7 tsutsui IOCS_OUT232C(c); 99 1.6 tsutsui break; 100 1.1 minoura } 101 1.1 minoura } 102 1.1 minoura 103 1.1 minoura int 104 1.5 isaki check_getchar(void) 105 1.1 minoura { 106 1.10 tsutsui int keycode; 107 1.7 tsutsui 108 1.1 minoura switch (x68k_console_device) { 109 1.1 minoura case ITE: 110 1.10 tsutsui while ((keycode = IOCS_B_KEYSNS()) != 0) { 111 1.10 tsutsui keycode &= 0xff; 112 1.10 tsutsui if (keycode != 0) { 113 1.10 tsutsui /* valid ASCII code */ 114 1.10 tsutsui return keycode; 115 1.10 tsutsui } 116 1.10 tsutsui /* discard non ASCII keys (CTRL, OPT.1 etc) */ 117 1.10 tsutsui (void)IOCS_B_KEYINP(); 118 1.12 isaki } 119 1.10 tsutsui /* no input */ 120 1.10 tsutsui return 0; 121 1.1 minoura case SERIAL: 122 1.7 tsutsui return IOCS_ISNS232C() & 0xff; 123 1.1 minoura } 124 1.1 minoura 125 1.1 minoura return -1; 126 1.1 minoura } 127 1.1 minoura 128 1.1 minoura int 129 1.5 isaki awaitkey_1sec(void) 130 1.1 minoura { 131 1.1 minoura int i, c; 132 1.1 minoura 133 1.1 minoura while (check_getchar()) 134 1.1 minoura getchar(); 135 1.1 minoura 136 1.1 minoura for (i = 0; i < 100 && (c = check_getchar()) == 0; i++) { 137 1.1 minoura while (MFP_TIMERC > 100) 138 1.5 isaki (void)JOYA; 139 1.1 minoura while (MFP_TIMERC <= 100) 140 1.5 isaki (void)JOYA; 141 1.1 minoura } 142 1.1 minoura 143 1.1 minoura while (check_getchar()) 144 1.1 minoura getchar(); 145 1.1 minoura 146 1.1 minoura return c; 147 1.1 minoura } 148 1.1 minoura 149 1.3 minoura extern void put_image(int, int); 150 1.3 minoura 151 1.1 minoura void 152 1.1 minoura print_title(const char *fmt, ...) 153 1.1 minoura { 154 1.1 minoura va_list ap; 155 1.1 minoura 156 1.3 minoura if (x68k_console_device == ITE) { 157 1.3 minoura int y, y1; 158 1.3 minoura char *buf = alloca(240); /* about 3 lines */ 159 1.3 minoura char *p; 160 1.3 minoura 161 1.3 minoura y = y1 = (IOCS_B_LOCATE(-1, -1) & 0xffff) + 1; 162 1.5 isaki put_image(8, y*16-6); 163 1.3 minoura IOCS_B_LOCATE(0, y+3); 164 1.4 minoura IOCS_B_PRINT("\360D\360a\360e\360m\360o\360n " 165 1.4 minoura "\360l\360o\360g\360o " 166 1.4 minoura "\360(\360C\360)\3601\3609\3609\3608\360 " 167 1.3 minoura "\360b\360y\360 " 168 1.3 minoura "\360M\360a\360r\360s\360h\360a\360l\360l\360 " 169 1.3 minoura "\360K\360i\360r\360k\360 " 170 1.3 minoura "\360M\360c\360K\360u\360s\360i\360c\360k\360."); 171 1.3 minoura va_start(ap, fmt); 172 1.3 minoura vsnprintf(buf, 240, fmt, ap); 173 1.3 minoura va_end(ap); 174 1.3 minoura while ((p = strchr(buf, '\n')) != 0) { 175 1.3 minoura *p = 0; 176 1.4 minoura IOCS_B_LOCATE(9, ++y); 177 1.4 minoura IOCS_B_PRINT(buf); 178 1.3 minoura buf = p+1; 179 1.3 minoura } 180 1.4 minoura IOCS_B_LOCATE(9, ++y); 181 1.3 minoura IOCS_B_PRINT(buf); 182 1.4 minoura IOCS_B_LOCATE(0, y1+5); 183 1.3 minoura } else { 184 1.3 minoura va_start(ap, fmt); 185 1.3 minoura vprintf(fmt, ap); 186 1.3 minoura va_end(ap); 187 1.3 minoura printf("\n"); 188 1.3 minoura } 189 1.1 minoura } 190