From 6e7ce465e927d12090063fe3d09a806088a59416 Mon Sep 17 00:00:00 2001 From: mycroft Date: Sun, 11 Jun 2000 02:34:23 +0000 Subject: [PATCH] After almost 5 years, it is now time to decommission pcvt. Bon voyage. --- sys/arch/i386/isa/pcvt/Doc/Acknowledgements | 121 - sys/arch/i386/isa/pcvt/Doc/Bibliography | 193 -- sys/arch/i386/isa/pcvt/Doc/BugList | 57 - sys/arch/i386/isa/pcvt/Doc/ChangeLog | 1040 ------ sys/arch/i386/isa/pcvt/Doc/CharGen | 149 - sys/arch/i386/isa/pcvt/Doc/Charsets | 99 - sys/arch/i386/isa/pcvt/Doc/EscapeSequences | 268 -- sys/arch/i386/isa/pcvt/Doc/FAQ | 405 --- .../i386/isa/pcvt/Doc/INSTALL.FreeBSD-2.0 | 160 - sys/arch/i386/isa/pcvt/Doc/INSTALL.NetBSD-1.0 | 115 - sys/arch/i386/isa/pcvt/Doc/Keyboard-Layout.HP | 286 -- sys/arch/i386/isa/pcvt/Doc/Keyboard-Layout.VT | 231 -- sys/arch/i386/isa/pcvt/Doc/Manifest | 170 - sys/arch/i386/isa/pcvt/Doc/TestedHardware | 80 - sys/arch/i386/isa/pcvt/Doc/ToDo | 15 - sys/arch/i386/isa/pcvt/Etc/MAKEDEV.pcvt | 16 - sys/arch/i386/isa/pcvt/Etc/Termcap | 289 -- sys/arch/i386/isa/pcvt/Etc/Terminfo | 41 - sys/arch/i386/isa/pcvt/Etc/pcvt.el | 19 - sys/arch/i386/isa/pcvt/Etc/rc.local | 288 -- sys/arch/i386/isa/pcvt/Etc/ttys.pcvt.freebsd | 148 - sys/arch/i386/isa/pcvt/Etc/ttys.pcvt.netbsd | 70 - sys/arch/i386/isa/pcvt/Etc/uemacs.tar.Z.uu | 594 ---- sys/arch/i386/isa/pcvt/Etc/xmodmap-german | 117 - sys/arch/i386/isa/pcvt/Makefile | 9 - sys/arch/i386/isa/pcvt/README.FIRST | 298 -- sys/arch/i386/isa/pcvt/Util/Makefile | 20 - sys/arch/i386/isa/pcvt/Util/Makefile.inc | 24 - sys/arch/i386/isa/pcvt/Util/cursor/Makefile | 4 - sys/arch/i386/isa/pcvt/Util/cursor/cursor.c | 157 - sys/arch/i386/isa/pcvt/Util/demo/Makefile | 54 - sys/arch/i386/isa/pcvt/Util/demo/README | 20 - .../i386/isa/pcvt/Util/demo/chardemo.vt.gz.uu | 53 - .../i386/isa/pcvt/Util/demo/colors.vt.gz.uu | 15 - .../i386/isa/pcvt/Util/demo/cowscene.vt.gz.uu | 90 - .../isa/pcvt/Util/demo/outerlimit.vt.gz.uu | 193 -- sys/arch/i386/isa/pcvt/Util/demo/playvt.c | 111 - sys/arch/i386/isa/pcvt/Util/demo/sgr.vt.gz.uu | 11 - .../i386/isa/pcvt/Util/demo/twzone.vt.gz.uu | 350 -- .../i386/isa/pcvt/Util/demo/xmas.vt.gz.uu | 110 - sys/arch/i386/isa/pcvt/Util/fed/Makefile | 8 - sys/arch/i386/isa/pcvt/Util/fed/edit.c | 340 -- sys/arch/i386/isa/pcvt/Util/fed/fed.c | 168 - sys/arch/i386/isa/pcvt/Util/fed/fed.h | 127 - sys/arch/i386/isa/pcvt/Util/fed/misc.c | 353 -- sys/arch/i386/isa/pcvt/Util/fed/select.c | 334 -- sys/arch/i386/isa/pcvt/Util/fontedit/Makefile | 7 - sys/arch/i386/isa/pcvt/Util/fontedit/README | 36 - .../i386/isa/pcvt/Util/fontedit/fontedit.c | 925 ------ sys/arch/i386/isa/pcvt/Util/fonts/COPYRIGHT | 37 - sys/arch/i386/isa/pcvt/Util/fonts/Makefile | 56 - .../i386/isa/pcvt/Util/fonts/vt220h.808.uu | 49 - .../i386/isa/pcvt/Util/fonts/vt220h.810.uu | 60 - .../i386/isa/pcvt/Util/fonts/vt220h.814.uu | 83 - .../i386/isa/pcvt/Util/fonts/vt220h.816.uu | 95 - .../i386/isa/pcvt/Util/fonts/vt220l.808.uu | 49 - .../i386/isa/pcvt/Util/fonts/vt220l.810.uu | 60 - .../i386/isa/pcvt/Util/fonts/vt220l.814.uu | 83 - .../i386/isa/pcvt/Util/fonts/vt220l.816.uu | 95 - sys/arch/i386/isa/pcvt/Util/ispcvt/Makefile | 8 - sys/arch/i386/isa/pcvt/Util/ispcvt/ispcvt.c | 303 -- sys/arch/i386/isa/pcvt/Util/kbdio/Makefile | 24 - sys/arch/i386/isa/pcvt/Util/kbdio/kbdio.y | 343 -- sys/arch/i386/isa/pcvt/Util/kbdio/lex.l | 86 - sys/arch/i386/isa/pcvt/Util/kcon/Makefile | 11 - sys/arch/i386/isa/pcvt/Util/kcon/kcon.c | 753 ----- sys/arch/i386/isa/pcvt/Util/keycap/Makefile | 17 - sys/arch/i386/isa/pcvt/Util/keycap/keycap.c | 377 --- sys/arch/i386/isa/pcvt/Util/keycap/keycap.h | 49 - sys/arch/i386/isa/pcvt/Util/keycap/keycap.src | 613 ---- .../i386/isa/pcvt/Util/keycap/shlib_version | 4 - sys/arch/i386/isa/pcvt/Util/loadfont/Makefile | 5 - .../i386/isa/pcvt/Util/loadfont/loadfont.c | 392 --- sys/arch/i386/isa/pcvt/Util/mcon/Makefile | 5 - sys/arch/i386/isa/pcvt/Util/mcon/mcon.c | 193 -- sys/arch/i386/isa/pcvt/Util/scon/Makefile | 5 - sys/arch/i386/isa/pcvt/Util/scon/scon.c | 860 ----- sys/arch/i386/isa/pcvt/Util/set2061/CAUTION | 28 - .../i386/isa/pcvt/Util/set2061/ICD2061Aalt.c | 297 -- sys/arch/i386/isa/pcvt/Util/set2061/Makefile | 10 - sys/arch/i386/isa/pcvt/Util/set2061/README | 22 - .../i386/isa/pcvt/Util/set2061/compiler.h | 340 -- sys/arch/i386/isa/pcvt/Util/set2061/main.c | 112 - sys/arch/i386/isa/pcvt/Util/userkeys/Makefile | 5 - .../i386/isa/pcvt/Util/userkeys/vt220keys.c | 297 -- sys/arch/i386/isa/pcvt/Util/vgaio/CAUTION | 28 - sys/arch/i386/isa/pcvt/Util/vgaio/Makefile | 22 - sys/arch/i386/isa/pcvt/Util/vgaio/lex.l | 67 - sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.h | 45 - sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.y | 262 -- sys/arch/i386/isa/pcvt/Util/vttest/Makefile | 6 - sys/arch/i386/isa/pcvt/Util/vttest/README | 57 - sys/arch/i386/isa/pcvt/Util/vttest/esc.c | 398 --- sys/arch/i386/isa/pcvt/Util/vttest/header.h | 50 - sys/arch/i386/isa/pcvt/Util/vttest/main.c | 2098 ------------ sys/arch/i386/isa/pcvt/pcvt_conf.h | 385 --- sys/arch/i386/isa/pcvt/pcvt_cons.h | 1 - sys/arch/i386/isa/pcvt/pcvt_drv.c | 936 ------ sys/arch/i386/isa/pcvt/pcvt_ext.c | 2847 ---------------- sys/arch/i386/isa/pcvt/pcvt_hdr.h | 1212 ------- sys/arch/i386/isa/pcvt/pcvt_ioctl.h | 584 ---- sys/arch/i386/isa/pcvt/pcvt_kbd.c | 2942 ----------------- sys/arch/i386/isa/pcvt/pcvt_kbd.h | 574 ---- sys/arch/i386/isa/pcvt/pcvt_out.c | 2251 ------------- sys/arch/i386/isa/pcvt/pcvt_sup.c | 2049 ------------ sys/arch/i386/isa/pcvt/pcvt_tbl.h | 476 --- sys/arch/i386/isa/pcvt/pcvt_vtf.c | 2216 ------------- 107 files changed, 34120 deletions(-) delete mode 100644 sys/arch/i386/isa/pcvt/Doc/Acknowledgements delete mode 100644 sys/arch/i386/isa/pcvt/Doc/Bibliography delete mode 100644 sys/arch/i386/isa/pcvt/Doc/BugList delete mode 100644 sys/arch/i386/isa/pcvt/Doc/ChangeLog delete mode 100644 sys/arch/i386/isa/pcvt/Doc/CharGen delete mode 100644 sys/arch/i386/isa/pcvt/Doc/Charsets delete mode 100644 sys/arch/i386/isa/pcvt/Doc/EscapeSequences delete mode 100644 sys/arch/i386/isa/pcvt/Doc/FAQ delete mode 100644 sys/arch/i386/isa/pcvt/Doc/INSTALL.FreeBSD-2.0 delete mode 100644 sys/arch/i386/isa/pcvt/Doc/INSTALL.NetBSD-1.0 delete mode 100644 sys/arch/i386/isa/pcvt/Doc/Keyboard-Layout.HP delete mode 100644 sys/arch/i386/isa/pcvt/Doc/Keyboard-Layout.VT delete mode 100644 sys/arch/i386/isa/pcvt/Doc/Manifest delete mode 100644 sys/arch/i386/isa/pcvt/Doc/TestedHardware delete mode 100644 sys/arch/i386/isa/pcvt/Doc/ToDo delete mode 100644 sys/arch/i386/isa/pcvt/Etc/MAKEDEV.pcvt delete mode 100644 sys/arch/i386/isa/pcvt/Etc/Termcap delete mode 100644 sys/arch/i386/isa/pcvt/Etc/Terminfo delete mode 100644 sys/arch/i386/isa/pcvt/Etc/pcvt.el delete mode 100644 sys/arch/i386/isa/pcvt/Etc/rc.local delete mode 100644 sys/arch/i386/isa/pcvt/Etc/ttys.pcvt.freebsd delete mode 100644 sys/arch/i386/isa/pcvt/Etc/ttys.pcvt.netbsd delete mode 100644 sys/arch/i386/isa/pcvt/Etc/uemacs.tar.Z.uu delete mode 100644 sys/arch/i386/isa/pcvt/Etc/xmodmap-german delete mode 100644 sys/arch/i386/isa/pcvt/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/README.FIRST delete mode 100644 sys/arch/i386/isa/pcvt/Util/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/Makefile.inc delete mode 100644 sys/arch/i386/isa/pcvt/Util/cursor/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/cursor/cursor.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/README delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/chardemo.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/colors.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/cowscene.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/outerlimit.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/playvt.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/sgr.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/twzone.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/demo/xmas.vt.gz.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fed/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/fed/edit.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/fed/fed.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/fed/fed.h delete mode 100644 sys/arch/i386/isa/pcvt/Util/fed/misc.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/fed/select.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/fontedit/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/fontedit/README delete mode 100644 sys/arch/i386/isa/pcvt/Util/fontedit/fontedit.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/COPYRIGHT delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220h.808.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220h.810.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220h.814.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220h.816.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220l.808.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220l.810.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220l.814.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/fonts/vt220l.816.uu delete mode 100644 sys/arch/i386/isa/pcvt/Util/ispcvt/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/ispcvt/ispcvt.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/kbdio/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/kbdio/kbdio.y delete mode 100644 sys/arch/i386/isa/pcvt/Util/kbdio/lex.l delete mode 100644 sys/arch/i386/isa/pcvt/Util/kcon/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/kcon/kcon.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/keycap/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/keycap/keycap.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/keycap/keycap.h delete mode 100644 sys/arch/i386/isa/pcvt/Util/keycap/keycap.src delete mode 100644 sys/arch/i386/isa/pcvt/Util/keycap/shlib_version delete mode 100644 sys/arch/i386/isa/pcvt/Util/loadfont/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/loadfont/loadfont.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/mcon/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/mcon/mcon.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/scon/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/scon/scon.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/set2061/CAUTION delete mode 100644 sys/arch/i386/isa/pcvt/Util/set2061/ICD2061Aalt.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/set2061/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/set2061/README delete mode 100644 sys/arch/i386/isa/pcvt/Util/set2061/compiler.h delete mode 100644 sys/arch/i386/isa/pcvt/Util/set2061/main.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/userkeys/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/userkeys/vt220keys.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/vgaio/CAUTION delete mode 100644 sys/arch/i386/isa/pcvt/Util/vgaio/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/vgaio/lex.l delete mode 100644 sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.h delete mode 100644 sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.y delete mode 100644 sys/arch/i386/isa/pcvt/Util/vttest/Makefile delete mode 100644 sys/arch/i386/isa/pcvt/Util/vttest/README delete mode 100644 sys/arch/i386/isa/pcvt/Util/vttest/esc.c delete mode 100644 sys/arch/i386/isa/pcvt/Util/vttest/header.h delete mode 100644 sys/arch/i386/isa/pcvt/Util/vttest/main.c delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_conf.h delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_cons.h delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_drv.c delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_ext.c delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_hdr.h delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_ioctl.h delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_kbd.c delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_kbd.h delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_out.c delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_sup.c delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_tbl.h delete mode 100644 sys/arch/i386/isa/pcvt/pcvt_vtf.c diff --git a/sys/arch/i386/isa/pcvt/Doc/Acknowledgements b/sys/arch/i386/isa/pcvt/Doc/Acknowledgements deleted file mode 100644 index c0718976f578..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/Acknowledgements +++ /dev/null @@ -1,121 +0,0 @@ -Thank You, (in the order of appearance) - - - Lynne and Bill Jolitz - - for your work on 386BSD and making all this possible ! - - - Holger Veit (veit@du9ds3.uni-duisburg.de) - - for the permission to use a modified version of his keyboard - driver and utilities for keyboard remapping / multinational - keyboard support. - - - Per Lindberg - - for the extremely helpful vt100 terminal testprogram found - in the directory vttest. - - - John Birchfield - - for the ncsa telnet package, which contains a vt100 emulation - and which was very helpful in studying some concepts. - - - Ralf Friedl (friedl@informatik.uni-kl.de) - - for making his implementation of multi-sceens for the net-2 - distribution available. i looked at this and took some ideas - and lines from his code. - - - Bruce Evans (bde@runx.oz.au) - - for contributing some bugfixes and a complete termcap entry - - - Brian H. Dunford-Shore (brian@morpheus.wustl.edu) - - for contributing most of the EGA/VGA screen switching code - and being a fast, reliable and responsive co-author. This - driver would not be what it is without Brian, Thank You ! - - - Frank da Cruz (fdc@columbia.edu) - - for my famous datacomm program and for giving the permission - to redistribute files from the msdos kermit distribution - located in the directory support/demo. - - - Joerg Wunsch (joerg_wunsch@uriah.sax.de) - - for contributing precise bugreports and -fixes, the 8x10 - EGA/VGA fonts and the color palette ioctls and for being - a very responsive contributor of various ideas. - Joerg wrote pcvt's interface to XFree86 1.2 and 1.3 and - the SYSV/syscons - like interface to XFree86 2.0. - There would be no support for X without Joerg's work! - Thank you very much Joerg, i enjoy it !!! :-) - - - Scott Turner (scotty@gagetalker.com) - - for contributing code to change the winsize structure, many - discussions on the keyboard code and fine-tuning the driver - - - Gordon L. Burditt (gordon@sneaky.lonestar.org) - - for the nicest and most complete bugreports i ever got - - - Theo Deraadt (deraadt@fsa.ca) - - for pushing me forward. There would be no 3.00 release - if Theo didn't asked for features ... ;-) - - - Onno van der Linden (c/o frank@fwi.uva.nl) - - for writing the 132 column support for the Cirrus - chipsets although he had no time to do it ... :-) - - - Wolfgang Solfrank, Ingo Koenig - - for putting some data onto tape (and handling and shipping - in the case of Wolfgang) to provide me with some latest - sources because i still have no ip-connectivity .... - - - Michael Havemester (tik@abqhh.hanse.de) - - for giving me a chance to stay up to date with NetBSD- - current, for programming the initial version of the fast - scrolling code and for the keyboard fifo code! - - - Charles Hannum (mycroft@gnu.ai.mit.edu) - - for getting bored by a slow-scrolling video driver and - for leaving me some bugs to fix ;-) - - - The NetBSD and FreeBSD teams - - for giving me something to play, work and learn with ! - There would be nothing to write a driver for without you !!! - - - J.T. Conklin - - for forwarding the pcvt-related NetBSD PR's to me ! - - - John Kohl - - for producing patches for NetBSD-current ! diff --git a/sys/arch/i386/isa/pcvt/Doc/Bibliography b/sys/arch/i386/isa/pcvt/Doc/Bibliography deleted file mode 100644 index 2f60910b7fd7..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/Bibliography +++ /dev/null @@ -1,193 +0,0 @@ - -VGA BOOKS ---------- - - Richard Wilton, "Programmers Guide to PC & PS/2 Video Systems", - Microsoft Press 1987 - - - Richard F. Ferraro, "Programmers Guide to the EGA and VGA Cards", - Second Edition, Addison-Wesley 1990 - - - Richard F. Ferraro, "Programmers Guide to the EGA and VGA Cards", - Third Edition, Addison-Wesley 1994 - - - Matthias Uphoff, "Die Programmierung der EGA/VGA Grafikkarte", - Addison Wesley 1992 - - - Bradley Dyck Kliewer, "EGA/VGA A Programmers Reference Guide", - McGraw Hill, 2nd Edition 1990 - - -UNIX AND UNIX DEVICE DRIVERS ----------------------------- - - Bell Telephone Laboratories, Inc. "UNIX Programmer's Manual, Seventh - Edition, Volume 2". Revised and Expanded Version. - Holt, Rinehart and Winston 1983 - - - George Pajari, "Writing Unix Device Drivers" - Addison Wesley 1992 - - - Janet I. Egan and Thomas J. Teixeira, "Writing a UNIX Device Driver" - John Wiley & Sons 1988 - - - Janet I. Egan and Thomas J. Teixeira, "Writing a UNIX Device Driver" - Second Edition. John Wiley & Sons 1992 - - - Leffler, McKusick, Karels, Quarterman, "The Design and Implementation - of the 4.3BSD UNIX Operating System" - Addison Wesley 1988, corrected Reprint 1989 - - - Leffler, McKusick, "The Design and Implementation of the 4.3BSD UNIX - Operating System, Answer Book" - Addison Wesley 1991 - - - Maurice J. Bach, "The Design of the UNIX Operating System" - Prentice-Hall 1986 - - - Sun Microsystems Inc., "Writing Device Drivers" - Part No. 800-3851-10, Revision A of 27 March 1990 - - - Hewlett-Packard Company, "HP-UX Driver Development Guide", - Part No. 98577-90013, First Edition 07/91 - - - W. Richard Stevens, "Advanced Programming in the UNIX Environment", - Addison Wesley 1992 - - - Phillip M. Adams, Clovis L. Tondo, "Writing Unix Device Drivers in C", - Prentice Hall 1993 - - - Berny Goodheart, James Cox, "The Magic Garden Explained", - Prentice Hall 1994 - - - Peter Kettle, Steve Statler, "Writing Device Drivers for SCO Unix" - Addison Wesley 1993 - - - Tim Burke, Mark A. Parenti, Al Wojtas, "Writing Device Drivers, - Tutorial and Reference", Digital Press 1995 - - -TERMINAL MANUALS ----------------- - - Digital Equipment, VT100 Users Manual, 2nd ed. 1979 - Digital Equipment, VT132 Users Manual - Digital Equipment, VT220 Programmers Reference Manual, 2nd ed. 1984 - Digital Equipment Corporation - - - Hewlett Packard, 700/92 Technical Reference Manual (ANSI Operation) - Hewlett Packard, 2392a Users Manual (ANSI Operation) - Hewlett-Packard Company - - - Walker Richer & Quinn, Inc., "Reflection 2 and Reflection 4 Technical - Reference Manual", Version 4.2 - Walker, Richer & Quinn, Seattle, August 1992 - - -IBM PC HARDWARE/FIRMWARE ------------------------- - - Frank van Gilluwe, "The Undocumented PC", - Addison Wesley, First Edition May 1994 - - - IBM Corporation, "Technical Reference Personal Computer AT", - Part No. 6280070, Form No. S229-9611-00, First Edition 1985 - - - Phoenix Technologies Ltd., "System BIOS for IBM PC/XT/AT Computers - and Compatibles", Addison Wesley, Fourth Printing June 1990 - - - Phoenix Technologies Ltd., "System BIOS for IBM PCs, Compatibles, - and EISA Computers", Second Edition - Addison Wesley, First Printing May 1991 - - - American Megatrends, Inc., "Hi-Flex ISA and EISA AMIBIOS Technical - Reference", American Megatrends, Inc. 1992 (9/25/92) - - - Thom Hogan, "The Programmers PC Sourcebook", 2nd Edition - Microsoft Press, 1991 - - -TERMCAP/TERMINFO ----------------- - - John Strang, Linda Mui and Tim O'Reilly, "Termcap and Terminfo", - O'Reilly & Associates, Inc. , April 1991 - - - Richard M. Stallman, "Termcap - The Termcap Library and Data Base", - Free Software Foundation, Second Edition November 1988 - - - -DATABOOKS/DATASHEETS --------------------- - - Intel Corporation, "Microsystem Components Handbook Volume II", - Intel Corporation, 1984 - - - Intel Corporation, "Peripheral Design Handbook", - Intel Corporation, 1980 - - - Tseng Labs, Inc. "ET4000 Graphics Controller Data Book", 1990 - - - Western Digital Corporation, "WD90C11, WD90C11A (PVGA1C) Enhanced - VGA Controller", Western Digital 9/18/91 - - - Western Digital Corporation, "WD90C00 Enhanced VGA Controller", - Western Digital 1/14/91 - - - Western Digital Corporation, "WD90C00 Interface Guide", - Western Digital 1/10/91 - - - Western Digital Corporation, "VGA Register Based Programmers Manual", - Western Digital 1/30/91 - - - Western Digital Corporation, "VGA BIOS Programmers Manual", - Western Digital 1/10/91 - - - Cirrus Logic, "True Color VGA Family - CL-GD542X", Technical Ref. - Manual, Cirrus Logic, Inc. April 1993 - - - S3 Inc, "86C801/86C805 GUI Accelerators" - S3 Incorporated, September 1992 - - - S3 Inc, "86C928 GUI Accelerator" - S3 Incorporated, July 1993 - - - Trident Microsystems Inc., "TVGA9000i Technical Reference Manual", - Trident Microsystems, Inc. (c) 1992, March 1993, Rev 1 diff --git a/sys/arch/i386/isa/pcvt/Doc/BugList b/sys/arch/i386/isa/pcvt/Doc/BugList deleted file mode 100644 index 27a574807cf6..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/BugList +++ /dev/null @@ -1,57 +0,0 @@ - -List of known bugs Last Edit-Date: [Tue Sep 5 17:52:05 1995] -================================================================================ - - -Description: Fixed/done by/date -------------------------------------------- -------------------------------- -Util/keycap/man5/keycap.5 does STILL not -build correctly when doing a make obj. -Will there ever be a solution ... :-) -------------------------------------------- -------------------------------- -NetBSD PR #404: Meta-Control-Space broken -with PCVT_META_ESC and PCVT_NULLCHARS set -Meta-Control-Space should (theoretically) -send ESC NUL if PCVT_NULLCHARS and -PCVT_META_ESC are defined; in reality, it -just sends ESC. Because of the grody -encoding hack used by sgets() to implement -PCVT_NULLCHARS (if the first character is -a null, send it), there isn't a trivial -one-line fix. -How-To-Repeat: in a kernel with -PCVT_NULLCHARS and PCVT_META_ESC, type a -M-C-SPC to emacs. -------------------------------------------- -------------------------------- -when auto switching to vt0 is enabled by -PCVT_SW0CNOUTP and the screen is switched -from an X-vt to screen 0, the video mem -is irrecoverably destroyed - no data loss -------------------------------------------- -------------------------------- -Altgr+Shift+key is not separately They way the keyboard mapping -mappable. is done is subject to a sub- - stantial rewrite in a future - release -------------------------------------------- -------------------------------- -132 column mode not working with #9 GXE -(S3-based) (sorry, i don't have one -hm) -(see discussion of 132 column mode in the - NotesAndHints file!) -------------------------------------------- -------------------------------- -WD90Cxx chip detection fails to detect -chips other than C00,C10 and C11. C30 -chips are detected as C11s .... -------------------------------------------- -------------------------------- -On one keyboard, if a "Lock" key is pressed -the leds do not get updated and the key- -board hangs. -------------------------------------------- -------------------------------- -HP function key labels code needs to set -the user defined fkey string somehow! -------------------------------------------- -------------------------------- -Video 7 1024i not fully supported yet, has -sometimes problems with some chars to displ -------------------------------------------- -------------------------------- -The HP-Escape sequences need to be FULLY 28.12.93, -hm did a bit to supp- -implemented port elm. Needs MORE work ! -------------------------------------------- -------------------------------- diff --git a/sys/arch/i386/isa/pcvt/Doc/ChangeLog b/sys/arch/i386/isa/pcvt/Doc/ChangeLog deleted file mode 100644 index 75f673162dd3..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/ChangeLog +++ /dev/null @@ -1,1040 +0,0 @@ -ChangeLog last edit-date: [Tue Oct 3 12:32:18 1995] -================================================================================ - -Release 3.32 October 1995 --------------------------------------------------------------------------------- - -- renamed Doc/NotesAndHints to Doc/FAQ - -- TS_ASLEEP not available in FreeBSD 2.1 (FreeBSD 2.1.0 SNAP 950928) - -- patch from John Kohl adding missing kbd_setmode() in switch_screen() - -- implemented KDGKBMODE ioctl - -- removed support for KBDGLEDS and KBDSLEDS private ioctls - -- changed/updated pcvt termcap entry in Doc/Termcap - -- patch from Thomas Gellekum: GL and GR did not get updated after - loading a new charset into G0..G3, fixed in pcvt_vtf.c - -- patch from Charles Hannum to further cleanup the saved keyboard state - per screen patch. - -- patch from Frank van der Linden to support a saved keyboard state per - screen instead of one global saved flag. - -- the support for NetBSD <= 0.9 and FreeBSD <= 1.1.5.1 has been dropped since - i don't run this OS versions anymore. Not all the code supporting - this versions has been removed but it will disappear without further - notice. - -- removing support for the old pccons-like handling of the Xserver, the - former option PCVT_USL_VT_COMPAT has been removed since it is - now the only supported way of running X with pcvt. - -- patch from Martin Husemann for 132 cols switch support for Cirrus GD6225 - -- patch from Martin Husemann to support Cirrus GD6225 VGA chipsets (Notebooks) - -- patch from Thomas Gellekum to introduce VT220 C1 control support - -- patch from Thomas Gellekum, this fixes a problem in the scrollregion code, - only reproducable under VMS: in some cases svsp->abs_write was set - to 1 when the scrollregion was set which caused check_scroll() to - fail. - -- patch from Ulf Kieber (uk1@irz301.inf.tu-dresden.de) to pcvt_conf.h to - better support changing the kernel message foreground and background - color at compile time, on monochrome diplays kernel messages are - underlined by default, so one can't distinguish between 'p' and 'q' - on some displays. - -- hint from Patrick Hausen to put 'pcvt' in the kcon manual page header - -- patch from Joerg to loadfont to support variable scanline values - -- patch from Joerg to make the mouse emulator work again (pcvt_drv.c) - - -Release 3.30 July 1995 --------------------------------------------------------------------------------- - -- new Makefile for pcvt fonteditor Util/fed - -- patch from Joerg, removing all trailing whitespace chars - -- added missing ECHO definition in Util/Makefile.inc.NetBSD-current - (reported by Matthieu Herrb) - -- patch from John Kohl and Douglas Crosher for NetBSD-current regarding a - changed name of an include file - -Changes 3.10 -> 3.20 June 1995 --------------------------------------------------------------------------------- - -- updating Etc/rc.local to support path variables for pcvt utilities - -- fixing some code for compile with -Wall (unused variables/ add brackets) - -- patch to make pcvt work on NetBSD-current and a patch to fix a FreeBSD - bug; both from John Kohl, also a minor change from him: - - I changed the auto-detect code to set PCVT_NETBSD to 102 if on - -current; I figure people can use "options PCVT_NETBSD=101" in - their config file if they need to. - -- keyboard code bugfix from Jukka A. Ukkonen (ukkonen@csc.fi): - - I noticed that the doreset() function in pcvt was too hasty - in expecting SELFOK answers from certain keyboards. At least - Alps Membrane seems to first respond with an ACK as expected - but then it takes a short moment for itself. - During that time the only response to any attempts to fetch - the status value is -1. If one didn't allow for a few negative - replies being received before the SELFOK, one would get the - SELFOK only when expecting the answer to KBD ID query and - right after that there would be a request to re-issue the - KBD ID query. - - My patch may not be the best possible solution, but it hits - the point quite nicely. With this patch attached e.g. Alps - Membrane will be correctly recognized as an MF-II keyboard. - -- adding NetBSD-current patches from John Kohl - -- added ${DESTDIR} to some Makefiles (patch from Joerg) - -- added support for Cirrus Logic CL-GD5430 VGA chipset 132 columns mode - -- new Util/Makefile.inc for FreeBSD 2.0.5-RELEASE - -- merging in changes from FreeBSD 2.0.5-RELEASE - -- (internal) release beta 25 --------------------------------------------------- - -- added ECHO to Makefile.inc.*BSD - -- added some (!) ${DESTDIR}'s to utilities Makefiles in Util - -- patch from Michael Havemester for NetBSD current later than April 21 1995, - for integration into NetBSD later than this date one has to define - a version value greater than 101, i.e. "options PCVT_NETBSD=102" - -- patch from joerg: - - if pcvt is acting as the systems console avoid panics going to - the debugger while we are in process mode. - - before using svsp->vs_tty and svsp->vs_tty->t_pgrp check that - vs_tty and t_pgrp are really set, other wise one can get panics - while booting with -c in FreeBSD - -- added -f to all gunzip's in Util/demo - -- added destination directory to ispcvt Makefile - -- moved pcvt.4 and Makefile from Doc to Util/pcvtdoc - -- Util Makefile cleanup - -- Util Makefile patch from Bruce Evans - -- Util Makefile patch from Joerg - -- updated example rc.local in directory Etc to run on a serial console - -- release beta 24 -------------------------------------------------------------- - -- bugfix from Thomas Eberhardt: the force 24 lines enable function key - label was not updated when changing force 24 lines mode with - 'scon -f on|off', this is now fixed. - -- bugfix from John Kohl fixing divide by zero problem in pcvt_ext.c when - ringing the bell and pitch is 0: this avoids an integer divide - trap in supervisor mode. - -- changed the default behaviour of keyboard controller delay from using - delay()/DELAY() to using dummy reads to port 0x84 because i got - keyboard hangs in X. - -- bugfix: in pcvt_ext.c, MDA state restore when leaving X was lost, should - function now again. - -- renamed PCVT_XSERVER to XSERVER in ispcvt.c - -- bugfix in pcvt_vtf.c: renamed PCVT_USL_COMPAT to PCVT_USL_VT_COMPAT - -- added '-d ' option to ispcvt and loadfont - -- removed PCVT_NEEDPG - -- almost completely removed support for 386BSD 0.1 with patchkit 0.2.4 - -- applied a patch from Joerg providing missing FreeBSD 2.1 functionality and - a some minor bugfixes and checks. - -- provide a single place PCVT_KBD_DELAY in pcvt_hdr.h. made it configurable - via PCVT_PORTIO_DELAY to use either 6 dummy reads from port 0x84 - or the delay/DELAY function of the operating system. Changed ispcvt - to report status of compile time switch. - -- release beta 23 -------------------------------------------------------------- - -- removed some files for 386BSD as there is virtually noone outside - using it anymore - -- make pcvt_ioctl.h accept "KERNEL" or "_KERNEL" for NetBSD-current - -- configuration fix: patch from Rafal Boni for pcvt_vtf.c, he writes: - This patch lets one compile pcvt on a system that is lacking XSERVER - and UCONSOLE [or either?] in the config file. I found this while - trying to build a minimal floppy-based test kernel. The problem is - that roll_up and roll_down assume that PCVT_USL_COMPAT is - unconditionally set, and hence muck with parts of the video structure - that are only there if PCVT_USL_COMPAT is set. - (generalized the patch a bit so that fastscroll functionality is - not lost in case of PCVT_USL_COMPAT not being defined. -hm) - -- bugfix: pcvt_ext.c switch_screen() - when switching to a 25 line charset - pure VT emulation screen which has force 24 lines set, then we have - to clear the last line on screen (bugreport from Joerg). - -- added define PCVT_NONRESP_KEYB_TRY for how many times to try to detect - a non-connected keyboard. This was previously set to 100 and - Joerg reports a 5+ minutes delay for a 386 booting without keyboard. - Set to 25 now in the definition. Also made shure the messages in - the corresponding loop display only once. [doreset() in pcvt_kbd.c] - -- updated kbdio utility to include the 7 us delay and added a 'what' command - detect type of MCA motherboard keyboard controller according to - Frank van Gilluwe, "The Undocumented PC", Addison Wesley, pp 273 - -- "Gateway 2000" problem: after some discussion on the NetBSD port-i386 - mailing list about hanging keyboards, Martin Husemann sent in a - patch where each inb(CONTROLLER_DATA) is now preceeded by a - delay(6). This fixed his keyboard problem, the same was reported - from Roland McGrath for his Gateway 2000 keyboard/machine. - -- patch from John Kohl for usl_vt_ioctl() in file pcvt_ext.c, he writes: - This is probably a long standing bug. tsleep() returns ERESTART - if it's interrupted. ERESTART is -1, which means that the - VT_WAITACTIVE call returns from usl_vt_ioctl() with -1, - meaning "not one of my ioctl's". - -- patch from Matthieu Herrb for NetBSD-current (post 1.0) support - -- patch from Joerg for FreeBSD pre-2.1 support - -- added file ToDo in directory Doc - -- fix for Util/Makefile.inc.NetBSD-c from Onno - -- removing unnecessary Trident support code from pcvt_out.c - -- fix from Onno for IST_EDGE in NetBSD-current - -- patch from Thomas Eberhardt to fix the bell frequency and duration setting - for NetBSD - -- some fixes from Onno van der Linden for NetBSD - -- added patch for NetBSD-current from Rafal Boni and Lon Willett - -- added another mega patch from Lon Willett fixing several bugs: - - 1 -- Misc porting changes to deal with NetBSD-current, including - a new Util/Makefile.inc.NetBSD-current. - - 2 -- The Control_R scancodes were being mapped to the Control_L - pcvt keynum. - - 3 -- FASTSCROLL/graphics-mode problem: there was a problem where - switching from a graphics screen to a text screen would corrupt - the text screen's content if it had been scrolling using the - FASTSCROLL code. (The problem is the bcopy() from kernel to - video memory was using the vs[i].Memory pointer as the source, - instead of the vs[i].Crtat pointer). This is fixed in the beta - 21 release by just disabling the fast scroll code for screens - which aren't active. - - The patch I'm sending you re-enables the fast scroll code on - inactive (i.e. in kernel memory) screens, saving a few cpu - cycles. - - 4 -- This is a big one: running multiple X servers was not - really working. The USL handshaking code was a mess (not very - well designed to begin with, but there's not much that can be - done about that). I did manage to get it fairly functional, but - there's a lot of changes. - -- changing example rc.local to take care of good old EGA's - -- fixing support for EGA boards in vt_coldinit() - -- removing vt100 font files from Util/fonts, updated Manifest - -- fixing an obviously longstanding bug in roll_up() / roll_down() which was - triggered by Joergs "Crtat" cleanup mega patch. - -- removing PCVT_FAKE_SYSCONS10 - -- removing duplicate names in termcap entries - -- fixing vt_coldinit: setting variable "color" for mda/hercules and cga - initializing cursor position - -- fixing roll_up() and roll_down() for mda/hercules: mda's have ALWAYS - just one page of memory, original hercules boards too so they - can NEVER use the fastscroll option. SOME hercules are somehow - enhanced in that they support 2 pages. pcvt now just supports - one page hercules/mda! - -- made cleanups to 8x14 high and 8x8 high fonts: adjust the 5 scanline - characters to adjust with the corner characters from the low fonts - -- applying patch from Joerg which fixes some bugs: - - writing to a tty containing an X server resulted in some stange - behaviour depending on the opsys and opsys version used - - the init code preserving the screen contents and cursor shape - can only be done on boards allowing the reading of - several crtc registers - -- removed bcopyb declaration from pcvt_hdr.h for FreeBSD 2.1 - -- another patch from Lon Willett (willett@math.utah.edu), he writes: - - 1 -- Very minor: One of my previous changes didn't get merged - into "pcvt_out.c"; the caclulation of ws_row doesn't account for - "force24" at one spot. It's easier to just set it from - screen_rows anyway, unless there's something that I didn't - understand happening here. - - 2 -- Debugging stuff: I don't know if you care to add it, but I - found it useful, so I left it in. I rearranged the - PCVT_SHOWKEYS code a little, and added a few lines to show - keyboard commands and responses, with special delimiters. - [file: pcvt_kbd.c] - - 3 -- "kcon" utility enhancement: I added a "-R" switch to kcon - to do a KBDRESET ioctl. [file: Util/kcon/kcon.c] - - 4 -- KBDRESET-ioctl bug: the code was trying to read kbd - responses without an spltty(), so naturally it would fail, since - pcrint() was grabbing the ACKs. [file: pcvt_kbd.c] - - 5 -- update_led() makes kbd hang: the problem here is that - update_led() makes the keyboard generate two KEYB_R_ACK - responses, and one of the interrupts sometimes gets lost when - there is a lot of other I/O happening. See the comment in the - code. My fix seems to work for me, but you may want to handle - it some other way. It would probably be quite reasonable to - check for lost interrupts periodically anyway, whether - update_led() has been called or not. [file: pcvt_kbd.c] - - (NOTE: item 5 has been disabled because it causes older - FreeBSD's to panic because of the timer queue not being - initialized at the time called. -hm) - -- partly rewrote doreset() in pcvt_kbd.c to enable boot procedure to proceed - if no (PC) keyboard is found. The current behaviour and implementation - is subject to change. - -- patch from Thomas Gellekum to Util/keycap/keycap.src - -- minor modification to main.c in Util/set2061 - -- patch from Onno and John Kohl to make pcvt beta 16 work on NetBSD current: - 1. pcvt_conf.h - _real_ 1.0 ===> NetBSD1_0 == 1 - current 1.0 (1.0A) ===> NetBSD1_0 == 2 - 2. pcvt_hdr.h - Put pcvt_conf.h before _all_ the #ifdef PCVT_*. This way - the #ifdef NetBSDx_y stuff can do its work. - -- size of PCVT_BURST was still reported as 1 for FreeBSD 2.0, fixed - -- made some adjustments for FreeBSD 2.0 in Util/vgaio - -- Another patch from Joerg for FreeBSD 2.0 - -- included vgaio, kbdio and set2061 into the outer Makefile, this programs - are build and cleaned but don't install anything. - All program's in the Util dir should now cleanly make ... - -- enable 132 column support for Trident TVGA8900CL, some NetBSDisms - -- addend patch from Joerg for pcvt-320b7 to fix FreeBSD 2.0's ttymalloc's - encapsulation into #if's. Also new keycap.src entry. - -- fixed keyboard status/LED not updated on soft reset emulator - -- on 23rd of December i had some spare time, so i added some demos to the - Util/demo directory as well a a time-killer program (playvt) to view - some of the VT animations and a christmas animation i got from Joerg. - -- added a new utility set2061 to program the clock generator on my S3 based - ELSA Winner VGA board. This eventually lets me use 132 columns on this - board, because i'm now able to program the clock to generate 40MHz - on clock output #2. - -- debugged winsize patch on FreeBSD 1.1, line discipline open init's the - queues, winsize initialization must happen after line disc. open! - -- got a bunch of NetBSD PR's from J.T. Conklin: - - PR #214: PCVT treats ctrl-shift exactly like shift for most characters. - (fixed by Lon Willet's Mega Patch described below -hm) - - PR #399: If you define PCVT_META_ESC when builting PCVT, Meta-Return - sends 0x8d instead of ESC RET. - (fixed by applying the patch from Bill Sommerfeld. -hm) - - PR #400: pcvt sometimes gets confused about window size - (fixed by applying the patch from Bill Sommerfeld. -hm) - - PR #404: Meta-Control-Space broken with PCVT_META_ESC and PCVT_NULLCHARS - (put into "BugList" file, no solution yet .. -hm) - - PR #488: pcvt can loose keyboard control if you start an xserver from - an xterm - (already fixed by a patch from John Kohl, see below -hm) - - PR #580: NetBSD i386/pcvt bugs/enhancements; fixes included - (already integrated the patch from Lon Willet, see below -hm) - -- on coldinit, if FAT_CURSOR is defined, the old large blockcursor is used - -- enhanced the vgaio output in an attempt to make 132 column mode work - for my S3 board .... - -- applied patch from Thomas Gellekum: install instructions for FreeBSD 2.0, - patch to fontedit to compile under FreeBSD 2.0, an addition to - keycap.src and a fix for kbdio - -- changed installation instructions to reflect recent changes, removed - instructions for FreeBSD 1.0 and added instructions for FreeBSD 2.0 - -- upgraded all utilities version strings to 3.20 - -- new example of rc.local - -- changing timeout()/untimeout() function parameter type to TIMEOUT_FUNC_T - definition in pcvt_hdr.h - -- changed install instructions to reference Etc dir instead of Doc dir for - several files which were moved from Doc to Etc. - -- new parameter -d for the cursor utility, updated cursor manpage - -- applying a patch from Lon Willett, willett@math.utah.edu which fixes - several bugs and provides some enhancements. Lon writes: - - 1 -- The displayed cursor is not updated during kernel I/O, - because async_update() doesn't get called. This is merely ugly - while the system startup messages are being displayed, but it is - positively annoying when using the kernel debugger. - - 2 -- CONTROL-SHIFT- is taken to be the same as SHIFT-. - It should be interpretted as CONTROL-, or even have its own - binding. One of the lines below fixes it in the former way. - This is especially bad (i.e. clearly buggy) when I type - CONTROL-SHIFT-<6/^> to get a "Control-^", and instead get a "^". - - 3 -- The "special" region at the bottom of the screen, i.e. the - function-key-labels/status-line in HPVT mode, and the blank line - in FORCE24LINES mode, do not get properly cleared/updated. - - 4 -- When switching screen sizes/modes, the FORCE24LINES setting - is not always handled. - - 5 -- The PCVT_VT220KEYB functions are missing some features. - The control key settings are bug fixes; they apply only if - system function key labels are on, and match the labels. The - shift key definitions are enhancements. - - The new keys (previously undefined) are: - - Control-F1 -- toggle 80/132 columns - Control-F2 -- soft reset emulator - Control-F3 -- toggle force 24 lines mode - Control-F4 -- toggle keyboard debugging - - Shift-F1 -- select screen 4 - Shift-F2 -- select screen 5 - Shift-F3 -- select screen 6 - Shift-F4 -- select screen 7 - Shift-F5 -- select (current screen - 1) - - 6 -- [Enhancement] The initial startup screen is cleared, and - the screen gets cleared when changing modes/sizes. I don't like - this. I want a chance to see bootstrap loader messages, and I - also want the command "scon -d/dev/ttyv0 -H -s28" in my - rc.local, but then I lose various messages from daemons, etc - (which aren't always logged to syslog). So I have fixed the - code so that it tries to preserve the contents of the screen - when starting up, and when changing modes/sizes. - - 7 -- [Enhancement?] I added code to preserve the initial cursor - shape at startup. This isn't really necessary, since the - "cursor" command can be used to set it to your preference; but - it seems like this is the preferable policy to use for the - default. - -- applying patches from Onno van der Linden and Martin Husemann: adding - support for post 1.0 NetBSD-current and adding PCVT_NO_LED_UPDATE - -- patch from Joerg Wunsch: support for FreeBSD 2.0 and better support - for serial console coexistence - -- bugreport from Michael Havemester regarding PCVT_NOFASTSCROLL: it was - not enabled in pcvt_vtf.c, fixed. - -- renamed pcvt_disable_intr and pcvt_enable_intr to PCVT_DISABLE_INTR and - PCVT_ENABLE_INTR (Joerg) - -- attempt to automatically compile time configure in pcvt_conf.h, how - does FreeBSD do this ? should work for NetBSD (from Onno v.d. Linden) - -- split off pcvt_kbd.h from pcvt_kbd.c, file > 100k - -- split off pcvt_config.h from pcvt_hdr.h. All compile time configurations - should be put into pcvt_config.h now. - -- moved version definitions to begin of file in pcvt_ioctl.h and pcvt_hdr.h - -- fixing NetBSD #ifdef in pcvt_drv.c - -- fixed bug in scon. when doing "scon -c " the destination screen was - cleared, this is fixed now by properly setting "force_24lines" - -- added kbdio utility from Joerg into Util directory - -- changed font dir from /usr/share/misc/vgafonts to /usr/share/misc/pcvtfonts - -- Fix for Gateway 2000 keyboard problems from Brian Moore - -- Starting to implement more keymoard mapping layers in pcvt_kbd.c. This - section is a building site, enclosed in NOT_YET_DEF ifdef's - -- VT_SETMODE ioctl patch from John Kohl , see text - from John in the source file pcvt_ext.c - -- patch from Joerg for kbd_emulate_pc(), intro of timeout - -- fixed bug in soft/hard reset and real system fkey labels - -- added patch from Joerg for FreeBSD 1.1.5.1R - -- fixed both SR and SF entries in termcap database file - -- removed SR entry in termcap database file (bugreport from John Perry) - -- bugfix in cirrus 132 column switching got from Onno/Charles - -- french keycap database entry from Matthieu Herrb - -- cleanup patch from Joerg for Util/demo/Makefile und Util/fonts/Makefile - - -Changes 3.00 -> 3.10 June 1994 --------------------------------------------------------------------------------- - -- patch from Joerg correcting my assumed timeout/untimeout FreeBSD casts - -- adjusted some #if's while validating NetBSD 0.9 and NetBSD-current - -- rolled in Joerg's changes for a pre-1.1.5 (?) FreeBSD-current - -- Util/fonts: install only the necessary fontfiles, vt100 not used anymore - -- updated and commented Etc/rc.local and updated to more recent /etc/ttys files - -- updated all installation instructions and changed their names - -- documenting more PCVT_ options in pcvt_hdr.h - -- adding CONF_ options to driver config ioctl and upgrading ispcvt - -- commenting the source, housekeeping, step up to 3.10 beta 2 - -- casting timeout()/untimeout() for FreeBSD 1.1R :-( - -- unprotecting vgapage() routine with #if !PCVT_KBD_FIFO - -- adding Michael Havemester's keyboard fifo diffs to source tree - -- pcvt_drv.c: made declaration of Crtat global for this file for NetBSD - -- changing Util/fonts/Makefile and Util/demo/Makefile to run in all - supported environments - -- moving inline from pcvt_vtf.h into pcvt_hdr.h, i still feel that this is - not the best solution, but i got annoyed by the 10 line pcvt_vtf.h - -- bugfix, in hpmode, clear last 4 lines when 28 column mode and force - 24 lines are true - -- applying patch from Thomas Gellekum : - - discard escape sequences ESC space F and ESC space G - - discard escape sequences DECELR = enable locator report - and DECSLE = select type of locator event - - disable scrolling when writing outside the scrolling region - at an absolute position. - - [ pcvt now seems to be "VAX resistant" :-) ] - -- optional switch to screen 0 can be done on kernel/console output - -- fixed kernel output cursor positioning - -- removed PCVT_FORCE8BIT - -- pcvt_ext.c, changed screen switching bcopyb's to bcopy's - -- new patch from Onno to support all BIOS versions of the Cirrus chipset. - -- pcvt_x_hook() has to care about fkey labels now - -- updated Doc/NotesAndHints and Doc/BugList - -- applied patch from Onno van der Linden for updated Cirrus chipset support - -- updated Doc/Bibliography - -- removed paranoid delay()/DELAY() from vga_test() - -- added prototype ttrstrt() into pcvt_drv.c for NetBSD 0.9 - -- made INSTALLATION.NetBSD and INSTALLATION.NetBSD.bundled from mycrofts base - -- Charles Hannum took Michael Havemesters speedup modifications, made some - further enhancements and after adding support for pcvt, put it into - the NetBSD-current tree. THANK YOU, Charles ! - The NetBSD version of May 20th '94 was taken as the base for 3.10. - - -Changes 2.20 -> 3.00 March 1994 --------------------------------------------------------------------------------- - -- Release 3.00 - -- last minute patch from Joerg (pcvt_hdr.h, BugList, NotesAndHints) - -- included speedup patch from Michael Havemester as Etc/LAST-MINUTE - -- updated Doc/pcvt.4 - -- removed bug in Util/ispcvt/Makefile which caused ispcvt to be installed - into /usr/sbin and /usr/local/bin - -- split ioctl VGAPCVTID into two: intro of ioctl VGAPCVTINFO for compile - time options only. - VGAPCVTID is now frozen for identification purposes (XFree86 3.0) - updated Util/ispcvt for the above mentioned changes - -- issued patch to upgrade beta14 to beta16 - -- bugfix: when scrolling up (bcopy) is interrupted by a keystroke requesting - a change of the current screen, the "new" screen is scrolled up. Fixed - in pcvt_kbd.c and pcvt_out.c (check_scroll) - -- fixed bug "Jumping through vt's with ALT-F12 does jump over vt0" - -- PCVT_PCBURST intro, update of ioctl and Util/ispcvt - -- NetBSD speedup patch from Michael Havemester (factor 6-10) - -- issued patch to upgrade beta14 to beta15 (never officially announced) - -- added patch for ttioctl parameters NetBSD-current 12 Feb 94 from Michael - Havemester in pcvt_drv.c - -- INSTALLATION.xxx(x)BSD upgraded to reflect changes in Util and NetBSD-current - -- struct pcvtid changed to hold the value of PCVT_xxx(x)BSD, ispcvt upgraded - -- applied patch from Szabolcs Szigeti for 132 column operation for Trident - TVGA 8900B and TVGA8900C based boards - -- PCVT_NETBSD can/must now be 1 or 09 for Release 0.9 and > 09 for current - -- applied patches from John Brezak and Szabolcs Szigeti for recent - NetBSD-current changes (syscframe -> trapframe) - -- in Util, removed Makefile.inc. Make Makefile.inc.FreeBSD and - Makefile.inc.NetBSD and added a check to the toplevel and every - other Makefile in this part of the tree. sigh ... - -- patch from Joerg for pcvt.4 Makefile and Debugger in FreeBSD - -- issued pcvt-beta14, code freeze for 3.00 release, just bugfixes now - -- INSTALLATION.FreeBSD and a small cleanup patch from Joerg - -- large patch from Joerg to get pcvt FreeBSD-current compliant - -- permission/owner cleanup, files:664, dirs:775, user:root, group:wheel - -- got rid of the verbose error message when installing in Util/fonts - -- new make-method in Util/kcon to workaround make portability problems - -- NetBSD-current detection workaroundaroundaround for NEW_AVERRUNNABLE in - pcvt_header.h - -- MONO_BUF and COLOR_BUF now ifndef'ed - -- fixed typo in pcvt_kbd.h in cfkey11() and cfkey12() - -- machine/pio.h must be included in pcvt_hdr.h for recent NetBSD-current - -- protected every tsleep call with an "if(curproc)" otherwise there is - chance to panic the system (Joerg has an idea why ...) - -- more fixes from Joerg: keyboard scansets fixed, X server is now aware - of redefined keys (ioctl implemented) - -- patch from Heiko Rupp, configuration with XSERVER not defined didn't compile - -- new version of vgaio from Joerg installed - -- large keyboard cleanup patch from Joerg merged in - -- bugfixes from Joerg: fix crash on not-open vt, remove pcxint, add option - PCVT_INHIBIT_NUMLOCK (for notebook owners :-), support for EGA/VGA - fonts with up to 32 scanlines. - -- included vgaio, a program to read/write vga register values from Joerg. - -- included mcon, the keyboard mouse emulator control program from Joerg. - -- applied averrunnable patch to satisfy the most recent NetBSD-current. - -- fixing cursor not updated bug if usl/vt server is running on vt0 - -- polished some chars in Util/fonts/vt220l.810, fixed all permissions in - the uuencoded fontfiles. - -- debugged the EGA/VGA curses based font editor 'fed' in Util/fed. It seems - it's working ok now now. - -- updated copyright header files - -- synchronize asynchronous cursor position update with having a valid - (new) cursor (row) position from sputc(). (Otherwise a cursor - would appear temporarily in the first position of the first - function key label in the HP mode) - -- updated screeninfo ioctl and scon to report the monitor type - -- added file Doc/Notes for random notes and hints for pcvt-users. - -- enhanced the pcvtid-ioctl and the ispcvt(8) utility to print out the - values of all "PCVT_XXXXXX" compile time options. - -- included work from Joerg to convert all ifdef's to if's, to be able - to compile various configurations of pcvt without changing - options in the header file. - -- included (currently untested !) patch for a keyboard mouse emulator - from Joerg. (he got problems after he bought a notebook with - just one serial port, which he wanted to use for slip ...) - -- screensaver reset is now also done asynchronously to get more speed. the - function average() was renamed to async_update(). - -- cursor position update and cursor position display in HP mode is now done - asynchronously in function average() in pcvt_sup.c. the function - update_cursor does no longer exist. this gave about 10..30% increase - in speed depending on the data cat'ed (termcap, kernel, 1Mb nulls) - -- HP function key emulation processing debugged, this has to be rewritten - to use a stack and a new parser. elm -K now works a bit more, the - display is not garbled anymore, but fkey strings do not work. - -- pcvt_vtf.c split off from pcvt_out.c, file got > 100k. Checked all - forward declarations in header and source files - -- 132 column support for Cirrus Logic CL-GD542X chipsets written by - Onno van der Linden, c/o vdlinden@fwi.uva.nl - -- keyboard scancode display (#define PCVT_SHOWKEYS) - -- printscreen keycode fix form Onno van der Linden - -- Util/Makefile.inc added .depend dependency for make depend - -- pcvt_ioctl.h is now installed into /usr/include/machine. - -- keyboard scancode 1 is now used by default, perhaps it cures some problems - -- support for keyboard scancodes sets 1 and 2 (compile time selectable via - PCVT_SCANSET), patch from Onno van der Linden, c/o vdlinden@fwi.uva.nl - -- Util/fontedit.c updated to "#if defined (__386BSD__) || defined (__NetBSD__)" - (suggested by Mark Weaver, Mark_Weaver@brown.edu) - -- 132 column support for S3 86c928 chipsets - -- split off pcvt_ext.c from pcvt_sup.c, it was more than 100k .... - -- intro of Doc/Manifest and Doc/TestedHardware, removed README.X-PATCH because - it was now really outdated - -- superprobe compatibility patches from Joerg - -- intro of file Doc/BugList - -- another powerpatch from Joerg: - - some vgaioctl's are now available if in X mode (i.e. to scon to - another screen from within an xterm) - - removed bug in keyboardhandling, numlock'ed numkeys did send an - additional null (0x00) char, this has been fixed now. - - SysRq key made functional - -- made force 24 lines (see below) the default configuration to have a well - behaving vt220 emulator at startup. - -- every vt now has a separate caps-lock, num-lock and scroll-lock flag and - a separate handling of these lock-keys. - -- made sleeping in case of scroll lock working from an earlier patch from Joerg. - -- large patch from Joerg: - - Doc/pcvt.4 updated to reflect recent changes - - struct winsize set ok when switching between HP/VT - - struct winsize pixels reflect real values now - - ioctl for switching between 80 and 132 cols - - 132 columns for generic VGA's - - updated scon to provide access to ioctl 80/132 col switching - -- removed pcconcoftc and kbdsoftc structures from header files, removed - pcconsintr variable and introduced kbd polling synchronization - variable kbd_polling. - -- merging Joerg's patch to support 132 columns on Tseng Labs ET3000 - -- moved Util/uemacs/* --> Etc/uemacs.tar.Z.uu - -- added patches from Joerg for new Makefiles in Util - -- added keyboard security define's to the new X server code - -- adding bugfixes from Joerg Wunsch for "old" (= non vt switching) X server - -- Control-Alt-Functionkey(1...12) switches now virtual screens/terminals to - behave consistently with xfree 2.0, also the pages are now checked - against the real no. of terminals available ALL the time ... - -- pcvt_hdr.h: changed "int pcstart();" to "void pcstart();" to avoid warning - message when compiling under NetBSD-current - -- Doc dir split into Doc and Etc, Support renamed to Util - -- adding NetBSD-current support for new X server support (syscframe changed - to trapframe in NetBSD-current as of 11/11/93) - -- adding Joergs changes for XFree86 2.0 multiple X server and/or terminal - session support - -- adding entries from patchkit 0.2.4 codrv keymap to Support/keycap/keycap.src - -- Keyboard security introduced into the XSERVER dependent part in pcvt_drv.c - -- renamed device files from /dev/ttycXX to /dev/ttyvXX - -- added file Doc/pcvt.el from Joerg Wunsch to distribution - -- added HP-mode function key map from Gordon L. Burditt to description - in Doc/Keyboard.HP - -- fixed bug in scon which prevents it from showing the correct status of - 132 column support of chipset - -- 132 column mode for Trident TVGA9000 works now, after 2 1/5 months of - calling everybody i eventually got a tech ref manual from Trident .... - -- it is now possible to "force" pcvt into a 24 line mode when operating - in pure VT mode with 25 lines or in HP mode with 28 lines. This - is sometimes necessary when running software which assumes it runs - on a "real" VT220 which has just 24 lines. - -- updated scon to support the 24 lines force mode (scon -f [ on | off ]) - -- soft reset fkey now positions cursor into left upper corner, update_cursor() - made global function - -- updated scon (-l) to print out additional info about the vga chipset, - family and 132 column support if VGA detected. - -- added additional fields to screeninfo structure in pcvt_ioctl.h to be - able to return information about current vga chipset. - -- moved VGA type/family definitions from pcvt_hdr.h to pcvt_ioctl.h - -- Terminfo and Termcap updated to support 132 columns - -- fixed bug in kcon which outputs garbage for remapped keys in kcon -l. - (reported by Gordon L. Burditt, gordon@sneaky.lonestar.org) - -- modified Makefile for Support/ispcvt to copy it for installation instead - of moving it .. - -- renamed /usr/share/misc/keycap -> /usr/share/misc/keycap.pcvt to - avoid nameclash with same file for codrv (Gordon Burditt) - -- security bit no longer ignored when initializing keyboard (see #define - PCVT_USEKBDSEC in pcvt_hdr.h, suggested by Terry Lambert) - -- cpufunc.h include made only for NetBSD (Gordon Burditt) - -- switch statement in pcvt_drv.c removed for 386BSD (Gordon Burditt) - -- Trident cursor size bug removed - -- keyboard initialization for ddb - -- added support for cursor on/of switching, screensaver and DECTCEM - -- removed explicit Hercules support, MDA = Hercules in this context now - -- patchkit from Joerg Wunsch (kbd-overlay malloc, scroll_sleep, clip fix) - -- ispcvt now installed into /usr/sbin - -- removed PCVT_NETBSD08 and PCVT_NETBSDCU, intro of PCVT_NETBSD - -- implemented 132 column operation for wd90c11 chipsets - -- PCVT_PREPATCH022 renamed to PCVT_NEEDPG - -- INSTALLATION.NetBSD written - -- DEVICE in kcon makefile changed from /dev/console to /dev/ttyc0 - -- new keyboard code in pcvt_kbd.c from NetBSD current - -- new /etc/rc.local script in INSTALLATION - -- implemented 132 column operation for et4000 chipsets - -- detection of super vga chipsets as a prerequisite for 132 col mode - -- switched to memory mapped virtual screen operation, configurable no. of - virtual screens, virtual screens now also on MDA and Hercules boards - - -Changes 2.10 -> 2.20 June 1993 --------------------------------------------------------------------------------- - -- added new option -a to scon to get the video adaptor in scripts - -- support for NetBSD-current, define PCVT_NETBSDCU to enable it - -- Support for NetBSD 0.8, define PCVT_NETBSD08 in pcvt_hdr.h to enable it. - -- Change Support/Makefile to use instead of - -- Font editor for the EGA/VGA font-files added to support the design of new - fonts. One will need Zeyd M. Ben-Halim's ncurses library to compile it, see - file README.FIRST for information where to get it - -- Doc/INSTALLATION upgraded - -- Terminfo entry added to support Zeyd M. Ben-Halim's ncurses port - -- ispcvt is now installed in /sbin to have it at boottime if /usr is not - yet mounted. - -- applied a patch which prevents CAPS LOCK, SHIFT LOCK, and SCROLL LOCK - from being repeated (causing i.e a flashing CAPS LOCK led while - holding CAPS LOCK key down). - (diff from Gordon L. Burditt, gordon@sneaky.lonestar.org) - -- merging patches to support the pccons-model of X11 server support - (diff from Joerg Wunsch, joerg_wunsch@uriah.sax.de) - -- file pcvt_drv.c routine pg() enclosed in "#ifdef PCVT_PREPATCH022" to solve - multiple defined symbols beginning with patchkit 0.2.2 - (reported by Marko Karppinen, dreamer@purkki.apu.fi) - -- added british keycap entry into keycap source file - (from Andy Duplain, duplain@rtf.bt.co.uk) - - -Changes 2.00 -> 2.10 March 1993 --------------------------------------------------------------------------------- - -- detecting the presence of video boards has been changed to ask the - BIOS "equipment byte" in the RTC-CMOS ram what's installed. this caused - many discussions but solved also many problems .... - -- driver name changed from "pc" to "vt" for multiple driver coexistence - (diff from Joerg Wunsch, joerg_wunsch@uriah.sax.de) - -- new devicenames recommended for showup in utils like "ps" - (many people suggested that ..) - -- new location for manual pcvt.0 - (diff from Joerg Wunsch, joerg_wunsch@uriah.sax.de) - -- new demo file "sgr.vt" to show available graphic renditions - -- intro of Doc/ChangeLog (this file) - -- fixed bug in Support/keycap/Makefile - (diff from Gordon L. Burditt, gordon@sneaky.lonestar.org) - -- make vttest (main.c) compile after applying patchkit-beta2 - -- screensaver fixed by Joerg Wunsch - -- screensaver now compiled in by default - -- made recognition of CONTROL-ALT-DELETE an optional #ifdef'ed feature - -- added sgr-conversion table for MDA adaptors - -- fixed sgr-conversion table for VGA monochrome environments - -- added support for using the kernel debugger - (diff from Bruce Evans, bde@runx.oz.au) - -- fixed several bugs regarding monochrome environments in pcvt_sup.c - -- fixed bug in scon preventing one from piping output though more - (reported by Gordon L. Burditt, gordon@sneaky.lonestar.org) - -- display current screen number in HP-mode in the bottom right of screen - -- changed names of all #define-able compile time options to start with - "PCVT_" for easy identification and installation into the kernel config file - -- applied another pcvt_kbd.c patchkit from Bruce Evans, bde@runx.oz.au. he - writes: - - These fixes are mainly related to ddb. sgetc has a weird interface that - has caused some bugs, and it was too easy for ddb to reenter itself. - - 1. Don't use char for keypad2num, char might be unsigned. Space is not - important since the array is small. - - 2. Don't use u_short for n. - - 3. Change some 0's to NULLs. - - 4. sgetc must not return NULL for the !noblock case. Only callers with - noblock set check for the null pointer. When the kernel follows a - null pointer, I think page 0 is sometimes mapped in so nothing bad - happens. The kernel panics if the page is not mapped in. - - 5. Reentrancy fix. The debugger really ought to check for reentrancy - itself, but the driver still needs to return early after the - debugger returns, so that it doesn't return a junk ESC from - ctrl-alt-ESC. - - 6. xlatkey2ascii may return NULL too. - --------------------------------------------------------------------------------- diff --git a/sys/arch/i386/isa/pcvt/Doc/CharGen b/sys/arch/i386/isa/pcvt/Doc/CharGen deleted file mode 100644 index c047bfacca0b..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/CharGen +++ /dev/null @@ -1,149 +0,0 @@ -Character Generator description (before it gets lost ..) --------------------------------------------------------------------------------- - -The lower character generator is the default IBM character set II. - -The description of the higher character generator follows below. The -character names are taken from the "Postscript Language Reference -Manual", 2nd Edition, Fourth printing July 1991, pp 596. - -NOTE: The hex values here are NOT the values the character is identified - by in the emulator. The "physical" (vt220 character) to "logical" - (this table, character generator) conversion is done in the character - output routine by using the tables from file pcvt_tbl.h. - -The order of the characters is not regular and was largely influenced by -the status of my brain while pixel-placing characters .... - -HEX What ---- ------------------------------------------------- -00 Control code display for -. control characters in the -1f range 0x00 - 0x1f - -20 Control code display for -. control characters in the -3f range 0x80 - 0x9f - -HEX What ---- ------------------------------------------------- -40 rho -41 psi -42 partialdiff -43 lambda -44 iota -45 eta -46 epsilon -47 chi -48 logicaland -49 logicalor -4a union -4b propersuperset -4c propersubset -4d gamma -4e Xi -4f Psi - -HEX What ---- ------------------------------------------------- -50 Pi -51 arrowdblright -52 arrowdblboth -53 Lambda -54 Theta -55 congruent -56 gradient -57 Delta -58 proportional -59 therefore -5a integral -5b fraction -5c (inverted fraction ????) -5d angle -5e (inverted angle ????) -5f braceleftmid - -HEX What ---- ------------------------------------------------- -60 bracerightmid -61 bracelefttp -62 braceleftbt -63 bracerighttp -64 bracerightbt -65 radical -66 omega -67 (Yen ??) -68 xi -69 yacute -6a thorn -6b eth -6c Thorn -6d Yacute -6e multiply -6f Eth - -HEX What ---- ------------------------------------------------- -70 threequarters -71 Cedillasmall -72 Acutesmall -73 emdash -74 registered -75 endash -76 logicalnot -77 dieresis -78 notequal -79 scan 9 -7a scan 7 -7b scan 5 -7c scan 3 -7d scan 1 -7e upsilon -7f emptyset - -HEX What ---- ------------------------------------------------- -80 oe -81 Otilde -82 atilde -83 Ydieresis -84 Ucircumflex -85 Uacute -86 Ugrave -87 Oslash -88 OE -89 Otilde -8a Ocircumflex -8b Oacute -8c Ograve -8d Idieresis -8e Icircumflex -8f Iacute - -HEX What ---- ------------------------------------------------- -90 Igrave -91 Edieresis -92 Ecircumflex -93 Egrave -94 Atilde -95 Acircumflex -96 Aacute -97 Agrave -98 onesuperior -99 (small black rectangle) -9a zeta -9b threesuperior -9c copyright -9d currency -9e kappa -9f (inverted question mark) - -HEX What ---- ------------------------------------------------- -a0 the remaining positions -. are used for the vt220 -ff downloadable characterset - -------------------------------------------------------------------------------- - (phoooo ..) diff --git a/sys/arch/i386/isa/pcvt/Doc/Charsets b/sys/arch/i386/isa/pcvt/Doc/Charsets deleted file mode 100644 index b30dd8a44a87..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/Charsets +++ /dev/null @@ -1,99 +0,0 @@ - -I. Character Set Selection on VT220 Terminals -================================================== - - -name C0 GL C1 GR - +---+ +-------------------+ +---+ +-------------------+ - |00h| | | |80h| | | -range | | | | 20h .. 7fh | | | | | a0h .. ffh | - |1fh| | | |9fh| | | - +---+ +-------------------+ +---+ +-------------------+ -length 32 96 32 96 - - /\ -SECOND /||\ "lock"- or "single"-shift one set of G0, G1, G2 or -STEP || G3 into one of the "displayable" charactersets GL - || or GR. (escape) sequences are: SI, SO, ESC ~, ESC n, - || ESC }, ESC o, ESC |, ESC N and ESC O. - - +----+ +----+ +----+ +----+ -name | G0 | | G1 | | G2 | | G3 | -length |(96)| |(96)| |(96)| |(96)| - +----+ +----+ +----+ +----+ - - /\ - /||\ designate a hard or a soft character set as - || one of G0, G1, G2 or G3, used escape sequences -FIRST || are, ESC ( X, ESC ) X, ESC * X and ESC + X - where X is -STEP || B for ascii, < for supplemental, 0 for special, A for - || british, 4 for dutch, C and 5 for finnish etc. etc. ... - || - - +-----+ +------------+ +--------+ +-----------+ +------------+ -name |ascii| |supplemental| |special | | national | |downloadable| - | | | graphics | |graphics| |replacement| |characterset| -length | (96)| | (96)| | (96)| | (96)| | (96)| - +-----+ +------------+ +--------+ +-----------+ +------------+ - - \-------\ /----------/ norway/danish - | dutch - together, this is also finnish - referred to as the french - multinational character french canada - set (power on default german - on a dec vt220) italian - spanish - swedish - swiss - - -II. Emulating Character Set Selection -========================================= - -MDA/HCG/CGA: - - just a partial emulation is done, because these boards don't allow - downloadable charactersets. some characters simply don't display - because they are not in the characterset roms on the video board. - - if you want to change the mapping, have a look at the default tables - in pcvt_tbl.h. - -EGA/VGA: - - these cards have provisions for downloadable charactersets and so - many vt220/vt320 charactersets are fully supported: - - - US Ascii - - DEC Supplemental - - DEC Special Graphic - - DEC Technical - - ISO Latin-1 - - Downloadable - - when the emulator is started, it behaves initially similar to - the MDA/CGA/HCG method described above. - - when a second (special) characterset for a given screen resolution - is loaded via the "loadfont" utility, the emulator detects this fact - and uses from then on extended tables to access the second charset - as an upper half 512 characterset in terms of ega/vga speak. - - from this time on, vt220 downloadable fonts are usable. - - the organization of this extended characterset is as follows: - - 0x00 ... 0x1f C0 display function fonts - 0x20 ... 0x3f C1 display function fonts - 0x40 ... 0x9f fonts for DEC Supplemental, DEC Special - Graphic, DEC Technical and ISO Latin-1 - 0xa0 ... 0xff VT220 Downloadable Font - - the mapping between vt220 charactersets and the charactersets inside - the ega/vga is done by tables found in the file pcvt_tbl.h. - - there is a MSDOS fonteditor called "EVAFONT" available on the - SIMTEL-20 archive, which i used to edit the character sets in the - distribution. - diff --git a/sys/arch/i386/isa/pcvt/Doc/EscapeSequences b/sys/arch/i386/isa/pcvt/Doc/EscapeSequences deleted file mode 100644 index 8e0e2c77e6d7..000000000000 --- a/sys/arch/i386/isa/pcvt/Doc/EscapeSequences +++ /dev/null @@ -1,268 +0,0 @@ - Control Codes and Escape Sequences supported by pcvt -=============================================================================== - -CONTROL CODES -------------------------------------------------------------------------------- - - NUL (0x00) ignored - SOH (0x01) ignored - STX (0x02) ignored - ETX (0x03) ignored - EOT (0x04) ignored - ENQ (0x05) ignored - ACK (0x06) ignored - - BEL (0x07) beep - - BS (0x08) move one character position to the left - until at left margin - - HT (0x09) move to next tab stop - - LF (0x0a) move to next line, same column - VT (0x0b) move to next line, same column - FF (0x0c) move to next line, same column - - CR (0x0d) move to left margin on current column - - SO (0x0e) invoke character set G1 into GL - SI (0x0f) invoke character set G0 into GL - - DLE (0x10) ignored - DC1 (0x11) ignored - DC2 (0x12) ignored - DC3 (0x13) ignored - DC4 (0x14) ignored - NAK (0x15) ignored - SYN (0x16) ignored - ETB (0x17) ignored - - CAN (0x18) abort current escape sequence - - EM (0x19) ignored - - SUB (0x1a) abort current escape sequence - - ESC (0x1b) start of escape sequence - - FS (0x1c) ignored - GS (0x1d) ignored - RS (0x1e) ignored - US (0x1f) ignored - - VT220 control codes in the range 0x80 .. 0x9f are completely ignored, - but displayed as C1 display controls. - - -ESCAPE SEQUENCES DIGITAL EQUIPMENT -------------------------------------------------------------------------------- - -(ni) = not implemented yet, all hooks available inside emulator! -

= numeric parameter - - ESC space F select 7-bit c1 control transmission (ni) - ESC space G select 8-bit c1 control transmission (ni) - - ESC # 3 double height top half (ni) - ESC # 4 double height bottom half (ni) - ESC # 5 single width single height (ni) - ESC # 6 double width single height (ni) - - ESC # 8 fill screen with 'E's - - ESC 7 save cursor - - ESC 8 restore cursor - - ESC = keypad application mode - - ESC > keypad numeric mode - - ESC D index - - ESC E next line - - ESC H set tab at cur col - - ESC M reverse index - - ESC N single shift G2 - - ESC O single shift G3 - - ESC Z who are you - - ESC d Only available if PCVT_SETCOLOR was defined when - compiling the kernel, allows to set custom color table - for more info, see pcvt_out.c ... - - ESC c power up reset - - ESC n Lock Shift G2 -> GL - - ESC o Lock Shift G3 -> GL - - ESC } Lock Shift G2 -> GR - - ESC | Lock Shift G3 -> GR - - ESC ~ Lock Shift G1 -> GR - - ESC [ ?

h set dec private modes - ESC [ ?

l reset dec private modes - 1 CKM - cursor key mode - 6 OM - origin mode - 7 AWM - auto wrap mode - - ESC [

' z DECELR - Enable Locator Report (ni) - - ESC [

' { DECSLE - Select type of locator events (ni) - - ESC [ ? n Terminal Reports - - ESC [ ? K selective erase in line - - ESC [ ? J selective erase in display - - ESC [

@ insert char(s) - - ESC [

A cursor up - - ESC [

B cursor down - - ESC [

C cursor forward - - ESC [

D cursor backward - - ESC [

H cursor direct cursor addressing - - ESC [

J erase screen - - ESC [

K erase line - - ESC [

L insert line - - ESC [

M delete line - - ESC [

P delete char - - ESC [

S scroll up - - ESC [

T scroll down - - ESC [

X erase character - - ESC [

c device attributes - - ESC [

f direct cursor addressing - - ESC [

g clear tabs - - ESC [

h set mode - ESC [

l reset mode - 4 IRM - insert replacement mode - 20 LNM - line feed / newline mode - - ESC [

i media copy (ni) - - ESC [

m select graphic rendition - 0 reset to normal attributes - 1 bold - 4 underline - 5 blinking - 7 reverse - 22 bold off - 24 underline off - 25 blinking off - 27 reverse off - 30-37 foreground colors (on color display) - 40-47 background colors (on color display) - - ESC [

n device status report - - ESC [

r set scrolling region - - ESC [

x request / report terminal parameters - - ESC [

y invoke selftests (ni) - - - ESC [ x request/report parameters - ESC [ y invoke seftest(s) - - ESC [ " q SCA - ESC [ ! p SCA - - ESC (

designate G0 - ESC )

designate G1 - ESC *

designate G2 - ESC +

designate G3 - ESC -

designate G1 (96) - ESC .

designate G2 (96) - ESC /

designate G3 (96) - A British or ISO-Latin-1 - B USASCII - C Finnish - 5 Finnish - E Norwegian/Danish - 6 Norwegian/Danish - H Swedish - 7 Swedish - K German - Q French Canadien - R French - Y Italian - Z Spanish - 0 special graphics - 1 alternate ROM - 2 alt ROM, spec graphics - 3 HP Roman 8, upper 128 chars*/ - 4 Dutch - < DEC Supplemental - = Swiss - > DEC Technical - - -ESCAPE SEQUENCES HEWLETT-PACKARD -------------------------------------------------------------------------------- - -ESC&fakdL

.X?9WV1-`4OEM>7D/KERA^,K/I!EFJ@,]BTB08_-,44'X7/9\D][L8`FE -M?(+NA)1GZBZ!JT#*WHOFFW&5W3+B'N5"[&R_(.S[DZH8RD+ -MZ(1X(2E%EQD`,\NRT*FP.R28W)<7K5H(.Q^@,;`F2R>B3&@IK!'='//5D%;M -M`#(Q9]R*1OD,),>$BV9H>BO(2&)-6@-)84&T!F@&BUG:JWNI1UY.4@KD-5)6 -M7B*Q\*1Y+BAT^!KY][=ETFMD:X(+K8D`()*WT"T)HC/*_341RTE!-;Y"5G57 -M)DDPKW,01U[DK%"B@Q@T5GJQO"0.`Y!C_XJY*HJ&#V(4Q"AFG:$F:RFE2$1XLOR_K`$P6=%R'"NZTL]RO.*6!ZN@EZ+RIIGEG_# -MBM9[*5=S0E#MC@@O0=$E^":PE=D&F>7R0LZ_/2DW;2&VD?)%'^)Y(K -M4.YV$L*'`K=@=A&F2>N@C.*SD>2]8X8"R3IPHYJCANR_`'>)$@-AAN-^TM7_ -M*B^O!5/C4OE9J,TX`:N -M*/8>A$XLY<8R"[#&(8/NEK%IP*E&-%LDZ1/Y(BB5Y["3B&6EDR7/Q`H/][>&UR>IFR3.>5LXFA[W><9MB?:PB -M/Q:+U90T^\WB#XNK;G'UM\6W?UG\KEY<_4GY_%E?M -MFM%NN;B2N_WBJMY=+ZY6:U9W2T*(OJ?UFJXTBM@MS:NZ8/?++^9.OVQ*KWTI -M7=-6R^B&*@.UL<7?_C`GJ83!8VO:6'`+T+]VK36B?$U5;,M6T6AT[?'FJ2:\Z[=X?#V\/AO?Y3F3^-U.YP^'`X -MO)[;*E18)7.8UU:(\JXZN.OC86/_-__IUQK3?8^ZXJ/^H^V[3\,?7H?NTIVN -M.JV256AE_K`OSVSGT^[/KJ-67?63[18FNMK:R9INOJ^?UM[4IL=,Y0O7,\*6"M.U04B7MMU%P"*NF^ON -MPHY'8\;,4"R07A>UH:BZ<86Z-W2]C6&YM<$*T;58:S.B6!/%$KFVVWR*@BT4 -MG`6;2-`^F*JM=Z@J04U@FVYSF>`V$)=46R0HQCQJOZ'BH,&KK-E)C)*H+ -M1F0E@#$HD15&9(V<&L,18ZR7Q2J#L9C*8$]*(\EQF.-G-HC4!^O5U/B@K.5IZ'$J"TYL`KUT1+C -ML63`*I3'$N.Q1DZMHHA5UJ^3L(0YJP1&;5D#JU#O+##O+%:I50(EK\#(*]K4 -M*M&>\G]NK/2"/)Q<`F.V:%+[!.J>!>:>A0+VH606&)D%B#?$B7BC\?&&CI&3 -MD$]#8S07(.X0J+L6&*<%B#L$RFF!<5J`N$,PU#,ZX\PHTD!)C.8"1!P"==<< -MX[0`$8=`.A!D>YS#$NC#NWE_7A9IIJM -ME]\#<8SA'$0?'/7:'*,S!]$'1^G,,#IS$'WP^HGX-]EWSGOS&$9U!F(/-J!Z -M]:;7#F,U`[$'&["Z.O0`&*L9B#U8DP%(]V/&SK!6LS'17SM,$($P-<8,6HU) -M?7`((`1A`U)7V^V;D!;A&`*(01ADM:Y?V3R+QIGY328)@;$WCF'`(!!A?`3\ -MV@,[F#&QW4Z:@7"$L1',P<&X_3C#Z,U`4,(H!M,GXGS\'P-)BA&?@=B$U:>@ -M7_=4IQC5*8A4Z&H$MXMPAPB'$9^"N(6V([CE`&X6R#M(Y%!L9E`0N]#AS"`C -M53&_3T$,0^%TT+\J$E7=13C,X5,0T5`YA"-5A%LF0]XGB^HX]MB:0$%H0\5( -MY4?71LQB46QUH"#(H1RW/DV*46Q!H"#DH0RW'J;*W(8W67(H-J4H"(`HS8U[ -MLWOL@;#Y0T$<1.L\3C09FS@@&EKE\FV)I318*D)TM%IC4P@$1.U8/;^OQQ)+ -M(*^$2:-I%["EQR,\'O,4-J>4+*KH]A5LJ3#%T*`>!*^8-!H*@5CAJ?2+,"M; -M/Q=6F@4WK#Y= -MAK8)F3BC?S)YKJRV\<&5LMUN=+_NGZ3042+?/E+9I/*Z6Z[GB03)BGP:RD`A -MUS%1;!Z?WFSFGVN)906$W6*XAC!!EN2%R4@Z&G,9[&%Y:89)LZZZW`2C1NE_ -MM>9Y/([A<8/7:R/RT@*3%L`6F9>6F+1,;<&R_FJM\K`*@U7`I"8OW6#2#3"I -M3:3]RADQ6@RC30T[D?)7ZU7$7UR]U#\1?>70W4.\E;/)53"DJWO!N1.T/X%[ -M=>>6O*2T,:65=SK*+-@>(!%/6J>6O^$%(TV-"KXQD.M7)KX@*8R3D9ER`\2Z -MR[1$N6@G(STL=@\S!V7*Q5VQK.KCS?X!]!AF(.)&:ISP5RYP!,@IM,Q`IP*] -MCU#=`.)E@J(R*+V`?;#K#37T`1`I2I-!<0*;3\FPG1ISW(QP% -M3&WR^C2I/KGHK>D&$=0@TZ],"C\+W3X%W0)#-=%?9U#6F'2JAO'NIGTOC+/-;/(#8;<`*O:O'2+2;?`JE5> -M>H5)K[KQ-BMF]95Y")T#E!B599T:(_.LE1AK)4V-D7G62HRUDD5CQDE\98X) -M9/$P'DL.;,F356)DU2^DMN3)*C&R2@GF4!+FR3QQ)49<":(*F2>GQ,@I07PA -M\^24&#EE"R?-(-VNS/F:+"#&5PE""Y4GI\+(J4!DH?+D5!@Y%85#,LJ@*W,> -M*@N),5:!@$+E^:DP?BH01J@\/Q7&3Y4&#^.4N#)'UK*`&&45"!E4GJ8*HZD" -M@8+*TU1A-%4-C&4'66]E#A-F`3'F*A`6J#Q-%493!<*!)D_3!J-I4\-H!\UZ -M*W,$-`N-<;@!84&3IVN#T;4!84&3IVN#T;6!8<$XZZW,:=TL),;A!@0$C819 -M+"_<\[4Q]\8`7UVE2:E06[GHWU2V*_X<9+F5.2,=I**0H:63,3ST\&W,/(5Z -M;GEMS(W/3S4A./(WC;FI/I4SZ^7,>CFS7LZLES/KYSJR7,^OES'HY -MLU[.K/];G%F?7EWU(::XW_4_+-SK^UN'LAW1->PKPU; -MN";XM?0M..A7#^^J!-IAZI>J$2:Y/R*(Q_M$:8>IUP_O<+6*J<:)&8AZ^_W]O7E#O!Z1^_N]`WO7C\[K`+7KB]Z34]7001K"7 -M.?P4;S789T)$C@0MME^HQ3/&,0_SU6.7`WWFB.5T@X2'ND&]44!-I<-KHL?L -MZ&99'+T/'SY$0N1$39:%'`_W^Y17]X>C?L'D)]:T/FI/8E,L6_/Q%?JW+K>Y -MET?SL1;FMZO0=MN#K=%VYI&A3>(\$EO'W+A*C:[TT=9J=*T/MEJC7W58]LY5 -M-!_8\-'AF8]K^.`0E:G@,-VMJRQC91DKRUA9)I5%K"QB91$KBZ0RCY5YK,QC -M99Y49K$RBY59K,R2RC16IK$RC95I4KF.E>M8N8Z5ZU#9[M&7ILS\M@N**[#[ -MZZ5?.EV1W_93D\0RJY"M0H(P,6UX$!TZA*V_K>Q`[&>0.!028"!*A%^ZX-BA -M!`S:[_EW2Y+`DJ77>X`Z!/6QF[/&H#N-`JYF=E0V!0.&!U!35Z7U/#CH(M=( -M8JWOA]";H:/)4-.T,WEH+BJ:Z$7ZL?(8RZ`8Z85[*D.&HDMAUH6;C*YXV -MMN_0H.9#:".Q:17T:U/&^"R#WJ6ER_](=W*"`D8.N -M3`9KU6'D3V?JA<4]BV -M>#S:#[<1)H.ES3N>;6X+DS&Y=]=7S_6@NM.<=ZGBYW$!KD4=3H;.TA'F<5K? -MX)NI;5]H(NQT:SIZM9>^.X3B?Y'#J,,9IUVOA=,D%)_5B\QF#EZ3QOO),!NU -M#GV8OW>%37=!YON*;&;G\32N%=5=;$RS03/CQ5USK`OJF4^(,G[6N2A]Q?ZJN]'V:G8.%Q:FR(5IXL*U=!$T;+I4P43)(&5[;.,$ -M-U&_Z!2F=("VQ=`;&]-FU-/K>!\NY_-[[GGKQESSX=\4SC*T9?H$$$ZKYU5+ -M)N-]JAY)R'<1]7MXAI<-'GM#`-V866_[T*57RZF4[K^]6MS4OS#]Y90*L)&. -M:3?"T9[,?P<]@BT;G*S,KO22F)@:Z/>"P42NH4]2N85;A&>L$:$9S3W? -M?H53F9F,L!NBX]&U9^(Q.&CALP^Y/QVL8)W#X3"-9XP(O0"%_(FDQ&[L5;QUZGE]Y@-S,[-0F^L-O0=7V#?W*O@M -M=:^!WT'W"M"H@'GH8BP/XWW1!3[8X!7QBI6]?)(1HK)5V=J7S/OJO[,S74;8S>Y#.LCD@XG(D_@"3 -M39W8+%#??K@U2(;*?KHD/N=YGH&Z!T$Z@CUU!?L:YSA4=L$-9.WPZC-C$ -MF4U\]5:HQ`KS6:4D,<+=YQS-:3_CDW-D=_`).[(]^.2<33:I_LZU&AQ)<&&P -M"[_,%_GT(=GYA*(Y&&;3A]Y>=^,Z[L(/3*!-11)-+K[$U?BT)O%I3N+3FL2G -M.4EH<4-27]V3P;!R\R6>91[>C^3>1_4-)R_O;F^/#[\UG>_>=_6-Z,O\!P@' -MMEP`KEZ$?MWX->YS/4D8O4T8N,J^N.E[:O,EOB%R(6EX$[G\C%D^[=2<>HJ< -M@_K3TWI:VA82%A(6$A82%A(6$A82%A(6$A82%A(6$OY'DM!]+-E_+;Z1=D^> -M_/'KIV>][@N7,$.XOYZ>OK&UI3L!&DZ"FM.:T_,[-O=(R+IUZ/L'V!D=NEV=Q^6E[B7G: -MP.EG'&C+GZ&U#XW./QVS[9UE+F*FG6$>XKUXIEF7;_!\,PYI[DS3#31VAKG6 -M+?[^E/.:;K*EC7VVLYYP\O7MXVO3=-.O;VR\[)+))Z!N[$PS+2)/.Z52W.GF -M3HIZKA4IOP*>:TG*+W]E32IKTI/+Q*33ZBG'>9Y5Z93OG'!5.MMR4R90F4#D -M\P@]]00J\^2I1?0_<*(LKH[_'BDZ8?#F+U[\[=7;:NH)X.#;;OZ/[6TUZ328 -MGO^3$G]29MM>U`7S%S_<;K_;8P\6N9:+^48?[B -MO^]NWA4?^?7$E(:8F_=O"S$G(*;=[+Z:GI?VJQ7FKQZJ8OCJ_^]_;[0M")SA,53GX5)QN?/_CQ[?2,M%\Z-;^I"CFG -M(F?C0KH7^[>WOZ\F)ZO]+JKYW?[X<%N5MQ,4BOX*_&?C4A,O]O=G8J3];JWY -M[=NJL+.P\U>PNCR? -LK:O,4Y_?D[\>]SORP^WQS>WV]N?PK-K59 diff --git a/sys/arch/i386/isa/pcvt/Util/fed/edit.c b/sys/arch/i386/isa/pcvt/Util/fed/edit.c deleted file mode 100644 index c15a90ceb6d9..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fed/edit.c +++ /dev/null @@ -1,340 +0,0 @@ -/* - * Copyright (c) 1992, 1993, 1994 by Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis. - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPER ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * edit.c, 3.00, last edit-date: [Sun Jan 2 20:08:27 1994] - */ - -/*--------------------------------------------------------------------------- - * - * edit.c font editor edit character - * ------------------------------------------ - * - * written by Hellmuth Michaelis, hm@hcshh.hcs.de - * - * -hm first public release - * -hm some debugging & cleanup - * - *---------------------------------------------------------------------------*/ - -#include "fed.h" - -#define UP 0 -#define DOWN 1 - -static int pen; - -/*---------------------------------------------------------------------------* - * fill edit mode command window - *---------------------------------------------------------------------------*/ -void edit_mode(void) -{ - mvwprintw(cmd_win,1,1,"(W)hite "); - mvwprintw(cmd_win,2,1,"(Black "); - mvwprintw(cmd_win,3,1,"(I)nvert "); - mvwprintw(cmd_win,4,1,"(R)ow BLACK "); - mvwprintw(cmd_win,5,1,"(r)ow WHITE "); - mvwprintw(cmd_win,6,1,"(C)ol BLACK "); - mvwprintw(cmd_win,7,1,"(c)ol WHITE "); - mvwprintw(cmd_win,8,1,"(Q)uit/Save "); - - mvwprintw(cmd_win,9 ,1,"e(X)it/undo "); - mvwprintw(cmd_win,10,1,"Pen (U)p "); - mvwprintw(cmd_win,11,1,"Pen (D)own "); - mvwprintw(cmd_win,12,1," "); - mvwprintw(cmd_win,13,1,"(^P)rev Line"); - mvwprintw(cmd_win,14,1,"(^N)ext Line"); - mvwprintw(cmd_win,15,1,"(^F)orwd Col"); - mvwprintw(cmd_win,16,1,"(^B)ack Col"); - wrefresh(cmd_win); -} - -/*---------------------------------------------------------------------------* - * edit mode command loop - *---------------------------------------------------------------------------*/ -int edit(void) -{ - int c, r; - char l; - unsigned int k_ch; - - c = r = 0; - - pen = UP; - - for(;;) - { - if(pen == DOWN) - dis_cmd(" Edit Mode, the Pen is DOWN"); - else - dis_cmd(" Edit Mode, the Pen is UP"); - - l = ((mvwinch(ch_win,(r+1),(c+1))) & A_CHARTEXT); - wattron(ch_win,A_REVERSE); - mvwprintw(ch_win,(r+1),(c+1),"%c",l); - wattroff(ch_win,A_REVERSE); - wmove(ch_win,(r+1),(c+1)); - wrefresh(ch_win); - - k_ch = wgetch(ch_win); - - switch(k_ch) - { - case K_LEFT: - case KEY_LEFT: - if(c > 0) - { - normal_ch(r,c); - c--; - } - break; - - case K_DOWN: - case KEY_DOWN: - if(r < (ch_height-1)) - { - normal_ch(r,c); - r++; - } - break; - - case K_UP: - case KEY_UP: - if(r > 0) - { - normal_ch(r,c); - r--; - } - break; - - case K_RIGHT: - case KEY_RIGHT: - if(c < (ch_width-1)) - { - normal_ch(r,c); - c++; - } - break; - - case KEY_HOME: - normal_ch(r,c); - c = r = 0; - break; - - case KEY_LL: - normal_ch(r,c); - c = ch_width-1; - r = ch_height-1; - break; - - case 0x0c: - wrefresh(curscr); - break; - - case '\n': - case '\r': - case ' ' : - chg_pt(r,c); - break; - - case 'q': - pen = UP; - normal_ch(r,c); - wrefresh(ch_win); - return(1); - break; - - case 'x': - pen = UP; - normal_ch(r,c); - wrefresh(ch_win); - return(0); - break; - - case 'w': - case 'W': - setchr(WHITE); - break; - - case 'b': - case 'B': - setchr(BLACK); - break; - - case 'i': - case 'I': - invert(); - break; - - case 'r': - setrow(WHITE); - break; - - case 'R': - setrow(BLACK); - break; - - case 'c': - setcol(WHITE); - break; - - case 'C': - setcol(BLACK); - break; - - case 'u': - case 'U': - pen = UP; - break; - - case 'd': - case 'D': - pen = DOWN; - break; - - default: - beep(); - break; - - } - } -} - -/*---------------------------------------------------------------------------* - * - *---------------------------------------------------------------------------*/ -void normal_ch(int r, int c) -{ - char l = ((mvwinch(ch_win,(r+1),(c+1))) & A_CHARTEXT); - wattroff(ch_win,A_REVERSE); - if(pen == DOWN) - mvwprintw(ch_win,(r+1),(c+1),"*"); - else - mvwprintw(ch_win,(r+1),(c+1),"%c",l); - wmove(ch_win,(r+1),(c+1)); -} - -/*---------------------------------------------------------------------------* - * - *---------------------------------------------------------------------------*/ -void chg_pt(int r, int c) -{ - char l; - l = ((mvwinch(ch_win,(r+1),(c+1))) & A_CHARTEXT); - if(l == WHITE) - l = BLACK; - else - l = WHITE; - mvwprintw(ch_win,(r+1),(c+1),"%c",l); - wmove(ch_win,(r+1),(c+1)); -} - -/*---------------------------------------------------------------------------* - * invert current character - *---------------------------------------------------------------------------*/ -void invert(void) -{ - int r,c; - - r = 1; - - while(r <= ch_height) - { - c = 1; - while(c <= ch_width) - { - if(WHITE == mvwinch(ch_win, r, c)) - mvwaddch(ch_win, r, c, BLACK); - else - mvwaddch(ch_win, r, c, WHITE); - c++; - } - r++; - } -} - -/*---------------------------------------------------------------------------* - * fill current character black/white - *---------------------------------------------------------------------------*/ -void setchr(char type) -{ - int r,c; - - r = 1; - - while(r <= ch_height) - { - c = 1; - while(c <= ch_width) - { - mvwaddch(ch_win, r, c, type); - c++; - } - r++; - } -} - -/*---------------------------------------------------------------------------* - * set current row to black/white - *---------------------------------------------------------------------------*/ -void setrow(char type) -{ - int r,c; - - getyx(ch_win,r,c); - - c = 1; - - while(c <= ch_width) - { - mvwaddch(ch_win, r, c, type); - c++; - } -} - -/*---------------------------------------------------------------------------* - * set current column to black/white - *---------------------------------------------------------------------------*/ -void setcol(char type) -{ - int r,c; - - getyx(ch_win,r,c); - - r = 1; - - while(r <= ch_height) - { - mvwaddch(ch_win, r, c, type); - r++; - } -} - -/*---------------------------------- E O F ----------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/Util/fed/fed.c b/sys/arch/i386/isa/pcvt/Util/fed/fed.c deleted file mode 100644 index aa577ab9897b..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fed/fed.c +++ /dev/null @@ -1,168 +0,0 @@ -/* - * Copyright (c) 1992, 1993, 1994 by Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis. - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPER ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * fed.c, 3.00, last edit-date: [Sun Jan 2 20:08:45 1994] - */ - -/*--------------------------------------------------------------------------- - * - * fed.c font editor main file - * ------------------------------------- - * - * written by Hellmuth Michaelis, hm@hcshh.hcs.de - * - * -hm first public release - * -hm activating font save - * - *---------------------------------------------------------------------------*/ - -#define FED - -#include "fed.h" - -void main(int argc, char *argv[]) -{ - int i; - int row, col; - int ret; - - if(argc != 2) - { - fprintf(stderr,"EGA/VGA Fonteditor, Rel 1.00\n"); - fprintf(stderr,"usage: %s \n",argv[0]); - exit(1); - } - - readfont(argv[1]); /* read fontfile into memory */ - - initscr(); - cbreak(); - noecho(); - nonl(); - keypad(stdscr,TRUE); - idlok(stdscr, TRUE); - - move(0,0); - standout(); - addstr(" Interactive EGA/VGA Fonteditor - (c) 1993, 1994 Hellmuth Michaelis "); - standend(); - -/* character horizontal ruler */ - - move(WINROW-1, CHCOL + ((WIDTH16 - ch_width)/2) + 1); - if(ch_width == WIDTH16) - addstr("1234567890123456"); - else - addstr("12345678"); - -/* charcater vertical ruler */ - - for(i=1; i < ch_height+1; i++) - mvprintw((WINROW+i), (CHCOL + ((WIDTH16 - ch_width)/2) - 2), "%2d", i); - - -/* select horizontal ruler */ - - move(WINROW-1,SETCOL+2); - addstr("0 1 2 3 4 5 6 7 8 9 A B C D E F "); - -/* select vertical ruler */ - - for(i=0; i<10; i++) - mvaddch((WINROW+i+1),(SETCOL-1),(i+'0')); - for(i=0; i<6; i++) - mvaddch((WINROW+10+i+1),(SETCOL-1),(i+'A')); - -/* label available commands window */ - - move(WINROW-1,CMDCOL+1); - addstr("Commands"); - - refresh(); - -/* command window */ - - cmd_win = newwin(((WSIZE)+(2*WBORDER)),(CMDSIZE+(2*WBORDER)), - WINROW,CMDCOL); - keypad(cmd_win,TRUE); - idlok(cmd_win, TRUE); - box(cmd_win,'|','-'); - - sel_mode(); - -/* character font window */ - - ch_win = newwin((ch_height+(2*WBORDER)),(ch_width+(2*WBORDER)), - WINROW, CHCOL+((WIDTH16 - ch_width)/2)); - keypad(ch_win,TRUE); - idlok(ch_win, TRUE); - - box(ch_win,'|','-'); - wrefresh(ch_win); - -/* character select window */ - - set_win = newwin((WSIZE+(2*WBORDER)),((WSIZE*2)+(2*WBORDER)), - WINROW,SETCOL); /* whole character set */ - keypad(set_win,TRUE); - idlok(set_win, TRUE); - - box(set_win,'|','-'); - - row = 0; - col = 0; - - for(i=0; i<256; i++) - { - mvwprintw(set_win,row+1,col+1,"%02.2X",i); - if(++row > 15) - { - row = 0; - col += 2; - } - } - wmove(set_win,1,1); - wrefresh(set_win); - -/* start */ - - clr_cmd(); - - curchar = 0; - - if((ret = selectc()) == 1) - { - writefont(); - } - endwin(); -} - -/*---------------------------------- E O F ----------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/Util/fed/fed.h b/sys/arch/i386/isa/pcvt/Util/fed/fed.h deleted file mode 100644 index 27a32c355260..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fed/fed.h +++ /dev/null @@ -1,127 +0,0 @@ -/* - * Copyright (c) 1992, 1993, 1994 by Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis. - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPER ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * fed.h, 3.00, last edit-date: [Sun Jan 2 20:10:31 1994] - */ - -#include -#include -#include -#include - -#ifdef FED - -int ch_height; -int ch_width; - -int curchar; - -WINDOW *ch_win; -WINDOW *set_win; -WINDOW *cmd_win; - -#else - -extern int ch_height; /* current fontfile character dimensions */ -extern int ch_width; - -extern int curchar; /* character being edited */ - -extern WINDOW *ch_win; /* windows */ -extern WINDOW *set_win; -extern WINDOW *cmd_win; - -#endif - -#define FONTCHARS 256 /* no of chars in a fontfile */ - -#define WHITE ('.') -#define BLACK ('*') - -#define K_UP 0x10 /* ^P */ -#define K_DOWN 0x0e /* ^N */ -#define K_RIGHT 0x06 /* ^F */ -#define K_LEFT 0x02 /* ^B */ - -#define WINROW 3 -#define CMDCOL 3 -#define CHCOL 20 -#define SETCOL 41 -#define WSIZE 16 -#define CMDSIZE 12 -#define WBORDER 1 - -/* fonts */ - -#define WIDTH8 8 /* 8 bits wide font */ -#define WIDTH16 16 /* 16 bits wide font */ - -#define FONT8X8 2048 /* filesize for 8x8 font */ -#define HEIGHT8X8 8 /* 8 scan lines char cell height */ - -#define FONT8X10 2560 /* filesize for 8x10 font */ -#define HEIGHT8X10 10 /* 10 scan lines char cell height */ - -#define FONT8X14 3584 /* filesize for 8x14 font */ -#define HEIGHT8X14 14 /* 14 scan lines char cell height */ -#define WIDTH8X14 8 /* 8 bits wide font */ - -#define FONT8X16 4096 /* filesize for 8x16 font */ -#define HEIGHT8X16 16 /* 16 scan lines char cell height */ - -#define FONT16X16 8192 /* filesize for 16x16 font */ -#define HEIGHT16X16 16 /* 16 scan lines char cell height */ - - -void edit_mode ( void ); -int edit ( void ); -void normal_ch ( int r, int c ); -void chg_pt ( int r, int c ); -void invert ( void ); -void setchr ( char type ); -void setrow ( char type ); -void setcol ( char type ); -void main ( int argc, char *argv[] ); -void readfont ( char *filename ); -void dis_cmd ( char *strg ); -void clr_cmd ( void ); -void save_ch ( void ); -void move_ch ( int src, int dest ); -void xchg_ch ( int src, int dest ); -void display ( int no ); -void sel_mode ( void ); -int selectc ( void ); -void normal_set ( int r, int c ); -int sel_dest ( void ); -void normal_uset ( int r, int c ); -void writefont( void ); - -/* ------------------------------ EOF ----------------------------------- */ diff --git a/sys/arch/i386/isa/pcvt/Util/fed/misc.c b/sys/arch/i386/isa/pcvt/Util/fed/misc.c deleted file mode 100644 index a0dff32703ac..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fed/misc.c +++ /dev/null @@ -1,353 +0,0 @@ -/* - * Copyright (c) 1992, 1993, 1994 by Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis. - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPER ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * misc.c, 3.00, last edit-date: [Sun Jan 2 20:09:21 1994] - */ - -/*--------------------------------------------------------------------------- - * - * misc.c font editor misc routines - * ----------------------------------------- - * - * written by Hellmuth Michaelis, hm@hcshh.hcs.de - * - * -hm first public release - * -hm writefont routine - * - *---------------------------------------------------------------------------*/ - -#include "fed.h" - -#include -#include -#include -#include - -static unsigned char *fonttab; /* ptr to font in core memory */ - -static char *bitmask[] = { - "....", /* 0 */ - "...*", /* 1 */ - "..*.", /* 2 */ - "..**", /* 3 */ - ".*..", /* 4 */ - ".*.*", /* 5 */ - ".**.", /* 6 */ - ".***", /* 7 */ - "*...", /* 8 */ - "*..*", /* 9 */ - "*.*.", /* A */ - "*.**", /* B */ - "**..", /* C */ - "**.*", /* D */ - "***.", /* E */ - "****", /* F */ - NULL }; - -static char lfilename[1024]; /* current filename */ -static unsigned int lfilesize; /* current filename's size */ - -/*---------------------------------------------------------------------------* - * read fontfile into memory - *---------------------------------------------------------------------------*/ -void readfont(char *filename) -{ - FILE *in; - struct stat sbuf, *sbp; - int ret; - char buffer[1024]; - - sbp = &sbuf; - - if((in = fopen(filename, "r")) == NULL) - { - sprintf(buffer, "cannot open file %s for reading", filename); - perror(buffer); - exit(1); - } - - if((fstat(fileno(in), sbp)) != 0) - { - sprintf(buffer, "cannot fstat file %s", filename); - perror(buffer); - exit(1); - } - - switch(sbp->st_size) - { - case FONT8X8: - ch_height = HEIGHT8X8; - ch_width = WIDTH8; - break; - - case FONT8X10: - ch_height = HEIGHT8X10; - ch_width = WIDTH8; - break; - - case FONT8X14: - ch_height = HEIGHT8X14; - ch_width = WIDTH8; - break; - - case FONT8X16: - ch_height = HEIGHT8X16; - ch_width = WIDTH8; - break; - - case FONT16X16: - ch_height = HEIGHT16X16; - ch_width = WIDTH16; - break; - - default: - fprintf(stderr,"error, file %s is no valid font file, size=%d\n",filename,sbp->st_size); - exit(1); - } - - if((fonttab = (unsigned char *)malloc((size_t)sbp->st_size)) == NULL) - { - fprintf(stderr,"error, malloc failed\n"); - exit(1); - } - - strcpy(lfilename, filename); /* save for write */ - lfilesize = sbp->st_size; /* save for write */ - - if((ret = fread(fonttab, sizeof(*fonttab), sbp->st_size, in)) != sbp->st_size) - { - sprintf(buffer,"error reading file %s, size = %d, ret = %d\n",filename,sbp->st_size, ret); - perror(buffer); - exit(1); - } -} - -/*---------------------------------------------------------------------------* - * write fontfile to disk - *---------------------------------------------------------------------------*/ -void writefont() -{ - FILE *in, *out; - int ret; - char buffer[1024]; - - if((in = fopen(lfilename, "r")) != NULL) - { - int c; - char wfn[1024]; - - strcpy(wfn, lfilename); - strcat(wfn, ".BAK"); - if((out = fopen(wfn, "w")) == NULL) - { - sprintf(buffer, "cannot open file %s for writing", wfn); - perror(buffer); - exit(1); - } - - while(( c = fgetc(in) ) != EOF ) - fputc(c, out); - - fclose(out); - fclose(in); - } - - if((out = fopen(lfilename, "w")) == NULL) - { - sprintf(buffer, "cannot open file %s for writing", lfilename); - perror(buffer); - exit(1); - } - - if((ret = fwrite(fonttab, sizeof(*fonttab), lfilesize, out)) != lfilesize) - { - sprintf(buffer,"error writing file %s, size=%d, ret=%d\n",lfilename,lfilesize, ret); - perror(buffer); - exit(1); - } -} - -/*---------------------------------------------------------------------------* - * display a string - *---------------------------------------------------------------------------*/ -void dis_cmd(char *strg) -{ - move(22,0); - clrtoeol(); - mvaddstr(22,0,strg); - refresh(); -} - -/*---------------------------------------------------------------------------* - * clear a command string - *---------------------------------------------------------------------------*/ -void clr_cmd(void) -{ - move(22,0); - clrtoeol(); - refresh(); -} - -/*---------------------------------------------------------------------------* - * move char from src to dest - *---------------------------------------------------------------------------*/ -void move_ch(int src, int dst) -{ - unsigned char *s, *d; - int offset = 0; - - if(ch_width == WIDTH16) - offset = 2; - else - offset = 1; - - s = &(fonttab[ch_height * offset * src]); - d = &(fonttab[ch_height * offset * dst]); - - bcopy(s, d, (ch_height*offset)); /* src -> dst */ -} - -/*---------------------------------------------------------------------------* - * exchange char's src and dest - *---------------------------------------------------------------------------*/ -void xchg_ch(int src, int dst) -{ - unsigned char *s, *d; - unsigned char buf[32]; - int offset = 0; - - if(ch_width == WIDTH16) - offset = 2; - else - offset = 1; - - s = &(fonttab[ch_height * offset * src]); - d = &(fonttab[ch_height * offset * dst]); - - bcopy(s, buf, (ch_height*offset)); /* src -> tmp */ - bcopy(d, s, (ch_height*offset)); /* dst -> src */ - bcopy(buf, d, (ch_height*offset)); /* tmp -> dst */ -} - -/*---------------------------------------------------------------------------* - * display the current selected character - *---------------------------------------------------------------------------*/ -void display(int no) -{ - unsigned char *fontchar; - char line[32]; - int ln_no; - unsigned char hibyte; - unsigned char lobyte; - int offset; - int r; - - offset = 0; - r = 1; - lobyte = 0; - - if(ch_width == WIDTH16) - fontchar = &(fonttab[ch_height * 2 * no]); - else - fontchar = &(fonttab[ch_height * no]); - - for (ln_no = 0; ln_no < ch_height; ln_no++) - { - hibyte = *(fontchar + (offset++)); - - if(ch_width == WIDTH16) - { - lobyte = *(fontchar + offset++); - } - - strcpy(line,bitmask[(int)((hibyte >> 4) & 0x0f)]); - strcat(line,bitmask[(int)(hibyte & 0x0f)]); - - if(ch_width == WIDTH16) - { - strcat(line,bitmask[(int)((lobyte >> 4) & 0x0f)]); - strcat(line,bitmask[(int)(lobyte & 0x0f)]); - mvwprintw(ch_win, r, 1, "%16.16s", line); - } - else - { - mvwprintw(ch_win, r, 1, "%8.8s", line); - } - r++; - } - wmove(ch_win, 1, 1); - wrefresh(ch_win); -} - -/*---------------------------------------------------------------------------* - * save character - *---------------------------------------------------------------------------*/ -void save_ch(void) -{ - unsigned char *s; - int offset = 0; - int r, c; - unsigned short byte; - unsigned short shift; - - if(ch_width == WIDTH16) - offset = 2; - else - offset = 1; - - s = &(fonttab[ch_height * offset * curchar]); - - r = 1; - - while(r <= ch_height) - { - c = 1; - byte = 0; - if(offset == 2) - shift = 0x8000; - else - shift = 0x80; - - while(c <= ch_width) - { - if(mvwinch(ch_win, r, c) == BLACK) - byte |= shift; - shift = (shift >> 1); - c++; - } - *s++ = byte; - r++; - } -} - -/*---------------------------------- E O F ----------------------------------*/ - - diff --git a/sys/arch/i386/isa/pcvt/Util/fed/select.c b/sys/arch/i386/isa/pcvt/Util/fed/select.c deleted file mode 100644 index 6b9d3858cf7c..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fed/select.c +++ /dev/null @@ -1,334 +0,0 @@ -/* - * Copyright (c) 1992, 1993, 1994 by Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis. - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPER ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * select.c, 3.00, last edit-date: [Sun Jan 2 20:09:36 1994] - */ - -/*--------------------------------------------------------------------------- - * - * select.c font editor select character - * ---------------------------------------------------- - * - * written by Hellmuth Michaelis, hm@hcshh.hcs.de - * - * -hm first public release - * -hm debugging - * - *---------------------------------------------------------------------------*/ - -#include "fed.h" - -int sc, sr, scurchar; - -int edit(); - -void sel_mode(void) -{ - mvwprintw(cmd_win,1,1,"(E)dit "); - mvwprintw(cmd_win,2,1,"(M)ove "); - mvwprintw(cmd_win,3,1,"exchan(G)e "); - mvwprintw(cmd_win,4,1,"(Q)uit/Save "); - mvwprintw(cmd_win,5,1,"e(X)it/Undo "); - mvwprintw(cmd_win,6,1," "); - mvwprintw(cmd_win,7,1," "); - mvwprintw(cmd_win,8,1," "); - - mvwprintw(cmd_win,9 ,1," "); - mvwprintw(cmd_win,10,1," "); - mvwprintw(cmd_win,11,1," "); - mvwprintw(cmd_win,12,1," "); - mvwprintw(cmd_win,13,1,"(^P)rev Line"); - mvwprintw(cmd_win,14,1,"(^N)ext Line"); - mvwprintw(cmd_win,15,1,"(^F)orwd Col"); - mvwprintw(cmd_win,16,1,"(^B)ack Col"); - wrefresh(cmd_win); -} - -int selectc() -{ - int c, r; - int ret; - char h, l; - unsigned int k_ch; - - c = (curchar / 16); - r = (curchar % 16); - - for(;;) - { - dis_cmd(" Select Character"); - - sel_mode(); - - curchar = r + (c*16); - - display(curchar); - - h = ((mvwinch(set_win,(r+1),((c*2)+1))) & A_CHARTEXT); - l = ((mvwinch(set_win,(r+1),((c*2)+2))) & A_CHARTEXT); - wattron(set_win,A_REVERSE); - mvwprintw(set_win,(r+1),((c*2)+1),"%c%c",h,l); - wattroff(set_win,A_REVERSE); - wmove(set_win,(r+1),((c*2)+1)); - wrefresh(set_win); - - k_ch = wgetch(set_win); - - switch(k_ch) - { - case K_LEFT: - case KEY_LEFT: - if(c > 0) - { - normal_set(r,c); - c--; - } - break; - - case K_DOWN: - case KEY_DOWN: - if(r < 15) - { - normal_set(r,c); - r++; - } - break; - - case K_UP: - case KEY_UP: - if(r > 0) - { - normal_set(r,c); - r--; - } - break; - - case K_RIGHT: - case KEY_RIGHT: - if(c < 15) - { - normal_set(r,c); - c++; - } - break; - - case 'e': - case 'E': - edit_mode(); - dis_cmd(" Edit Character"); - display(curchar); - ret = edit(); - if(ret == 1) - save_ch(); - break; - - case 'g': - case 'G': - dis_cmd(" Exchange: select Destination, then press RETURN or any other Key to ABORT"); - sr = r; - sc = c; - scurchar = curchar; - if((curchar = sel_dest()) == -1) - { /* failsafe */ - r = sr; - c = sc; - curchar = scurchar; - } - else - { /* valid return */ - normal_set(r,c); - c = (curchar / 16); - r = (curchar % 16); - xchg_ch(scurchar,curchar); - } - break; - - case 'm': - case 'M': - dis_cmd(" Move: select Destination, then press RETURN or any other Key to ABORT"); - sr = r; - sc = c; - scurchar = curchar; - if((curchar = sel_dest()) == -1) - { /* failsafe */ - r = sr; - c = sc; - curchar = scurchar; - } - else - { /* valid return */ - normal_set(r,c); - c = (curchar / 16); - r = (curchar % 16); - move_ch(scurchar,curchar); - } - break; - - case 'q': - case 'Q': - normal_set(r,c); - wrefresh(set_win); - return(1); - break; - - case 'x': - case 'X': - normal_set(r,c); - wrefresh(set_win); - return(0); - break; - - case 0x0c: - wrefresh(curscr); - break; - - default: - beep(); - break; - - } - } -} - -void normal_set(int r, int c) -{ - char h, l; - - h = ((mvwinch(set_win,(r+1),((c*2)+1))) & A_CHARTEXT); - l = ((mvwinch(set_win,(r+1),((c*2)+2))) & A_CHARTEXT); - wattroff(set_win,A_REVERSE); - mvwprintw(set_win,(r+1),((c*2)+1),"%c%c",h,l); - wmove(set_win,(r+1),((c*2)+1)); -} - -int sel_dest(void) -{ - int c, r; - char h, l; - unsigned int k_ch; - - c = (curchar / 16); - r = (curchar % 16); - - for(;;) - { - - curchar = r + (c*16); - - display(curchar); - - h = ((mvwinch(set_win,(r+1),((c*2)+1))) & A_CHARTEXT); - l = ((mvwinch(set_win,(r+1),((c*2)+2))) & A_CHARTEXT); - wattron(set_win,A_UNDERLINE); - mvwprintw(set_win,(r+1),((c*2)+1),"%c%c",h,l); - wattroff(set_win,A_UNDERLINE); - wmove(set_win,(r+1),((c*2)+1)); - wrefresh(set_win); - - k_ch = wgetch(set_win); - - switch(k_ch) - { - case K_LEFT: - case KEY_LEFT: - if(c > 0) - { - normal_uset(r,c); - c--; - } - break; - - case K_DOWN: - case KEY_DOWN: - if(r < 15) - { - normal_uset(r,c); - r++; - } - break; - - case K_UP: - case KEY_UP: - if(r > 0) - { - normal_uset(r,c); - r--; - } - break; - - case K_RIGHT: - case KEY_RIGHT: - if(c < 15) - { - normal_uset(r,c); - c++; - } - break; - - case '\r': - case '\n': - normal_uset(r,c); - return(r + (c*16)); - - case 0x0c: - wrefresh(curscr); - break; - - default: - normal_uset(r,c); - return(-1); - } - } -} - -void normal_uset(int r, int c) -{ - char h, l; - - h = ((mvwinch(set_win,(r+1),((c*2)+1))) & A_CHARTEXT); - l = ((mvwinch(set_win,(r+1),((c*2)+2))) & A_CHARTEXT); - - wattroff(set_win,A_UNDERLINE); - mvwprintw(set_win,(r+1),((c*2)+1),"%c%c",h,l); - wmove(set_win,(r+1),((c*2)+1)); - - if((r==sr) && (c==sc)) - { - wattron(set_win,A_REVERSE); - mvwprintw(set_win,(r+1),((c*2)+1),"%c%c",h,l); - wattroff(set_win,A_REVERSE); - wmove(set_win,(r+1),((c*2)+1)); - } -} - - - -/*---------------------------------- E O F ----------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/Util/fontedit/Makefile b/sys/arch/i386/isa/pcvt/Util/fontedit/Makefile deleted file mode 100644 index d6cdc9960047..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fontedit/Makefile +++ /dev/null @@ -1,7 +0,0 @@ -PROG= fontedit -CLEANFILES+= core.fontedit fontedit.core - -MKMAN= no - -.include - diff --git a/sys/arch/i386/isa/pcvt/Util/fontedit/README b/sys/arch/i386/isa/pcvt/Util/fontedit/README deleted file mode 100644 index 1854129b63d7..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fontedit/README +++ /dev/null @@ -1,36 +0,0 @@ -When I first saw this posted to rn, I tried to compile this on a machine -running BSD UNIX. Much to my dissapointment, It said "unable to find -/usr/include/termio.h" and thus it sat for a couple months. I was able to -compile it on a 3b5, but I didn't have a vt220 hooked up to it. I was doing -some unrelated work with ioctl calls and finally realized that it would not be -too hard to convert it from System V to BSD. It also looked kind of strange -with the cursor on, so I turned this off. To implement this, compile with -the "-DCURFIX" flag in the Makefile. -I am working on a new version that uses curses and that would enable you to -change the file that your are working on without leaving the program. -I thought I'd post it as it is now, since it has a lot of uses right away. -Imagine changing your favorite game to have objects that look like what they -are instead of the regular characters. Also, I think people should post their -own character sets, if they come up with some neat stuff. - Please send any comments or suggestions to: - - UUCP : ..!harvard!bu-cs!bucsb!eap - ARPANET: eap@bucsb.bu.edu - CSNET : eap%bucsb@bu-cs - - Have fun, - - - Eric Pearce - Boston University - - - - - - - - - - - - diff --git a/sys/arch/i386/isa/pcvt/Util/fontedit/fontedit.c b/sys/arch/i386/isa/pcvt/Util/fontedit/fontedit.c deleted file mode 100644 index 36a3232f097e..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fontedit/fontedit.c +++ /dev/null @@ -1,925 +0,0 @@ -/* - * fontedit - * Fonteditor for VT220 - * - * BUGS: - * o Cursor motion is less than optimal (but who cares at 9600), - * - * COMPILE: - * cc -O fontedit.c -o fontedit - * (use Makefile) - * - * Copyright (c) 1987 by Greg Franks. - * - * Permission is granted to do anything you want with this program - * except claim that you wrote it. - * - * - * REVISION HISTORY: - * - * Nov 21, 1987 - Fixed man page to say "Fontedit" instead of "Top" - * Nov 22, 1987 - Added BSD Compatible ioctl, turned cursor on/off - * - eap@bucsf.bu.edu - */ - -void clear_screen(); -#include -#ifdef SYSV -#include -#endif SYSV -#ifdef BSD -#include -#endif BSD -#if defined (__NetBSD__) || defined (__FreeBSD__) -#include -#include -#endif /* __NetBSD__ || __FreeBSD__ */ -#include - -#ifdef CURFIX -#define CURSORON "\033[?25h" -#define CURSOROFF "\033[?25l" -#endif CURFIX - -#define MAX_ROWS 10 -#define MAX_COLS 8 - -typedef enum { false, true } bool; - -#define KEY_FIND 0x0100 -#define KEY_INSERT 0x0101 -#define KEY_REMOVE 0x0102 -#define KEY_SELECT 0x0103 -#define KEY_PREV 0x0104 -#define KEY_NEXT 0x0105 -#define KEY_F6 0X0106 -#define KEY_F7 0x0107 -#define KEY_F8 0x0108 -#define KEY_F9 0x0109 -#define KEY_F10 0x010a -#define KEY_F11 0x010b -#define KEY_F12 0x010c -#define KEY_F13 0x010d -#define KEY_F14 0x010e -#define KEY_HELP 0x010f -#define KEY_DO 0x0110 -#define KEY_F17 0x0111 -#define KEY_F18 0x0112 -#define KEY_F19 0x0113 -#define KEY_F20 0x0114 -#define KEY_UP 0x0115 -#define KEY_DOWN 0x0116 -#define KEY_RIGHT 0x0117 -#define KEY_LEFT 0x0118 - -/* - * Position of main drawing screen. - */ - -#define ROW_OFFSET 3 -#define COL_OFFSET 10 - -/* - * Position of the DRCS table. - */ - -#define TABLE_ROW 4 -#define TABLE_COL 50 - -/* - * - */ - -#define ERROR_ROW 20 -#define ERROR_COL 40 - -bool display_table[MAX_ROWS][MAX_COLS]; - -#define TOTAL_ENTRIES (128 - 32) -#define SIXELS_PER_CHAR 16 - -char font_table[TOTAL_ENTRIES][SIXELS_PER_CHAR]; -unsigned int current_entry; - -#ifdef SYSV -struct termio old_stty, new_stty; -#endif SYSV -#ifdef BSD -struct sgttyb old_stty, new_stty; -#endif BSD -#if defined (__NetBSD__) || defined (__FreeBSD__) -struct termios old_stty, new_stty; -#endif /* __NetBSD__ || __FreeBSD__ */ -FILE * font_file = (FILE *)0; - - -/* - * Interrupt - * Exit gracefully. - */ - -interrupt() -{ - void clear_screen(); -#ifdef CURFIX - printf("%s\n",CURSORON); -#endif CURFIX -#ifdef SYSV - ioctl( 0, TCSETA, &old_stty ); -#endif SYSV -#ifdef BSD - ioctl( 0, TIOCSETP, &old_stty ); -#endif BSD -#if defined (__NetBSD__) || defined (__FreeBSD__) - ioctl( 0, TIOCSETA, &old_stty ); -#endif /* __NetBSD__ || __FreeBSD__ */ - clear_screen(); - exit( 0 ); -} - - -/* - * Main - * Grab input/output file and call main command processor. - */ - -main( argc, argv ) -int argc; -char *argv[]; -{ - void command(), init_restore(), clear_screen(); - void save_table(), get_table(), extract_entry(); - - if ( argc != 2 ) { - fprintf( stderr, "usage: fontedit filename\n" ); - exit( 1 ); - } - - printf( "Press HELP for help\n" ); - printf( "\033P1;1;2{ @\033\\" ); /* Clear font buffer */ - fflush( stdout ); - sleep( 1 ); /* Let terminal catch up */ - /* otherwise we get frogs */ - - if ( ( font_file = fopen( argv[1], "r" ) ) == (FILE *)0 ) { - if ( ( font_file = fopen( argv[1], "w" ) ) == (FILE *)0 ) { - fprintf( stderr, "Cannot create file %s \n", argv[1] ); - exit( 1 ); - } - } - fclose( font_file ); - - if ( ( font_file = fopen( argv[1], "r" ) ) != (FILE *)0 ) { - get_table( font_file ); - fclose( font_file ); - } - - if ( ( font_file = fopen( argv[1], "r+" ) ) == (FILE *)0 ) { - fprintf( stderr, "Cannot open %s for writing\n", argv[1] ); - exit( 1 ); - } -#ifdef CURFIX - printf("%s\n",CURSOROFF); -#endif CURFIX -#ifdef SYSV - ioctl( 0, TCGETA, &old_stty ); -#endif SYSV -#ifdef BSD - ioctl( 0, TIOCGETP, &old_stty ); -#endif BSD -#if defined (__NetBSD__) || defined (__FreeBSD__) - ioctl( 0, TIOCGETA, &old_stty ); -#endif /* __NetBSD__ || __FreeBSD__ */ - signal( SIGINT, (void *) interrupt ); - new_stty = old_stty; -#ifdef SYSV - new_stty.c_lflag &= ~ICANON; - new_stty.c_cc[VMIN] = 1; - ioctl( 0, TCSETA, &new_stty ); -#endif SYSV -#if defined (__NetBSD__) || defined (__FreeBSD__) - new_stty.c_lflag &= ~ICANON; - new_stty.c_lflag &= ~ECHO; - new_stty.c_cc[VMIN] = 1; - ioctl( 0, TIOCSETA, &new_stty ); -#endif /* __NetBSD__ || __FreeBSD__ */ -#ifdef BSD - new_stty.sg_flags |= CBREAK; - new_stty.sg_flags &= ~ECHO; - ioctl( 0, TIOCSETP, &new_stty ); -#endif BSD - current_entry = 1; - extract_entry( current_entry ); - init_restore(); - command(); -#ifdef SYSV - ioctl( 0, TCSETA, &old_stty ); -#endif SYSV -#ifdef BSD - ioctl( 0, TIOCSETP, &old_stty ); -#endif BSD -#if defined (__NetBSD__) || defined (__FreeBSD__) - ioctl( 0, TIOCSETA, &old_stty ); -#endif /* __NetBSD__ || __FreeBSD__ */ - clear_screen(); - - /* Overwrite the old file. */ - - fseek( font_file, 0L, 0 ); - save_table( font_file ); - fclose( font_file ); -#ifdef CURFIX - printf("%s\n",CURSORON); -#endif CURFIX -} - - - -/* - * Command - * Process a function key. - * - * The user cannot fill in slots 0 or 95 (space and del respecitively). - */ - -void -command() -{ - register int c; - register int row, col; - register int i, j; - bool change, error, override; - - void build_entry(), extract_entry(), send_entry(), print_entry(); - void highlight(), draw_current(), init_restore(), help(); - void warning(); - - change = false; - error = false; - override = false; - row = 0; col = 0; - highlight( row, col, true ); - - for ( ;; ) { - c = get_key(); - highlight( row, col, false ); /* turn cursor off */ - - if ( error ) { - move ( ERROR_ROW, ERROR_COL ); - printf( "\033[K" ); /* Clear error message */ - move ( ERROR_ROW+1, ERROR_COL ); - printf( "\033[K" ); /* Clear error message */ - error = false; - } else { - override = false; - } - - switch ( c ) { - - case KEY_FIND: /* update DRCS */ - if ( !change && !override ) { - warning( "No changes to save" ); - override = true; - error = true; - } else { - build_entry( current_entry ); - send_entry( current_entry ); - print_entry( current_entry, true ); - change = false; - } - break; - - case KEY_F6: /* Turn on pixel */ - change = true; - display_table[row][col] = true; - highlight( row, col, false ); - col = ( col + 1 ) % MAX_COLS; - if ( col == 0 ) - row = ( row + 1 ) % MAX_ROWS; - break; - - case KEY_F7: /* Turn off pixel */ - change = true; - display_table[row][col] = false; - highlight( row, col, false ); - col = ( col + 1 ) % MAX_COLS; - if ( col == 0 ) - row = ( row + 1 ) % MAX_ROWS; - break; - - case KEY_INSERT: /* Insert a blank row */ - change = true; - for ( j = 0; j < MAX_COLS; ++j ) { - for ( i = MAX_ROWS - 1; i > row; --i ) { - display_table[i][j] = display_table[i-1][j]; - } - display_table[row][j] = false; - } - draw_current(); - break; - - case KEY_REMOVE: /* Remove a row */ - change = true; - for ( j = 0; j < MAX_COLS; ++j ) { - for ( i = row; i < MAX_ROWS - 1; ++i ) { - display_table[i][j] = display_table[i+1][j]; - } - display_table[MAX_ROWS-1][j] = false; - } - draw_current(); - break; - - case KEY_F13: /* Clear buffer */ - if ( change && !override ) { - warning( "Changes not saved" ); - error = true; - override = true; - } else { - for ( j = 0; j < MAX_COLS; ++j ) { - for ( i = 0; i < MAX_ROWS; ++i ) { - display_table[i][j] = false; - } - } - draw_current(); - } - break; - - case KEY_SELECT: /* Select font from DRCS */ - if ( change && !override ) { - warning( "Changes not saved" ); - error = true; - override = true; - } else { - extract_entry( current_entry ); - draw_current(); - } - break; - - case KEY_PREV: /* Move to prev entry in DRCS */ - if ( change && !override ) { - warning( "Changes not saved" ); - override = true; - error = true; - } else { - print_entry( current_entry, false ); - current_entry = current_entry - 1; - if ( current_entry == 0 ) - current_entry = TOTAL_ENTRIES - 2; - print_entry( current_entry, true ); - } - break; - - case KEY_NEXT: /* Move to next entry in DRCS */ - if ( change && !override ) { - warning( "Changes not saved" ); - override = true; - error = true; - } else { - print_entry( current_entry, false ); - current_entry = current_entry + 1; - if ( current_entry == TOTAL_ENTRIES - 1 ) - current_entry = 1; - print_entry( current_entry, true ); - } - break; - - case KEY_UP: /* UP one row. */ - if ( row == 0 ) - row = MAX_ROWS; - row = row - 1; - break; - - case KEY_DOWN: /* Guess. */ - row = ( row + 1 ) % MAX_ROWS; - break; - - case KEY_RIGHT: - col = ( col + 1 ) % MAX_COLS; - break; - - case KEY_LEFT: - if ( col == 0 ) - col = MAX_COLS; - col = col - 1; - break; - - case KEY_HELP: /* Display helpful info */ - clear_screen(); - help(); - c = getchar(); - init_restore(); - break; - - case '\004': /* All done! */ - return; - - case '\f': /* Redraw display */ - init_restore(); - break; - - default: /* user is a klutzy typist */ - move ( ERROR_ROW, ERROR_COL ); - printf( "Unknown key: " ); - if ( c < 0x20 ) { - printf( "^%c", c ); - } else if ( c < 0x0100 ) { - printf( "%c", c ); - } else { - printf( "0x%04x", c ); - } - fflush( stdout ); - error = true; - } - - highlight( row, col, true ); /* turn cursor on */ - } -} - - - -char *key_table[] = { - "\033[1~", /* Find */ - "\033[2~", /* Insert */ - "\033[3~", /* Remove */ - "\033[4~", /* Select */ - "\033[5~", /* Prev */ - "\033[6~", /* Next */ - "\033[17~", - "\033[18~", - "\033[19~", - "\033[20~", - "\033[21~", - "\033[23~", - "\033[24~", - "\033[25~", - "\033[26~", - "\033[28~", - "\033[29~", - "\033[31~", - "\033[32~", - "\033[33~", - "\033[34~", - "\033[A", - "\033[B", - "\033[C", - "\033[D", - (char *)0 }; - -/* - * get_key - * Convert VT220 escape sequence into something more reasonable. - */ - -int -get_key() -{ - register char *p; - char s[10]; - register int i, j; - - p = s; - for ( i = 0; i < 10; ++i ) { - *p = getchar(); - if ( i == 0 && *p != '\033' ) - return( (int)*p ); /* Not an escape sequence */ - if ( *p != '\033' && *p < 0x0020 ) - return( (int)*p ); /* Control character */ - *++p = '\0'; /* Null terminate */ - for ( j = 0; key_table[j]; ++j ) { - if ( strcmp( s, key_table[j] ) == 0 ) { - return( j | 0x0100 ); - } - } - } - return( -1 ); -} - - - -/* - * pad - * Emit nulls so that the terminal can catch up. - */ - -pad() -{ - int i; - - for ( i = 0; i < 20; ++i ) - putchar( '\000' ); - fflush( stdout ); -} - - - -/* - * init_restore - * refresh the main display table. - */ - -void -init_restore() -{ - register int row, col; - register int i; - - void draw_current(), clear_screen(), print_entry(); - - clear_screen(); - - for ( col = 0; col < MAX_COLS; ++col ) { - move( ROW_OFFSET - 2, col * 3 + COL_OFFSET + 1 ); - printf( "%d", col ); - } - move( ROW_OFFSET - 1, COL_OFFSET ); - printf( "+--+--+--+--+--+--+--+--+" ); - move( ROW_OFFSET + MAX_ROWS * 2, COL_OFFSET ); - printf( "+--+--+--+--+--+--+--+--+" ); - - for ( row = 0; row < MAX_ROWS; ++row ) { - if ( row != 0 && row != 7 ) { - move( row * 2 + ROW_OFFSET, COL_OFFSET - 2 ); - printf( "%d|", row ); - move( row * 2 + ROW_OFFSET + 1, COL_OFFSET - 1 ); - printf( "|" ); - move( row * 2 + ROW_OFFSET, COL_OFFSET + MAX_COLS * 3 ); - printf( "|" ); - move( row * 2 + ROW_OFFSET + 1, COL_OFFSET + MAX_COLS * 3 ); - printf( "|" ); - } else { - move( row * 2 + ROW_OFFSET, COL_OFFSET - 2 ); - printf( "%d*", row ); - move( row * 2 + ROW_OFFSET + 1, COL_OFFSET - 1 ); - printf( "*" ); - move( row * 2 + ROW_OFFSET, COL_OFFSET + MAX_COLS * 3 ); - printf( "*" ); - move( row * 2 + ROW_OFFSET + 1, COL_OFFSET + MAX_COLS * 3 ); - printf( "*" ); - } - } - draw_current(); - - move( TABLE_ROW - 1, TABLE_COL - 1 ); - printf( "+-+-+-+-+-+-+-+-+-+-+-+-+" ); - move( TABLE_ROW + 8 * 2 - 1, TABLE_COL - 1 ); - printf( "+-+-+-+-+-+-+-+-+-+-+-+-+" ); - for ( i = 0; i < 8; ++i ) { - move ( TABLE_ROW + i * 2, TABLE_COL - 1 ); - printf( "|" ); - move ( TABLE_ROW + i * 2 + 1, TABLE_COL - 1 ); - printf( "+" ); - move ( TABLE_ROW + i * 2, TABLE_COL + 12 * 2 - 1); - printf( "|" ); - move ( TABLE_ROW + i * 2 + 1, TABLE_COL +12 * 2 - 1); - printf( "+" ); - } - for ( i = 0; i < TOTAL_ENTRIES; ++i ) - print_entry( i, (i == current_entry) ? true : false ); -} - - - -/* - * draw_current - * Draw the complete current entry. - */ - -void -draw_current() -{ - register int row, col; - - printf( "\033)0" ); /* Special graphics in G1 */ - printf( "\016" ); /* Lock in G1 (SO) */ - - for ( row = 0; row < MAX_ROWS; ++row ) { - for ( col = 0; col < MAX_COLS; ++col ) { - if ( display_table[row][col] ) { - move( row * 2 + ROW_OFFSET, col * 3 + COL_OFFSET ); - printf( "\141\141\141" ); - move( row * 2 + ROW_OFFSET + 1, col * 3 + COL_OFFSET ); - printf( "\141\141\141" ); - } else { - move( row * 2 + ROW_OFFSET, col * 3 + COL_OFFSET ); - printf( " " ); /* erase splat */ - move( row * 2 + ROW_OFFSET + 1, col * 3 + COL_OFFSET ); - printf( " " ); /* erase splat */ - } - } - pad(); - } - printf( "\017" ); /* Lock in G0 (SI) */ - fflush( stdout ); -} - - - -/* - * highlight - * Draw the cursor in the main display area. - */ - -void -highlight( row, col, on ) -unsigned int row, col; -bool on; -{ - - printf( "\033)0" ); /* Special graphics in G1 */ - printf( "\016" ); /* Lock in G1 (SO) */ - if ( on ) { - printf( "\033[7m" ); /* Reverse video cursor */ - } - - if ( display_table[row][col] ) { - move( row * 2 + ROW_OFFSET, col * 3 + COL_OFFSET ); - printf( "\141\141\141" ); - move( row * 2 + ROW_OFFSET + 1, col * 3 + COL_OFFSET ); - printf( "\141\141\141" ); - } else { - move( row * 2 + ROW_OFFSET, col * 3 + COL_OFFSET ); - printf( " " ); /* erase splat */ - move( row * 2 + ROW_OFFSET + 1, col * 3 + COL_OFFSET ); - printf( " " ); /* erase splat */ - } - pad(); - printf( "\017" ); /* Lock in G0 (SI) */ - printf( "\033[0m" ); /* normal video */ - printf( "\b" ); /* Back up one spot */ - fflush( stdout ); -} - - - -/* - * Clear_screen - */ - -void -clear_screen() -{ - printf( "\033[H\033[J" ); /* Clear screen. */ - fflush( stdout ); -} - - - -/* - * move - */ - -move( y, x ) -int y, x; -{ - printf( "\033[%d;%df", y, x ); -} - - - -/* - * Build_entry - * Convert the bit pattern used in the main display area into something - * that the vt220 can digest - namely sixels... - */ - -void -build_entry( entry_no ) -unsigned int entry_no; -{ - register int row, col; - register unsigned int mask; - - for ( col = 0; col < 8; ++col ) { - - /* Top set of sixels */ - - mask = 0; - for ( row = 5; row >= 0; --row ) { - mask = mask << 1; - if ( display_table[row][col] ) - mask |= 1; - } - font_table[entry_no][col] = mask + 077; - - /* Bottom set of sixels */ - - mask = 0; - for ( row = 9; row >= 6; --row ) { - mask = mask << 1; - if ( display_table[row][col] ) - mask |= 1; - } - font_table[entry_no][col+8] = mask + 077; - } - -} - - - -/* - * Extract_engry - * convert sixel representation into an array of bits. - */ - -void -extract_entry( entry_no ) -unsigned int entry_no; -{ - register int row, col; - register unsigned int mask; - - for ( col = 0; col < 8; ++col ) { - - /* Top set of sixels */ - - mask = font_table[entry_no][col]; - if ( mask >= 077 ) - mask -= 077; - else - mask = 0; /* Bogus entry */ - - for ( row = 0; row <= 5; ++row ) { - display_table[row][col] = (bool)(mask & 0x0001); - mask = mask >> 1; - } - - /* Bottom set of sixels */ - - mask = font_table[entry_no][col+8]; - if ( mask >= 077 ) - mask -= 077; - else - mask = 0; - - for ( row = 6; row <= 9; ++row ) { - display_table[row][col] = (bool)(mask & 0x0001); - mask = mask >> 1; - } - } - -} - - - -/* - * Send_entry - * Emit the stuff used by the VT220 to load a character into the - * DRCS. We could, of course, send more than one entry at a time... - */ - -void -send_entry( entry_no ) -int entry_no; -{ - register char *fp = font_table[entry_no]; - - printf( "\033P1;%d;1;0;0;0{ @%c%c%c%c%c%c%c%c/%c%c%c%c%c%c%c%c\033\\", - entry_no, - fp[ 0], fp[ 1], fp[ 2], fp[ 3], fp[ 4], fp[ 5], fp[ 6], fp[ 7], - fp[ 8], fp[ 9], fp[10], fp[11], fp[12], fp[13], fp[14], fp[15] ); -} - - - -/* - * Print_entry - * The terminal normally has G0 in GL. We don't want to change - * this, nor do we want to use GR. Sooooo send out the necessary - * magic for shifting in G2 temporarily for the character that we - * want to display. - */ - -void -print_entry( entry_no, highlight ) -register unsigned int entry_no; -bool highlight; -{ - - register int y, x; - - y = entry_no & 0x07; - x = entry_no >> 3 & 0x1f; - entry_no += 32; /* Map up to G set */ - - move( y * 2 + TABLE_ROW, x * 2 + TABLE_COL ); - - if ( highlight ) - printf( "\033[7m" ); - - printf( "\033* @" ); /* select DRCS into G2 */ - printf( "\033N" ); /* select single shift */ - printf( "%c", entry_no ); /* Draw the character */ - - if ( highlight ) - printf( "\033[0m" ); -} - - - -/* - * Save_table - * Save a font table - */ - -void -save_table( font_file ) -FILE *font_file; -{ - register char *fp; - register int i; - - for ( i = 0; i < TOTAL_ENTRIES; ++i ) { - fp = font_table[i]; - fprintf( font_file, "\033P1;%d;1;0;0;0{ @%c%c%c%c%c%c%c%c/%c%c%c%c%c%c%c%c\033\\\n", - i, - fp[ 0], fp[ 1], fp[ 2], fp[ 3], fp[ 4], fp[ 5], fp[ 6], fp[ 7], - fp[ 8], fp[ 9], fp[10], fp[11], fp[12], fp[13], fp[14], fp[15] ); - } -} - - - -/* - * Get_table - * Extract font table entries from a file - */ - -void -get_table( font_file ) -FILE *font_file; -{ - char s[256]; - register char *p; - char *fp; - int i; - register int j; - - while( fgets( s, 255, font_file ) ) { - if ( strncmp( s, "\033P1;", 4 ) != 0 ) - continue; /* Bogus line */ - p = &s[4]; - if ( sscanf( p, "%d", &i ) != 1 ) - continue; /* Illegal entry number */ - - if ( i <= 0 || TOTAL_ENTRIES <= i ) - continue; /* Bogues entry */ - - fp = font_table[i]; - - while ( *p && *p != '@' ) - ++p; /* Skip to font definition */ - if ( ! *p++ ) - continue; /* Skip @ */ - - for ( j = 0; *p && *p != '\033' && j < 16; ++j, ++p ) { - if ( *p == '/' ) { - j = 8; - ++p; - } - fp[j] = *p; - } - send_entry( i ); - } -} - - - -/* - * Help - * Print out help information. - */ - -void -help() -{ - printf( "Font editor\n\n" ); - printf( "F6 - Pixel on\n" ); - printf( "F7 - Pixel off\n" ); - printf( "F13 - Clear display area\n" ); - printf( "HELP - This screen\n" ); - printf( "FIND - Update font table\n" ); - printf( "INSERT - Insert a blank row\n" ); - printf( "REMOVE - Remove a row\n" ); - printf( "SELECT - Select current font table entry\n" ); - printf( "PREV - Move to previous font table entry\n" ); - printf( "NEXT - Move to next font table entry\n" ); - printf( "^D - Exit\n" ); - printf( "\n\n\n\nPress any key to continue\n" ); -} - - - -/* - * Warning - * Issue a warning to the regarding the current status. - */ - -void -warning( s ) -char *s; -{ - move( ERROR_ROW, ERROR_COL ); - printf( "Warning: %s!\n", s ); - move( ERROR_ROW+1, ERROR_COL ); - printf( " Reissue command to override\n" ); -} diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/COPYRIGHT b/sys/arch/i386/isa/pcvt/Util/fonts/COPYRIGHT deleted file mode 100644 index 132052235480..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/COPYRIGHT +++ /dev/null @@ -1,37 +0,0 @@ -The font files: - - vt220h.808.uu, vt220h.810.uu, vt220h.814.uu, vt220h.816.uu, - vt220l.808.uu, vt220l.810.uu, vt220l.814.uu and vt220l.816.uu - -in this directory are - - Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch - - All rights reserved. - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions - are met: - 1. Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - 2. Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - 3. All advertising materials mentioning features or use of this software - must display the following acknowledgement: - This product includes software developed by - Hellmuth Michaelis and Joerg Wunsch - 4. The name authors may not be used to endorse or promote products - derived from this software without specific prior written permission. - - THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/Makefile b/sys/arch/i386/isa/pcvt/Util/fonts/Makefile deleted file mode 100644 index 45f5f5befd73..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/Makefile +++ /dev/null @@ -1,56 +0,0 @@ -FONTS = vt220l.814 vt220h.814 vt220l.808 vt220h.808 \ - vt220l.816 vt220h.816 vt220l.810 vt220h.810 - -LIBMODE = 644 -LIBOWN = bin -LIBGRP = bin -CLEANFILES= ${FONTS} - -all: $(FONTS) - -install: ${FONTS} - @if [ ! -d ${DESTDIR}${FONTDIR} ]; then \ - mkdir -p ${DESTDIR}${FONTDIR}; \ - fi - @for i in ${FONTS}; do \ - ${ECHO} "installing font $$i into ${DESTDIR}${FONTDIR}"; \ - ${INSTALL} -c -m ${LIBMODE} -o ${LIBOWN} -g ${LIBGRP} \ - $$i ${DESTDIR}${FONTDIR}; \ - done - -clean: - rm -f ${CLEANFILES} - -.include - -# this seems to be the lowest common denominator - -vt100pc.814: ${.CURDIR}/vt100pc.814.uu - uudecode ${.CURDIR}/$@.uu - -vt100sg.814: ${.CURDIR}/vt100sg.814.uu - uudecode ${.CURDIR}/$@.uu - -vt220l.814: ${.CURDIR}/vt220l.814.uu - uudecode ${.CURDIR}/$@.uu - -vt220h.814: ${.CURDIR}/vt220h.814.uu - uudecode ${.CURDIR}/$@.uu - -vt220l.808: ${.CURDIR}/vt220l.808.uu - uudecode ${.CURDIR}/$@.uu - -vt220h.808: ${.CURDIR}/vt220h.808.uu - uudecode ${.CURDIR}/$@.uu - -vt220l.816: ${.CURDIR}/vt220l.816.uu - uudecode ${.CURDIR}/$@.uu - -vt220h.816: ${.CURDIR}/vt220h.816.uu - uudecode ${.CURDIR}/$@.uu - -vt220l.810: ${.CURDIR}/vt220l.810.uu - uudecode ${.CURDIR}/$@.uu - -vt220h.810: ${.CURDIR}/vt220h.810.uu - uudecode ${.CURDIR}/$@.uu diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.808.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.808.uu deleted file mode 100644 index c9585dc1a39d..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.808.uu +++ /dev/null @@ -1,49 +0,0 @@ -begin 644 vt220h.808 -M9%1,1"`@(#X\0#@$>"(^(CQ`.`1X-@@V?$!X0'PV"#9\0'A`?#X("'Q`>'P< -M(BH<.$1\1"PP*"1X1'A$>"`@/GA$>$1^$`P\1$1\1#X("`A`0$!\/B`\($1$ -M*!`^"`@(?$!X0#X@/"`\0$`\/"(\)CQ`.`1X'"($1X'"(,$#YX1'@<`@P"''A$1'@,$CX"9%1,(B0X)"(\0#@$ -M>"(<"'Q`>'P\(CP^/$`\(C(J)B)\0'A`?"(V*CQ`.`1X(B((!Y\ -M0'A`'B`>/#Q`3#P>(!X\>$1X3!X@'CQ$1#@>(!P"/'"(<(AP#!(,<(APB'`, -M!`YPB'"(?"0(/'"(<(QB#@(<<(APC'@2/@)PB'">`A\ -M)`@\<(AX#&(.`AQPB'@,>!(^`G"(>!YP'`(<<(AX#G`\(AQPB'@><@0("'"( -M>!QR'"(<<(AX''(.`AQPB'@(?!(>$G"(>!QR'!(<<(AX"'`.$`YPB'@(!YP'!`><(AX'G`<$!```'S&QOS`P````,945'P8`'S&!G[&?```8+`8 -M+$V&`````!@X&!H,````_+8V-@0``'SD<.1\````PJ08*L8``$1$*"@0$``` -M$!`H*$1$``#&QL;&QGP```#\!@8&_````'[`P,!^````PD(D&"08`/Z"*#BJ -M_@``QE14?!@\`````/YL;.X````$_@'^!````"1^@7XD````$!`H1.X`.$2" -MJKJJ1#@``-QV`/X``/Z"Q,1H:#``&"PL1$:&_@`````VS,PV```8&`!F9@`` -M`!PT,#`PL.`!`@0($"!`@(!`(!`(!`(!`0($"!`@0/\``#\0"`0"`1@8,&`P -M&!@8&!@,!@P8&!@```X8&!@8&!@8&!@8&`X```!P&!@8&!@8&!@8&!AP```" -M`@(B$@H&``#NQM;6?```9F8\&'X8`%@D&"0X8`QX`!@`QL9^#'@`P,#XS/C` -MP%`@4`P\9CP`\&!X;'A@\``.`&9F/!@\````1"@0*$0`_&9F]F9F_`#P$'(6 -M_CINP@``````&`QX&#!@````````````_@```'R"NJJRJH)\`````'@````` -M``!X"`@``,;&``````````($?AA^($````````#_````````_P```````/\` -M``````#_````````_P````````#N9F8L&````GS.UN9\@```?-;&+^`#A$ -M_F)X8OX`<`#^8GAB_@#^`#ALQO[&`#AL$&S&_L8`#@`X;,;^Q@!P`#ALQO[& -M```<#!X`````````&!@````('CIB>#P$&'@,.`QX````?(*:HJ*:@GP`P]L\ -M9CS;PP``S%1@4$P``'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,``` -M?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#`` -M,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S& -M8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#`` -M`'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P -M`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\ -MQF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P -M``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@ -M,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,``` -M?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#`` -M,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S& -M8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#`` -M`'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P -M`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\ -MQF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@,``P -M``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,```?,9@ -M,``P``!\QF`P`#```'S&8#``,```?,9@,``P``!\QF`P`#```'S&8#``,``` -7?,9@,``P``!\QF`P`#```'S&8#``,`!@ -` -end diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.810.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.810.uu deleted file mode 100644 index 04689b1585bb..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.810.uu +++ /dev/null @@ -1,60 +0,0 @@ -begin 644 vt220h.810 -M1&143$0@("`@/CQ`.`1X(B(^(B(\0#@$>"(4"!0B?$!X0'PB%`@4(GQ`>$!\ -M/@@("`A\0'A`?!PB(BH<.$1\1$0D*#`H)'A$>$1X("`@(#YX1'A$>!X@'`(\ -M1$1\1$0^"`@("$!`0$!\/B`\("!$1$0H$#X("`@(?$!X0$`^(#P@(#Q`0$`\ -M/"(\)"(\0#@$>!PB(B(`0,!`0. -M>$1$1'@<(@P0/GA$1$1X'`(,`AQX1$1$>`0($CX"1&143$0B)#@D(CQ`.`1X -M(A0("`A\0'A`?#PB/"(\/$!`0#PB,BHF(GQ`>$!\(C8J(B(\0#@$>"(B(B(< -M?$!X0'P>("`@'GQ`>$!`'B`<`CP\0$Q$/!X@'`(\>$1X2$0>(!P"/$1$1$0X -M'B`<`CQPB'"(<`P2$A(,<(APB'`$#`0$#G"(<(AP'"(,$#YPB'"(`AP -M!`P$!`YPB'@(`AP!`@2/@)PB'@(`AP/@($"`APB'@(`AP -M#!(>$A)PB'@(`AP'!(2$AQPB'@( -M<(AX"'`>$!P0$```?,;&QOS`P,````#&5%14?!@8`'S&!@9^QL9\``!@L#`8 -M&"Q-A@`````8.!@8&!H,````_+8V-C8&!`````!\Y'#D?`````#"I!@8*L8` -M``""@D1$*"@0$```$!`H*$1$@H(``,;&QL;&QGP`````_`8&!@;\`````'[` -MP,#`?@```,)")!@8)!@```#^@B@X*(+^``#&5%14?#@0.````/YL;&QL;.X` -M````!/X!_@0``````"1^@7XD`````!`0*"A$1.X``#A$@JJZJH)$.````-QV -M`/X``````/Z"Q,1H:#```!@8+"Q$1H;^```````V2$@V`````!@8``!F9@`` -M`!PT,#`P,+#@```!`@0($"!`@```@$`@$`@$`@$```$"!`@0($#_`````#\0 -M"`0"`0`8&!@P8#`8&!@8&!@8#`8,&!@8&```#A@8&!@8&!@8&!@8&!@8&`X` -M``!P&!@8&!@8&!@8&!@8&!@8<`````("`B(2"@8``````.[&UM9\``!F9CP8 -M&'X8&`!8)!@8)#A@>`1X`!@P`,;&QGX,>`#`P/C,S/C`P```4"!0&`P\9F8\ -M`/!@>&QX8&#P``8,`&9F/!@8/`````!$*!`H1````/QF9O9F9F;\`/`0&!B_@`X;`#^8GA@8OX`,!@`_F)X8&+^`';<`!`X -M;,;^Q@`X;``0.&S&_L8`#!@`$#ALQO[&`&`P`!`X;,;^Q@``#!P,#!X````` -M`````!@8```````('CID8'@\!!@`>`PX#'@``````'R"FJ*BHIJ"?`##VSQF -M9CS;PP``````S%1@4$P``'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -M`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@ -M,#``,```?,;&8#`P`#```'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#`` -H`'S&QF`P,``P``!\QL9@,#``,```?,;&8#`P`#```'S&QF`P,``P`#`P -` -end diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.814.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.814.uu deleted file mode 100644 index 9d49552c3bbf..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.814.uu +++ /dev/null @@ -1,83 +0,0 @@ -begin 644 vt220h.814 -M`$1D5$Q$`"`@("`^````/$`X!'@`(B(^(B(````\0#@$>``B%`@4(@```'Q` -M>$!\`"(4"!0B````?$!X0'P`/@@("`@```!\0'A`?``<(B(J'`(``#A$?$1$ -M`"0H,"@D````>$1X1'@`("`@(#X```!X1'A$>``>(!P"/````$1$?$1$`#X( -M"`@(````0$!`0'P`/B`\("````!$1$0H$``^"`@("````'Q`>$!``#X@/"`@ -M````/$!`0#P`/"(\)"(````\0#@$>``<(B(B'````#Q`.`1X`!P("`@<```` -M>$1$1'@`("`@(#X```!X1$1$>``$#`0$#@```'A$1$1X`!PB#!`^````>$1$ -M1'@`'`(,`AP```!X1$1$>``$"!(^`@```$1D5$Q$`"(D."0B````/$`X!'@` -M(A0("`@```!\0'A`?``\(CPB/````#Q`0$`\`"(R*B8B````?$!X0'P`(C8J -M(B(````\0#@$>``B(B(B'````'Q`>$!\`!X@("`>````?$!X0$``'B`<`CP` -M```\0$Q$/``>(!P"/````'A$>$A$`!X@'`(\````1$1$1#@`'B`<`CP```!P -MB'"(<``,$A(2#````'"(<(AP``0,!`0.````<(APB'``'"(,$#X```!PB'"( -M<``<`@P"'````'"(<(AP``0($CX"````<(APB'``'A`<`AP```!PB'"(<``< -M(#PB'````'"(<(AP`#X"!`@(````<(APB'``'"(<(AP```!PB'"(<``<(AX" -M'````'"(<(AP``P2'A(2````<(APB'``'!(<$AP```!PB'"(<``.$!`0#@`` -M`'"(<(AP`!P2$A(<````<(APB'``'A`<$!X```!PB'"(<``>$!P0$````'"( -M>`AP``P2$A(,````<(AX"'``!`P$!`X```!PB'@(<``<(@P0/@```'"(>`AP -M`!P"#`(<````<(AX"'``!`@2/@(```!PB'@(<``>$!P"'````'"(>`AP`!P@ -M'"(<````<(AX"'``/@($"`@```!PB'@(<``<(APB'````'"(>`AP`!PB'@(< -M````<(AX"'``#!(>$A(```!PB'@(<``<$AP2'````'"(>`AP``X0$!`.```` -M<(AX"'``'!(2$AP```!PB'@(<``>$!P0'@```'"(>`AP`!X0'!`0```````` -M`'S&QL;&_,#`P``````8V]O;V]M^&!@8````?,8&!G[&QGP``````,#`8#`8 -M'#9C00`````````P<#`P,#08``````````#<9F9F9F8&!@8``````'S&\,#& -M?`````````#BMAP8.&S&````````@L;&;&PX.!`````````0.#AL;,;&@@`` -M`````,;&QL;&QL9\`````````/P&!@8&_```````````?L#`P,!^```````` -M``#&9CP8/&8\``````#^Q@!L?&P`QOX``````#P8V]O;VWX8/```````_FQL -M;&QL;&SN````````"`S^`_X,"``````````D9G[#?F8D```````````0$"@H -M1$3N```````\9L/G_^?#9CP``````````-QV`/X``````````/[&QLQL:#@P -M````````&#@L;$3&QOX``````````&[8V&X````````````8&```9F8````` -M```<-#`P,#`PL.`````````!`@0($"!`@````````(!`(!`(!`(!```````` -M``$"!`@0('\````````````_$`@$`@$``!@8&!@8,&`P&!@8&!@8&!@8&!@, -M!@P8&!@8&!@```X8&!@8&!@8&!@8&!@8&!@8&!@8&!@.``````!P&!@8&!@8 -M&!@8&!@8&!@8&!@8&!@8<````````@("`B(2"@8"``````````!LQM;6UFP` -M`````,S,>#`P_#`P,```````X'S@P'C`P&`X#'@```P8,`#&QL;&?@8,>``` -M`,#`^,S,^,#`P`````#8<.`P&`P^9F8\``````#P8'AL>&!@8/`````,&`#, -MS,QX,#`P>`````````!$*!`H1`````````#\9F9F]F9F9OP```#P$'`6_!@P -M9LZ:/@8&```````````````8#'@`&#!@``````````````````````#^```` -M````````?(*ZJKJRJH)\````````````>````````````````'@("``````` -M`,;&`````````````````````@9^"!!^8$```````````````````/\````` -M`````````/\``````````````/\``````````````/\``````````````/\` -M``````````````````#N;F9F;#@````````&?,[>]N9\P```````````?-;6 -MW-!^``````!VW`!\QL;&QGP``````';<`'@,?,S,=@```,S,`,S,2'@P,#!X -M````.&S&`,;&QL;&QGP````&#!@`QL;&QL;&?````&`P&`#&QL;&QL9\```` -M```&/FS.UM;F;/C``````'[,S,S.S,S,?@```';<`#ALQL;&QFPX````.&S& -M.&S&QL;&;#@````,&``X;,;&QL9L.````&`P`#ALQL;&QFPX````9F8`/!@8 -M&!@8&#P````\9@`\&!@8&!@8/`````P8`#P8&!@8&!@\````,!@`/!@8&!@8 -M&#P```#&Q@#^9F)X8&)F_@```#ALQ@#^9F!X8&;^````,!@,`/YF8'A@9OX` -M``!VW``0.&S&QO[&Q@```#ALQA`X;,;&_L;&````#!@`$#ALQL;^QL8````P -M&``0.&S&QO[&Q@`````,'`P,'@`````````````````8&````````````.`\ -M8,#`P,!@.`QX```\!AP&/`````````````!\@IJBHJ*:@GP```````##VSQF -M9CS;PP``````````YFQX;&9F``````!\QL9@,#``,#```````'S&QF`P,``P -M,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,``` -M````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,``````` -M?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;& -M8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P -M`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P -M``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P```` -M``!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\ -MQL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@ -M,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#`` -M,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#`` -M`````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#`````` -M`'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S& -MQF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P -M,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P -M,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,``` -M````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,``````` -M?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;& -M8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P -M`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P -M``````!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P```` -M``!\QL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\ -MQL9@,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@ -M,#``,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#`` -M,#```````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#`` -M`````'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#`````` -M`'S&QF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S& -MQF`P,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P -M,``P,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P -M,```````?,;&8#`P`#`P``````!\QL9@,#``,#```````'S&QF`P,``P,``` -=````?,;&8#`P`#`P``````!\QL9@,#``,#`````` -` -end diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.816.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.816.uu deleted file mode 100644 index 401db375c163..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220h.816.uu +++ /dev/null @@ -1,95 +0,0 @@ -begin 644 vt220h.816 -M``!$9%1,1``@("`@/@``````/$`X!'@`(B(^(B(``````#Q`.`1X`"(4"!0B -M``````!\0'A`?``B%`@4(@``````?$!X0'P`/@@("`@``````'Q`>$!\`!PB -M(BH<`@`````X1'Q$1``D*#`H)```````>$1X1'@`("`@(#X``````'A$>$1X -M`!X@'`(\``````!$1'Q$1``^"`@("```````0$!`0'P`/B`\("```````$1$ -M1"@0`#X("`@(``````!\0'A`0``^(#P@(```````/$!`0#P`/"(\)"(````` -M`#Q`.`1X`!PB(B(<```````\0#@$>``<"`@('```````>$1$1'@`("`@(#X` -M`````'A$1$1X``0,!`0.``````!X1$1$>``<(@P0/@``````>$1$1'@`'`(, -M`AP``````'A$1$1X``0($CX"``````!$9%1,1``B)#@D(@``````/$`X!'@` -M(A0("`@``````'Q`>$!\`#PB/"(\```````\0$!`/``B,BHF(@``````?$!X -M0'P`(C8J(B(``````#Q`.`1X`"(B(B(<``````!\0'A`?``>("`@'@`````` -M?$!X0$``'B`<`CP``````#Q`3$0\`!X@'`(\``````!X1'A(1``>(!P"/``` -M````1$1$1#@`'B`<`CP`````<(APB'``#!(2$@P``````'"(<(AP``0,!`0. -M``````!PB'"(<``<(@P0/@``````<(APB'``'`(,`AP``````'"(<(AP``0( -M$CX"``````!PB'"(<``>$!P"'```````<(APB'``'"`\(AP``````'"(<(AP -M`#X"!`@(``````!PB'"(<``<(APB'```````<(APB'``'"(>`AP``````'"( -M<(AP``P2'A(2``````!PB'"(<``<$AP2'```````<(APB'``#A`0$`X````` -M`'"(<(AP`!P2$A(<``````!PB'"(<``>$!P0'@``````<(APB'``'A`<$!`` -M`````'"(>`AP``P2$A(,``````!PB'@(<``$#`0$#@``````<(AX"'``'"(, -M$#X``````'"(>`AP`!P"#`(<``````!PB'@(<``$"!(^`@``````<(AX"'`` -M'A`<`AP``````'"(>`AP`!P@/"(<``````!PB'@(<``^`@0("```````<(AX -M"'``'"(<(AP``````'"(>`AP`!PB'@(<``````!PB'@(<``,$AX2$@`````` -M<(AX"'``'!(<$AP``````'"(>`AP``X0$!`.``````!PB'@(<``<$A(2'``` -M````<(AX"'``'A`<$!X``````'"(>`AP`!X0'!`0`````````````#YC8V-C -M?F!@8&```````!C;V]O;VWX8&!@8`````'S&!@9^QL9\`````````,#`8#`8 -M'#9C00```````````#!P,#`P-!@`````````````W&9F9F9F!@8&!@`````` -M``!\Y'#D?````````````.:V'!@X;,8```````````""QD1L*#@0```````` -M````$#@H;$3&@@````````#&QL;&QL;&QGP``````````/P&!@8&_``````` -M``````!^P,#`P'X``````````````,9F/!@\9CP```````#^Q@!L?'QL`,;^ -M```````\&-O;V]O;?A@8/````````/YL;&QL;&QL;.X```````````@,_@/^ -M#`@````````````D9G[#?F8D````````````$!`X*&Q$1.X````````X1(*J -MNKJJ@D0X````````````W'8`_@``````````````_H+$Q&AH,#`````````` -M`!@8+"Q$1H;^````````````=HB(=@``````````````&!@``&9F```````` -M```,'A@8&!@8&'@P```````````!`@0($"!`@```````````@$`@$`@$`@$` -M```````````!`@0($"!_```````````````_$`@$`@$````8&!@8&!@P8#`8 -M&!@8&!@8&!@8&!@8#`8,&!@8&!@8&```#A@8&!@8&!@8&!@8&!@8&!@8&!@8 -M&!@8&`X```````!P&!@8&!@8&!@8&!@8&!@8&!@8&!@8&!@8<``````````" -M`@("(A(*!@(``````````````&S&UM9L````````9F9F/!@8?A@8&``````` -M<#YP8#Q@8#````````````1"@0*$0```````````#\9F9F]F9F9F;\`````.`0```&#!@```````````````````````` -M``#^`````````````'R"NJJJLJJJ@GP``````````````'@````````````` -M`````'@("`````````#&Q@```````````````````````@9^"!!^8$`````` -M````````````````_P````````````````#_`````````````````/\````` -M````````````_P````````````````#_````````````````````````YF9B -M8C08```````````&?,[>]N9\P`````````````!\UM;V-C8?@````!VW``X;,;&QL;&;#@` -M````.&S&.&S&QL;&QFPX``````P8`#ALQL;&QL9L.`````!@,``X;,;&QL;& -M;#@`````9F8`/!@8&!@8&!@\`````!@\9@`\&!@8&!@8/``````&#!@`/!@8 -M&!@8&#P`````8#`8`#P8&!@8&!@\`````,;&`/YB8&!\8&!B_@`````X;,8` -M_F)@?&!@8OX`````8#`8`/YB8'Q@8&+^`````';<`!`X;,;&_L;&Q@`````X -M;,80.&S&QO[&QL8`````&#!@$#ALQL;^QL;&`````#`8#!`X;,;&_L;&Q@`` -M````"!@("!P`````````````````````&!@`````````````X#Q@P,#`8#@, -M>```````.`08!#@```````````````!\@IJBHJ*BFH)\``````````##VSQF -M9CS;PP``````````````YFYX;&8```````!\QL9@,#`P`#`P```````````` -M`````````````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P```````` -M?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P```` -M````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P -M````````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P -M`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@ -M,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\ -MQL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#`````` -M``!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#`` -M``````!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#`` -M,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P -M,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S& -MQF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,``````` -M`'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,``` -M`````'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P -M,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P -M,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;& -M8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P```````` -M?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P```` -M````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P -M````````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P -M`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@ -M,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#````````!\ -MQL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#`````` -M``!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#``,#`` -M``````!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P,#`` -M,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S&QF`P -M,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,````````'S& -MQF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,``````` -M`'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P,``` -M`````'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P,``P -M,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;&8#`P -M,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P````````?,;& -M8#`P,``P,````````'S&QF`P,#``,#````````!\QL9@,#`P`#`P```````` -M?,;&8#`P,``P,````````'S&QF`P,#``,#`````````````````````````` -!`,;& -` -end diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.808.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.808.uu deleted file mode 100644 index 02ad9444c478..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.808.uu +++ /dev/null @@ -1,49 +0,0 @@ -begin 644 vt220l.808 -M``````````!^@:6!O9F!?G[_V__#Y_]^;/[^_GPX$``0.'S^?#@0`#A\./[^ -MUA`X$#A\_OY\$#@``!@\/!@``/__Y\/#Y___/&;#P\/#9CS_PYF]O9G#_Q\' -M#7G-S,QX/&9F9CP8?A@X/#8R-'#PX']C?V-C9^;`&-L\Y^<\VQB`X/C^^."` -M``(./OX^#@(`&#Q^&!A^/!AF9F9F9@!F`'_;VWL;&QL`?L/\9F8_PWX``'Y^ -M?@```!@\?AA^/!C_&#Q^&!@8&``8&!@8?CP8```8#/X,&````#!@_F`P```` -M`&!@8'X````D9O]F)````!`X?/[^````_OY\.!``````````````&#P\&!@` -M&`!L;&P``````&QL_FS^;&P`,'S`?`;\,```QLP8,&;&`#AL.';]N;&?``P<+`P,##\`'C,##A@ -MP/P`>,P,.`S,>```/S`^`P,S'@`>,S`^,S,>`#\S`P8,#`P`'C, -MS'C,S'@`>,S,?`S,>```,#```#`P```P,```,#!@&#!@P&`P&````'X``'X` -M`#`8#`8,&#``/&8&#!@`&`!\QM[>WL!^`#!XS,S\S,P`_&9F?&9F_``\9L#` -MP&8\`/AL9F9F;/@`_F)H>&AB_@#^8FAX:&#P`#QFP,#.9CX`S,S,_,S,S`!X -M,#`P,#!X`!X,#`S,S'@`YFQX<'ALY@#P8&!@8F;^`,;N_M;&QL8`QN;VWL[& -MQ@`X;,;&QFPX`/QF9GQ@8/``>,S,S-QX'`#\9F9\;&;F`'C,P'@,S'@`_+0P -M,#`P>`#,S,S,S,QX`,S,S,S,>#``QL;&UO[^Q@#&QFPX.&S&`,S,S'@P,'@` -M_,R8,&3,_`!X8&!@8&!X`,!@,!@,!@(`>!@8&!@8>``0.&S&```````````` -M``#_,#`8`````````'@,?,QV`.!@8'QF9OP```!XS,#,>``<#`Q\S,Q^```` -M>,S\P'@`.&Q@^&!@\````';,S'P,^.!@;'9F9N8`,`!P,#`P>``,`!P,#,S, -M>.!@9FQX;.8`<#`P,#`P>````,S^_M;&````^,S,S,P```!XS,S,>````-QF -M9GQ@\```=LS,?`P>``#<=F!@\````'S`?`;\`!`P?#`P-AP```#,S,S,=@`` -M`,;&QGPX````QM;^_FP```#&;#ALQ@```,S,S'P,^```_)@P9/P`'#`PX#`P -M'``8&!@`&!@8`.`P,!PP,.``=MP````````0.&QLQL;^`'C,P,QX&`QX`,P` -MS,S,?@`<`'C,_,!X`'[#/`8^9C\`S`!X#'S,?@#@`'@,?,Q^`#`P>`Q\S'X` -M``!XP,!X##A^PSQF?F`\`,P`>,S\P'@`X`!XS/S`>`#,`'`P,#!X`'S&.!@8 -M&#P`X`!P,#`P>`#&.&S&_L;&`#`P`'C,_,P`'`#\8'A@_````'\,?\Q_`#YL -MS/[,S,X`>,P`>,S,>```S`!XS,QX``#@`'C,S'@`>,P`S,S,?@``X`#,S,Q^ -M``#,`,S,?`SXPQ@\9F8\&`#,`,S,S,QX`!@8?L#`?A@8.&QD\&#F_`#,S'C\ -M,/PP,/C,S/K&S\;'#AL8/!@8V'`<`'@,?,Q^`#@`<#`P,'@``!P`>,S,>``` -M'`#,S,Q^``#X`/C,S,P`_`#,[/S`````#\P,```````/P,#```P\;,WC-FS`_#QLS;-V_/`Q@8`!@8&!@``#-F -MS&8S````S&8S9LP``"*((H@BB"*(5:I5JE6J5:K;=]ONVW?;[A@8&!@8&!@8 -M&!@8&/@8&!@8&/@8^!@8V-C;V-C8V`````/XV-C8``/@8^!@8V]@;V -M-C8V-C8V-C8V-C8``/X&]C8V-C8V]@;^````-C8V-OX````8&/@8^``````` -M``#X&!@8&!@8&!\````8&!@8_P````````#_&!@8&!@8&!\8&!@`````_P`` -M`!@8&!C_&!@8&!@?&!\8&!@V-C8V-S8V-C8V-S`_```````_,#&QL;&P```!P -7&#!@>```````/#P\/``````````````` -` -end diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.810.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.810.uu deleted file mode 100644 index 7cba2cb91aa1..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.810.uu +++ /dev/null @@ -1,60 +0,0 @@ -begin 644 vt220l.810 -M`````````````'Z!I:6!@;V9@7Y^_]O;___#Y_]^;/[^?'PX.!`0````$#A\ -M_GPX$``X?'PX?/[^?#A\$!`X.'S^_GPX?````!@\/!@```#____GP\/G____ -M```\9D)"9CP``/__PYF]O9G#__\`#PQL;&QL`/&8P;,9L&,QX```````` -M?GY^?@`8&#Q^&!A^/!C_&!@\/'X8&!@8&!@8&!@8?CP\&!@`````&`S^#!@` -M`````#!@_F`P``````#`P,#`_@``````)&;_9B0``!@8/#Q^?O__``#__WY^ -M/#P8&```````````````,'AX>#`P`#`P`&QL;"@```````!L;/YL;&S^;&P` -M&'[8V'PV-OPP`,;,#!@X,&!FQ@`X;&PX,';#`P,#`S,S'@`YF9L;'AL;&;F`/!@8&!@ -M8&)F_@#&[O[^UL;&QL8`QN;F]M[.SL;&`#ALQL;&QL9L.`#\9F9F?&!@8/`` -M?,;&QL;&SGP.`/QF9F9X;&QFY@!\QL!@.`P&QGP`?EH8&!@8&!@\`,;&QL;& -MQL;&?`!F9F9F9F9F/!@`QL;&QL;6_N[&`,;&;#@0.&S&Q@#,S,S,>#`P,'@` -M_L:,&#!@PL;^`!X8&!@8&!@8'@``8&`P,!@8#`P`\#`P,#`P,##P`!`X;,8` -M``````````````````#_,#`8`````````````'@,?,S,=@#@8&!\9F9F9MP` -M````?,;`P,9\`!P,#'S,S,S,=@````!\QO[`P'P`.&Q@\&!@8&#P`````';, -MS'P,S'C@8&!L=F9F9N8`,#``<#`P,#!X``P,``P,#`S,S'C@8&!F;'AX;.8` -M<#`P,#`P,#!X`````,S^_M;6U@````#````W'9F8&#P`````'S&`Q\S,QV``!P`'@,?,S,=@`P,`!X#'S,S'8` -M````?L#`P'X&/#QF`#QF?F!@/`#,``!\QO[`P'P``'``?,;^P,!\``#,`'`P -M,#`P>``X;``X&!@8&#P``.``<#`P,#!X`,8`.&S&_L;&Q@`P,`!XS/S,S,P` -M'`#\8&!X8&#\`````'X;?MC8?P`^;,S,_LS,S,X`.&P`?,;&QL9\``#&`'S& -MQL;&?```<`!\QL;&QGP`>,P`S,S,S,QV``!P`,S,S,S,=@``Q@#&QL9^!@;\ -MQCALQL;&QFPX`,8`QL;&QL;&?``8&'[`P,#`?A@8.&QD8/A@8.;\`,S,>##\ -M,/PP,`#XS,S,^L;/QL<`#AL8&#P8&!C8<``<`'@,?,S,=@``.`!P,#`P,'@` -M`!P`?,;&QL9\```<`,S,S,S,=@!P_AP`W.;&QL8`_@#&YO;^WL[&`#QL;&P^ -M`'X````X;&QL.`!\````,``P,&#`QL9\``````#^P,``````````_@8&```` -MP\;,V#Y[PP8,#\/&S-DS9\T/`P,8&``8&#P\/!@`````,V;,9C,``````,QF -M,V;,```BB"*((H@BB"*(5:I5JE6J5:I5JMMWV^[;=]ONVW<8&!@8&!@8&!@8 -M&!@8&!CX&!@8&!@8&/@8^!@8&!@V-C8V-O8V-C8V``````#^-C8V-@```/@8 -M^!@8&!@V-C;V!O8V-C8V-C8V-C8V-C8V-@```/X&]C8V-C8V-C;V!OX````` -M-C8V-C;^`````!@8&/@8^````````````/@8&!@8&!@8&!@?`````!@8&!@8 -M_P```````````/\8&!@8&!@8&!@?&!@8&```````_P`````8&!@8&/\8&!@8 -M&!@8'Q@?&!@8V-C8V-S8V-C8V-C8W,#\`````````/S`W-C8V-C8V-O<` -M_P````````#_`/`````!F9F9V;&#`````=MP8&!@8`#P8?MO;VWX8/``X;,;&_L;&;#@` -M.&S&QL9L;&SN`!PR,!A\S,S,>`````!VV]O;;@```P9\S]O;\SY@P```'#!@ -M?&`P'````'S&QL;&QL8`````_@#^`/X`````,##\,#``_`!@,!@,&#!@`/X` -M#!@P8#`8#`#^``X;&Q@8&!@8&!@8&!@8&!@8V-AP```P,`#\`#`P`````';< -M`';<```X;&QL.````````````!@8````````````&``````/#`P,[&QL-#P< -H>&QL;&QL`````'#8&'#`^``````````\/#P\`````````````````&QL -` -end diff --git a/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.814.uu b/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.814.uu deleted file mode 100644 index 7d918bbe1c49..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/fonts/vt220l.814.uu +++ /dev/null @@ -1,83 +0,0 @@ -begin 644 vt220l.814 -M`````````````````````'Z!I8&!O9F!?@``````?O_;___#Y_]^```````` -M;/[^_OY\.!`````````0.'S^?#@0````````&#P\Y^?G&!@\```````8/'[_ -M_WX8&#P``````````!@\/!@``````/______Y\/#Y_______`````#QF0D)F -M/`````#_____PYF]O9G#_____P``'@X:,GC,S,QX```````\9F9F/!A^&!@` -M`````#\S/S`P,'#PX```````?V-_8V-C9^?FP``````8&-L\YSS;&!@````` -M`(#`X/C^^.#`@````````@8./OX^#@8"```````8/'X8&!A^/!@``````&9F -M9F9F9@!F9@``````?]O;VWL;&QL;`````'S&8#ALQL9L.`S&?``````````` -M`/[^_@``````&#Q^&!@8?CP8?@`````8/'X8&!@8&!@``````!@8&!@8&'X\ -M&``````````8#/X,&````````````#!@_F`P`````````````,#`P/X````` -M```````H;/YL*```````````$#@X?'S^_@````````#^_GQ\.#@0```````` -M```````````````````8/#P\&!@`&!@`````9F9F)```````````````;&S^ -M;&QL_FQL````&!A\QL+`?`:&QGP8&```````PL8,&#!FQ@``````.&QL.';< -MS,QV`````#`P,&````````````````P8,#`P,#`8#```````,!@,#`P,#!@P -M`````````&8\_SQF````````````&!A^&!@`````````````````&!@8,``` -M````````_@`````````````````````8&````````@8,&#!@P(````````!\ -MQL[>]N;&QGP``````!@X>!@8&!@8?@``````?,8&#!@P8,;^``````!\Q@8& -M/`8&QGP```````PWMS`?```````$#ALQL;^QL;&``````#\9F9F?&9F9OP``````#QFPL#` -MP,)F/```````^&QF9F9F9FSX``````#^9F)H>&AB9OX``````/YF8FAX:&!@ -M\```````/&;"P,#>QF8Z``````#&QL;&_L;&QL8``````#P8&!@8&!@8/``` -M````'@P,#`P,S,QX``````#F9FQL>&QL9N8``````/!@8&!@8&)F_@`````` -MQN[^_M;&QL;&``````#&YO;^WL[&QL8``````#ALQL;&QL9L.```````_&9F -M9GQ@8&#P``````!\QL;&QM;>?`P.`````/QF9F9\;&9FY@``````?,;&8#@, -MQL9\``````!^?EH8&!@8&#P``````,;&QL;&QL;&?```````QL;&QL;&;#@0 -M``````#&QL;&UM;^?&P``````,;&;#@X.&S&Q@``````9F9F9CP8&!@\```` -M``#^QHP8,&#"QOX``````#PP,#`P,#`P/```````@,#@<#@<#@8"```````\ -M#`P,#`P,##P````0.&S&`````````````````````````````/\`,#`8```` -M`````````````````'@,?,S,=@``````X&!@>&QF9F9\``````````!\QL#` -MQGP``````!P,##QLS,S,=@``````````?,;^P,9\```````X;&1@\&!@8/`` -M`````````';,S,Q\#,QX````X&!@;'9F9F;F```````8&``X&!@8&#P````` -M``8&``X&!@8&9F8\````X&!@9FQX;&;F```````X&!@8&!@8&#P````````` -M`.S^UM;6Q@``````````W&9F9F9F``````````!\QL;&QGP``````````-QF -M9F9\8&#P````````=LS,S'P,#!X```````#<=F9@8/```````````'S&`Q\S,QV -M``````#,S`!X#'S,S'8`````8#`8`'@,?,S,=@`````X;#@`>`Q\S,QV```` -M`````#QF8&8\#`8\````$#AL`'S&_L#&?```````S,P`?,;^P,9\`````&`P -M&`!\QO[`QGP``````&9F`#@8&!@8/``````8/&8`.!@8&!@\`````&`P&``X -M&!@8&#P`````QL80.&S&QO[&Q@```#AL.``X;,;&_L;&````&#!@`/YF8'Q@ -M9OX`````````S'8V?MC8;@``````/FS,S/[,S,S.`````!`X;`!\QL;&QGP` -M`````,;&`'S&QL;&?`````!@,!@`?,;&QL9\`````#!XS`#,S,S,S'8````` -M8#`8`,S,S,S,=@``````QL8`QL;&QGX&#'@`QL8`.&S&QL;&;#@```#&Q@#& -MQL;&QL;&?``````8&#QF8&!F/!@8`````#AL9&#P8&!@YOP``````&9F/!A^ -M&'X8&`````#XS,SXQ,S>S,S&``````X;&!@8?A@8&!C8<```&#!@`'@,?,S, -M=@`````,&#``.!@8&!@\`````!@P8`!\QL;&QGP`````&#!@`,S,S,S,=@`` -M````=MP`W&9F9F9F````=MP`QN;V_M[.QL8`````/&QL/@!^```````````X -M;&PX`'P````````````P,``P,&#&QGP```````````#^P,#````````````` -M`/X&!@8``````,#`QLS8,&#/@8&````&!@`&!@\ -M/#P8`````````#9LV&PV````````````V&PV;-@``````!%$$4011!%$$401 -M1!%$5:I5JE6J5:I5JE6J5:K==]UWW7?==]UWW7?==Q@8&!@8&!@8&!@8&!@8 -M&!@8&!@8&/@8&!@8&!@8&!@8&/@8^!@8&!@8V-C8V-C;V-C8V-C8V```` -M`````/XV-C8V-C8``````/@8^!@8&!@8V-C8V]@;V-C8V-C8V-C8V-C8V -M-C8V-C8V-C8``````/X&]C8V-C8V-C8V-C8V]@;^````````-C8V-C8V-OX` -M```````8&!@8&/@8^`````````````````#X&!@8&!@8&!@8&!@8&!\````` -M```8&!@8&!@8_P````````````````#_&!@8&!@8&!@8&!@8&!\8&!@8&!@` -M````````_P```````!@8&!@8&!C_&!@8&!@8&!@8&!@?&!\8&!@8&!@V-C8V -M-C8V-S8V-C8V-C8V-C8V-S`_```````````````_,#WMS` -M?````````!`X;,;&_L;&QL8```````#\9F9F?&9F9F;\````````/&;"P,#` -MP,)F/````````/AL9F9F9F9F;/@```````#^9F)H>&A@8F;^````````_F9B -M:'AH8&!@\````````#QFPL#`WL;&9CH```````#&QL;&_L;&QL;&```````` -M/!@8&!@8&!@8/````````!X,#`P,#,S,S'@```````#F9F9L>'AL9F;F```` -M````\&!@8&!@8&)F_@```````,;N_O[6QL;&QL8```````#&YO;^WL[&QL;& -M````````?,;&QL;&QL;&?````````/QF9F9\8&!@8/````````!\QL;&QL;& -MUMY\#`X`````_&9F9GQL9F9FY@```````'S&QF`X#`;&QGP```````!^?EH8 -M&!@8&!@\````````QL;&QL;&QL;&?````````,;&QL;&QL9L.!````````#& -MQL;&UM;6_NYL````````QL9L?#@X?&S&Q@```````&9F9F8\&!@8&#P````` -M``#^QH8,&#!@PL;^````````/#`P,#`P,#`P/`````````"`P.!P.!P.!@(` -M```````\#`P,#`P,#`P\`````!`X;,8````````````````````````````` -M````_P``,#`8````````````````````````>`Q\S,S,=@```````.!@8'AL -M9F9F9GP```````````!\QL#`P,9\````````'`P,/&S,S,S,=@`````````` -M`'S&_L#`QGP````````X;&1@\&!@8&#P````````````=LS,S,S,?`S,>``` -M`.!@8&QV9F9F9N8````````8&``X&!@8&!@\````````!@8`#@8&!@8&!F9F -M/````.!@8&9L>'AL9N8````````X&!@8&!@8&!@\````````````[/[6UM;6 -MQ@```````````-QF9F9F9F8```````````!\QL;&QL9\````````````W&9F -M9F9F?&!@\````````';,S,S,S'P,#!X```````#<=F9@8&#P```````````` -M?,9@.`S&?````````!`P,/PP,#`P-AP```````````#,S,S,S,QV```````` -M````QL;&QFPX$````````````,;&UM;6_FP```````````#&;#@X.&S&```` -M````````QL;&QL;&?@8,^````````/[,&#!@QOX````````.&!@8`Q\S,S,=@``````.&PX`'@,?,S,S'8````` -M`````#QF8&!F/`P&/``````0.&P`?,;^P,#&?````````,8``'S&_L#`QGP` -M`````&`P&`!\QO[`P,9\````````9@``.!@8&!@8/```````&#QF`#@8&!@8 -M&#P``````&`P&``X&!@8&!@\``````#&`!`X;,;&_L;&Q@`````X;#@`.&S& -MQO[&QL8`````&#!@`/YF8'Q@8&;^``````````!L_K(R?MC8;@```````#YL -MS,S^S,S,S,X``````!`X;`!\QL;&QL9\````````Q@``?,;&QL;&?``````` -M8#`8`'S&QL;&QGP``````#!XS`#,S,S,S,QV``````!@,!@`S,S,S,S,=@`` -M````QL8``,;&QL;&QGX&#'@`QL8`?,;&QL;&QL9\`````,;&`,;&QL;&QL;& -M?```````&!@\9F!@8&8\&!@``````#AL9&#P8&!@8.;\````````9F8\&'X8 -M?A@8&```````^,S,^,3,WLS,S,8```````X;&!@8?A@8&!@8V'`````8,&`` -M>`Q\S,S,=@``````#!@P`#@8&!@8&#P``````!@P8`!\QL;&QL9\```````8 -M,&``S,S,S,S,=@```````';<`-QF9F9F9F8`````=MP`QN;V_M[.QL;&```` -M```\;&P^`'X`````````````.&QL.`!\```````````````P,``P,&#`QL9\ -M`````````````/[`P,#```````````````#^!@8&!@```````,#`PL;,&#!@ -MW(8,&#X```#`P,+&S!@P9LZ>/@8&`````!@8`!@8&#P\/!@````````````V -M;-AL-@``````````````V&PV;-@````````11!%$$4011!%$$4011!%$5:I5 -MJE6J5:I5JE6J5:I5JMUWW7?==]UWW7?==]UWW7<8&!@8&!@8&!@8&!@8&!@8 -M&!@8&!@8&/@8&!@8&!@8&!@8&!@8^!CX&!@8&!@8&!@V-C8V-C8V]C8V-C8V -M-C8V`````````/XV-C8V-C8V-@``````^!CX&!@8&!@8&!@V-C8V-O8&]C8V -M-C8V-C8V-C8V-C8V-C8V-C8V-C8V-@``````_@;V-C8V-C8V-C8V-C8V-O8& -M_@``````````-C8V-C8V-OX``````````!@8&!@8^!CX```````````````` -M````^!@8&!@8&!@8&!@8&!@8&!\``````````!@8&!@8&!C_```````````` -M````````_Q@8&!@8&!@8&!@8&!@8&!\8&!@8&!@8&`````````#_```````` -M```8&!@8&!@8_Q@8&!@8&!@8&!@8&!@?&!\8&!@8&!@8V-C8V-C8W-C8V -M-C8V-C8V-C8V-C

- diff --git a/sys/arch/i386/isa/pcvt/Util/ispcvt/ispcvt.c b/sys/arch/i386/isa/pcvt/Util/ispcvt/ispcvt.c deleted file mode 100644 index b5b6abd17eac..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/ispcvt/ispcvt.c +++ /dev/null @@ -1,303 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - */ - -static char *id = - "@(#)ispcvt.c, 3.31, Last Edit-Date: [Tue Sep 5 16:31:24 1995]"; - -/*---------------------------------------------------------------------------* - * - * history: - * - * -hm upgraded to report pcvt compile time configuration - * -hm PCVT_INHIBIT_NUMLOCK patch from Joerg - * -hm PCVT_META_ESC patch from Joerg - * -hm PCVT_PCBURST - * -hm new ioctl VGAPCVTINFO - * -hm new CONF_ values for 3.10 - * -hm new CONF_ values for 3.20 - * -hm removed PCVT_FAKE_SYSCONS10 - * -hm added PCVT_PORTIO_DELAY - * -hm removed PCVT_386BSD - * -hm add -d option to specify a device - * -hm PCVT_XSERVER -> XSERVER - * -hm PCVT_MDAFASTSCROLL - * -hm removed PCVT_USL_VT_COMPAT - * - *---------------------------------------------------------------------------*/ - -#include -#include -#include - -#define DEFAULTFD 0 - -main(argc,argv) -int argc; -char *argv[]; -{ - extern int optind; - extern int opterr; - extern char *optarg; - - struct pcvtid pcvtid; - struct pcvtinfo pcvtinfo; - int c; - char *p; - int verbose = 0; - int config = 0; - int dflag = 0; - int fd; - char *device; - - while( (c = getopt(argc, argv, "vcd:")) != -1) - { - switch(c) - { - case 'v': - verbose = 1; - break; - - case 'c': - config = 1; - break; - - case 'd': - device = optarg; - dflag = 1; - break; - - case '?': - default: - usage(); - break; - } - } - - if(dflag) - { - if((fd = open(device, O_RDWR)) == -1) - { - if(verbose) - { - char buffer[80]; - strcpy(buffer,"ERROR opening "); - strcat(buffer,device); - perror(buffer); - } - exit(1); - } - } - else - { - fd = DEFAULTFD; - } - - if(ioctl(fd, VGAPCVTID, &pcvtid) == -1) - { - if(verbose) - perror("ispcvt - ioctl VGAPCVTID failed, error"); - exit(1); - } - - if(!strcmp(pcvtid.name, PCVTIDNAME)) - { - if(pcvtid.rmajor == PCVTIDMAJOR) - { - if(pcvtid.rminor != PCVTIDMINOR) - { - if(verbose) - fprintf(stderr,"ispcvt - minor revision: expected %d, got %d\n", PCVTIDMINOR, pcvtid.rminor); - exit(4); /* minor revision mismatch */ - } - } - else - { - if(verbose) - fprintf(stderr,"ispcvt - major revision: expected %d, got %d\n", PCVTIDMAJOR, pcvtid.rmajor); - exit(3); /* major revision mismatch */ - } - } - else - { - if(verbose) - fprintf(stderr,"ispcvt - name check: expected %s, got %s\n", PCVTIDNAME, pcvtid.name); - exit(2); /* name mismatch */ - } - - if(verbose) - { - fprintf(stderr,"\nispcvt: kernel and utils match, driver name [%s], release [%1.1d.%02.2d]\n\n",pcvtid.name,pcvtid.rmajor,pcvtid.rminor); - } - - if(config == 0) - exit(0); - - if(ioctl(fd, VGAPCVTINFO, &pcvtinfo) == -1) - { - if(verbose) - perror("ispcvt - ioctl VGAPCVTINFO failed, error"); - exit(1); - } - - if(verbose) - { - switch(pcvtinfo.opsys) - { - case CONF_NETBSD: - p = "PCVT_NETBSD"; - break; - - case CONF_FREEBSD: - p = "PCVT_FREEBSD"; - break; - - default: - case CONF_UNKNOWNOPSYS: - p = "UNKNOWN"; - break; - - } - fprintf(stderr,"Operating System = %s\t", p); - fprintf(stderr,"OS Release Id = %u\n", pcvtinfo.opsysrel); - fprintf(stderr,"PCVT_NSCREENS = %u\t\t", pcvtinfo.nscreens); - fprintf(stderr,"PCVT_SYSBEEPF = %u\n", pcvtinfo.sysbeepf); - fprintf(stderr,"PCVT_PCBURST = %u\t\t", pcvtinfo.pcburst); - fprintf(stderr,"PCVT_KBD_FIFO_SZ = %u\n\n", pcvtinfo.kbd_fifo_sz); - - /* config booleans */ - - fprintf(stderr,"PCVT_132GENERIC = %s", - (pcvtinfo.compile_opts & CONF_132GENERIC) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_24LINESDEF = %s", - (pcvtinfo.compile_opts & CONF_24LINESDEF) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_BACKUP_FONTS = %s", - (pcvtinfo.compile_opts & CONF_BACKUP_FONTS) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_CTRL_ALT_DEL = %s", - (pcvtinfo.compile_opts & CONF_CTRL_ALT_DEL) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_EMU_MOUSE = %s", - (pcvtinfo.compile_opts & CONF_EMU_MOUSE) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_INHIBIT_NUMLOCK = %s", - (pcvtinfo.compile_opts & CONF_INHIBIT_NUMLOCK) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_KEYBDID = %s", - (pcvtinfo.compile_opts & CONF_KEYBDID) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_KBD_FIFO = %s", - (pcvtinfo.compile_opts & CONF_KBD_FIFO) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_MDAFASTSCROLL = %s", - (pcvtinfo.compile_opts & CONF_MDAFASTSCROLL) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_META_ESC = %s", - (pcvtinfo.compile_opts & CONF_META_ESC) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_NOFASTSCROLL = %s", - (pcvtinfo.compile_opts & CONF_NOFASTSCROLL) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_NO_LED_UPDATE = %s", - (pcvtinfo.compile_opts & CONF_NO_LED_UPDATE) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_NULLCHARS = %s", - (pcvtinfo.compile_opts & CONF_NULLCHARS) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_PALFLICKER = %s", - (pcvtinfo.compile_opts & CONF_PALFLICKER) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_PORTIO_DELAY = %s", - (pcvtinfo.compile_opts & CONF_PORTIO_DELAY) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_PRETTYSCRNS = %s", - (pcvtinfo.compile_opts & CONF_PRETTYSCRNS) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_SCREENSAVER = %s", - (pcvtinfo.compile_opts & CONF_SCREENSAVER) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_SETCOLOR = %s", - (pcvtinfo.compile_opts & CONF_SETCOLOR) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_SHOWKEYS = %s", - (pcvtinfo.compile_opts & CONF_SHOWKEYS) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_SIGWINCH = %s", - (pcvtinfo.compile_opts & CONF_SIGWINCH) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_SW0CNOUTP = %s", - (pcvtinfo.compile_opts & CONF_SW0CNOUTP) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_USEKBDSEC = %s", - (pcvtinfo.compile_opts & CONF_USEKBDSEC) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_VT220KEYB = %s", - ((u_int)pcvtinfo.compile_opts & (u_int)CONF_VT220KEYB) ? "ON" : "OFF"); - next(); - fprintf(stderr,"PCVT_WAITRETRACE = %s", - (pcvtinfo.compile_opts & CONF_WAITRETRACE) ? "ON" : "OFF"); - next(); - fprintf(stderr,"XSERVER = %s", - (pcvtinfo.compile_opts & CONF_XSERVER) ? "ON" : "OFF"); - - fprintf(stderr,"\n\n"); - } - else /* !verbose */ - { - fprintf(stderr,"BSD Version = %u\n", pcvtinfo.opsys); - fprintf(stderr,"PCVT_NSCREENS = %u\n", pcvtinfo.nscreens); - fprintf(stderr,"PCVT_SYSBEEPF = %u\n", pcvtinfo.sysbeepf); - fprintf(stderr,"Compile options = 0x%08X\n", pcvtinfo.compile_opts); - } -} - -usage() -{ - fprintf(stderr,"\nispcvt - verify current video driver is the pcvt-driver\n"); - fprintf(stderr," usage: ispcvt [-v] [-c] [-d device]\n"); - fprintf(stderr,"options: -v be verbose\n"); - fprintf(stderr," -c print compile time configuration\n"); - fprintf(stderr," -d use devicefile for verification\n\n"); - exit(5); -} - -next() -{ - static int i = 0; - - fprintf(stderr, "%s", (i == 0) ? "\t\t" : "\n"); - - i = ~i; -} - -/* EOF */ diff --git a/sys/arch/i386/isa/pcvt/Util/kbdio/Makefile b/sys/arch/i386/isa/pcvt/Util/kbdio/Makefile deleted file mode 100644 index 39bb29e195d6..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/kbdio/Makefile +++ /dev/null @@ -1,24 +0,0 @@ -PROG= kbdio -SRCS= kbdio.y lex.l - -#YACC= bison -#YFLAGS+= -yd # Bison only - -YFLAGS+= -v # verbose -LFLAGS+= -I - -LDADD= -lm -ly -ll -DPADD= ${LIBM} ${LIBY} ${LIBL} - -MKMAN= no -MKPIC= no - -CFLAGS+= -I. #-g -YFLAGS+= -d - -CLEANFILES+= y.tab.h -CLEANFILES+= y.output # comment file from bison - -.include - -lex.o: y.tab.h lex.l diff --git a/sys/arch/i386/isa/pcvt/Util/kbdio/kbdio.y b/sys/arch/i386/isa/pcvt/Util/kbdio/kbdio.y deleted file mode 100644 index f0caf8d19f80..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/kbdio/kbdio.y +++ /dev/null @@ -1,343 +0,0 @@ -/* Hello emacs, this should be edited in -*- Fundamental -*- mode */ -%{ -/* $NetBSD: kbdio.y,v 1.4 1997/11/01 06:49:38 lukem Exp $ */ -/* - * Copyright (c) 1994,1995 Joerg Wunsch - * - * All rights reserved. - * - * This program is free software. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Joerg Wunsch - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#include -#include -#include -#include -#include -#include - -#ifdef __NetBSD__ -#include -#endif - -#define KBD_DELAY \ - { u_char x = inb(0x84); } \ - { u_char x = inb(0x84); } \ - { u_char x = inb(0x84); } \ - { u_char x = inb(0x84); } \ - { u_char x = inb(0x84); } \ - { u_char x = inb(0x84); } - -#define YYDEBUG 1 - -void yyerror(const char *msg); - -static void help(int), status(void), data(int), kbd(int), cmdbyte(int), - kbc(int), whatMCA(void); -static int kbget(void); -%} - -%union { - int num; -} - -%token NEWLINE -%token ALL CMD DATA DEFAULTS ECHOC ENABLE EXPR HELP ID LED -%token MAKE ONLY RELEASE RESEND RESET SCAN STATUS TYPEMATIC -%token WHAT -%token NUM - -%type expr opr - -%% - -interpret: lines ; - -lines: line - | lines line - ; - -line: statements NEWLINE - | NEWLINE - | error NEWLINE { fprintf(stderr, "bing!\n"); } - ; - -statements: statement - | statements ';' statement - ; - -statement: '?' { help(0); } - | HELP { help(0); } - | HELP EXPR { help(1); } - | STATUS '?' { status(); } - | WHAT '?' { whatMCA(); } - | DATA '?' { data(kbget()); } - | LED '=' NUM { kbd(0xed); kbd($3); } - | ECHOC { kbd(0xee); kbget(); } - | SCAN '=' NUM { kbd(0xf0); kbd($3); - if($3 == 0) data(kbget()); } - | SCAN '?' { kbd(0xf0); kbd(0); data(kbget()); } - | ID '?' { kbd(0xf2); data(kbget()); - data(kbget()); } - | TYPEMATIC '=' NUM ',' NUM - { kbd(0xf3); - if($3 > 1000) $3 = 1000; - if($5 > 30) $5 = 30; - if($5 < 2) $5 = 2; - kbd( - (int) - (8.0 * log(30.0 / (double)$5) - / log(2)) - | ((($3 / 250) - 1) * 32) - ); - } - | ENABLE { kbd(0xf4); } - | DEFAULTS { kbd(0xf6); } - | ALL TYPEMATIC { kbd(0xf7); } - | ALL MAKE RELEASE { kbd(0xf8); } - | ALL MAKE ONLY { kbd(0xf9); } - | ALL TYPEMATIC MAKE RELEASE - { kbd(0xfa); } - | NUM TYPEMATIC { kbd(0xfb); kbd($1); } - | NUM MAKE RELEASE { kbd(0xfc); kbd($1); } - | NUM MAKE ONLY { kbd(0xfd); kbd($1); } - | RESEND { kbd(0xfe); } - | RESET { kbd(0xff); } - | CMD '?' { kbc(0x20); cmdbyte(kbget()); } - | CMD '=' expr { kbc(0x60); kbd($3); } - | /* lambda */ - ; - -expr: opr { $$ = $1; } - | expr '+' opr { $$ = $1 | $3; } - | expr '-' opr { $$ = $1 & ~($3); } - ; - -opr: NUM { $$ = $1; } - | CMD { kbc(0x20); $$ = kbget(); } - ; - -%% - -static void -help(int topic) { - switch(topic) { - case 0: - printf( - "Input consists of lines, containing one or more semicolon-separated\n" - "statements. Numbers are implicitly hexadecimal, append a dot for\n" - "decimal numbers. Valid statements include:\n" - "help [expr]; give help [to expression syntax]\n" - "status ? interpret kbd ctrl status byte\n" - "what ? check for MCA type 1 or 2 motherboard controller\n" - "data ? get one byte of data\n" - "led = NUM set kbd LEDs\n" - "echo send kbd ECHO command\n" - "scan = NUM; scan ? set scan code set; return current set\n" - "id ? get two id bytes\n" - "typematic=delay,rate set typematic delay(ms)&rate(1/s)\n" - "enable; defaults enable kbd; back to defaults\n" - "all typematic make all keys typematic\n" - "all make release make all keys sending make/release\n" - "all make only make all keys sending make only\n" - "all typematic make release make all keys typematic & make/release\n" - "NUM typematic make specific key typematic\n" - "NUM make release make specific key sending make/release\n" - "NUM make only make specific key sending make only\n" - "resend; reset resend last byte from kbd; reset kbd\n" - "cmd ? fetch kbd ctrl command byte\n" - "cmd = expr set kbd ctrl command byte\n"); - break; - - case 1: - printf( - "Expressions can either consist of a number, possibly followed\n" - "by a + or - sign and bit values in numeric or symbolic form.\n" - "Symbolic bit values are:\n" - "scconv ignpar clklow ovrinh test irq\n" - "\n"); - break; - - case 2: - fprintf(stderr, "usage: kbdio [-d] [-f devname]\n"); - break; - } -} - -static void -status(void) { - int c = inb(0x64); - if(c&0x80) printf("parity error | "); - if(c&0x40) printf("rx timeout | "); - if(c&0x20) printf("tx timeout | "); - if(c&0x10) printf("kbd released "); - else printf("kbd locked "); - if(c&0x08) printf("| cmd last sent "); - else printf("| data last sent "); - if(c&0x04) printf("| power-on "); - else printf("| test ok "); - if(c&0x02) printf("| ctrl write busy "); - else printf("| ctrl write ok "); - if(c&0x01) printf("| ctrl read ok\n"); - else printf("| ctrl read empty\n"); -} - -/* see: Frank van Gilluwe, "The Undocumented PC", Addison Wesley 1994, pp 273*/ - -static void -whatMCA(void) { - int new, sav; - kbc(0x20); /* get command byte */ - sav = kbget(); /* sav = command byte */ - kbc(0x60); /* set command byte */ - kbd(sav | 0x40); /* set keyboard xlate bit */ - kbc(0x20); /* get keyboard command */ - new = kbget(); /* new = command byte */ - kbc(0x60); /* set command byte */ - kbd(sav); /* restore command byte */ - if(new & 0x40) - printf("Hmm - looks like MCA type 1 motherboard controller\n"); - else - printf("Hmm - looks like MCA type 2 motherboard controller\n"); -} - -static void -kbd(int d) { - int i = 100000; - while(i && (inb(0x64) & 2)) i--; - if(i == 0) { printf("kbd write: timed out\n"); return; } - outb(0x60, d); -} - -static void -kbc(int d) { - int i = 100000; - while(i && (inb(0x64) & 2)) i--; - if(i == 0) { printf("ctrl write: timed out\n"); return; } - outb(0x64, d); -} - -static int -kbget(void) { - int i, c; - for(;;) { - i = 10000; - while(i && (inb(0x64) & 1) == 0) i--; - if(i == 0) { printf("data read: timed out\n"); return -1; } - KBD_DELAY - c = (unsigned char)inb(0x60); - switch(c) { - case 0: case 0xff: - printf("got kbd overrun\n"); break; - case 0xaa: - printf("got self-test OK\n"); break; - case 0xee: - printf("got ECHO byte\n"); break; - case 0xfa: - printf("got ACK\n"); break; - case 0xfc: - printf("got self-test FAIL\n"); break; - case 0xfd: - printf("got internal failure\n"); break; - case 0xfe: - printf("got RESEND request\n"); break; - default: - goto done; - } - } -done: - return c; -} - -static void -cmdbyte(int d) { - if(d&0x40) printf("scan conv "); - else printf("pass thru "); - if(d&0x20) printf("| ign parity "); - else printf("| check parity "); - if(d&0x10) printf("| kbd clk low "); - else printf("| enable kbd "); - if(d&0x08) printf("| override kbd inh "); - if(d&0x04) printf("| test ok "); - else printf("| power-on "); - if(d&0x01) printf("| irq 1 enable\n"); - else printf("| no irq\n"); -} - -static void -data(int d) { - if(d < 0) return; - printf("data: 0x%02x\n", d); -} - -void yyerror(const char *msg) { - fprintf(stderr, "yyerror: %s\n", msg); -} - -int main(int argc, char **argv) { - int fd, c; - const char *devname = "/dev/console"; - - while((c = getopt(argc, argv, "df:")) != -1) - switch(c) { - case 'd': - yydebug = 1; - break; - - case 'f': - devname = optarg; - break; - - case '?': - default: - help(2); - return 2; - } - argc -= optind; - argv += optind; - if(argc > 0) { - help(2); - return 2; - } - - if((fd = open(devname, O_RDONLY)) < 0) { - perror("open(kbd)"); - return 1; - } - - if(ioctl(fd, KDENABIO, 0) < 0) { - perror("ioctl(KDENABIO)"); - return 1; - } - yyparse(); - - (void)ioctl(fd, KDDISABIO, 0); - return 0; -} - diff --git a/sys/arch/i386/isa/pcvt/Util/kbdio/lex.l b/sys/arch/i386/isa/pcvt/Util/kbdio/lex.l deleted file mode 100644 index fc290c635c6c..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/kbdio/lex.l +++ /dev/null @@ -1,86 +0,0 @@ -%{ -/* $NetBSD: lex.l,v 1.3 1997/10/13 14:22:25 lukem Exp $ */ -/* - * Copyright (c) 1994,1995 Joerg Wunsch - * - * All rights reserved. - * - * This program is free software. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Joerg Wunsch - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#include -#include - -#include "y.tab.h" - -extern YYSTYPE yylval; - -%} - -D [0-9a-fA-F] - -%% - -all { return ALL; } -cmd { return CMD; } -data { return DATA; } -defaults { return DEFAULTS; } -echo { return ECHOC; } -enable { return ENABLE; } -expr { return EXPR; } -help { return HELP; } -id { return ID; } -led { return LED; } -make { return MAKE; } -only { return ONLY; } -release { return RELEASE; } -resend { return RESEND; } -reset { return RESET; } -scan { return SCAN; } -status { return STATUS; } -typematic { return TYPEMATIC; } -what { return WHAT; } - - /* numeric values */ -clklow { yylval.num = 0x10; return NUM; } -ignpar { yylval.num = 0x20; return NUM; } -irq { yylval.num = 0x01; return NUM; } -ovrinh { yylval.num = 0x08; return NUM; } -scconv { yylval.num = 0x40; return NUM; } -test { yylval.num = 0x04; return NUM; } - -{D}({D}*)\. { sscanf(yytext, "%d", &yylval.num); return NUM; } - -{D}({D}*) { sscanf(yytext, "%x", &yylval.num); return NUM; } - -[ \t] { /* ignore */ } - -\n { return NEWLINE; } - -. { return yytext[0]; } diff --git a/sys/arch/i386/isa/pcvt/Util/kcon/Makefile b/sys/arch/i386/isa/pcvt/Util/kcon/Makefile deleted file mode 100644 index d8f706a43017..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/kcon/Makefile +++ /dev/null @@ -1,11 +0,0 @@ -PROG= kcon -DEVICE= /dev/ttyv0 -CFLAGS+= -I${.CURDIR}/../keycap -DKEYB_DEVICE=\"${DEVICE}\" - -MKMAN= no - -KEYCAPOBJDIR!= cd ${.CURDIR}/../keycap; make print-objdir - -LDADD= -L${KEYCAPOBJDIR} -lkeycap - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/kcon/kcon.c b/sys/arch/i386/isa/pcvt/Util/kcon/kcon.c deleted file mode 100644 index f543b61a2fe4..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/kcon/kcon.c +++ /dev/null @@ -1,753 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis - * - * Copyright (c) 1992, 1993 Holger Veit. - * - * All rights reserved. - * - * This code is derived from software contributed to 386BSD by - * Holger Veit - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis and Holger Veit - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - */ - -static char *id = - "@(#)kcon.c, 3.30, Last Edit-Date: [Fri Jun 30 20:11:42 1995]"; - -/*---------------------------------------------------------------------------* - * - * kcon.c Keyboard control and remapping - * ---------------------------------------------- - * - * based on "keymap" which was written by - * Holger Veit (veit@du9ds3.uni-duisburg.de) - * - * -hm a first rewrite - * -hm rewrite for pcvt 2.0 distribution - * -hm adding show current typematic values - * -hm hex/octal/esc output choices - * -hm remapping debugging - * -hm garbage output for remapped keys bugfix - * -hm patch from Lon Willet, adding -R - * - *---------------------------------------------------------------------------*/ - -#include -#include -#include -#include -#include - -#include "keycap.h" - -int Rf = 0; -int df = 0; -int lf = 0; -int mf = 0; -int of = 0; -int pf = 0; -int rf = 0; -int tf = 0; -int xf = 0; -int sf = 0; - -/*---------------------------------------------------------------------------* - * main entry - *---------------------------------------------------------------------------*/ -main(argc, argv) -int argc; -char *argv[]; -{ - extern char *optarg; - extern int optind; - - int c = 0; - - int errf = 0; - - int rate = -1; - int delay = -1; - char *map; - int kbfd; - - while((c = getopt(argc, argv, "Rd:lm:opr:st:x")) != -1) - { - switch(c) - { - case 'R': - Rf = 1; - break; - - case 'd': - df = 1; - delay = atoi(optarg); - break; - - case 'l': - lf = 1; - break; - - case 'm': - mf = 1; - map = optarg; - break; - - case 'o': - if(xf) - errf = 1; - else - of = 1; - break; - - case 'p': - pf = 1; - break; - - case 'r': - rf = 1; - rate = atoi(optarg); - break; - - case 's': - sf = 1; - break; - - case 't': - if(*optarg == '+') - tf = 1; - else if(*optarg == '-') - tf = -1; - else - errf = 1; - break; - - case 'x': - if(of) - errf = 1; - else - xf = 1; - break; - - default: - usage(); - } - } - - if((Rf == 0 && df == 0 && lf == 0 && tf == 0 && sf == 0 && - rf == 0 && mf == 0 ) || errf) - { - usage(); - } - - if((kbfd = open(KEYB_DEVICE, 0)) < 0) - { - perror("kcon: keyboard open failiure"); - exit(1); - } - - if(sf) - { - showtypeamatic(kbfd); - exit(0); - } - - if(lf) - { - listcurrent(kbfd); - exit(0); - } - - if (Rf) - { - if (ioctl(kbfd, KBDRESET, 0) < 0) { - perror ("kcon: ioctl KBDRESET failed"); - exit (1); - } - } - - if(tf) - { - setrepeat(kbfd, tf); - } - - if(df || rf) - { - if(delay > 3) - { - fprintf(stderr,"Delay value (%d) out of range, possible values are 0..3!\n",delay); - exit(1); - } - if(rate > 31) - { - fprintf(stderr,"Rate value (%d) out of range, possible values are 0..31!\n",rate); - exit(1); - } - settypeam(kbfd, delay, rate); - } - - if(mf) - { - remapkeys(kbfd, map); - } - - close(kbfd); - exit(0); -} - -/*---------------------------------------------------------------------------* - * display usage info & exit - *---------------------------------------------------------------------------*/ -usage() -{ - fprintf(stderr, "\nkcon: keyboard control and remapping utility for pcvt video driver\n"); - fprintf(stderr, "usage: [-R] [-d delay] [-l] [-m map] [-o] [-p] [-r rate] [-t +/-] [-x]\n"); - fprintf(stderr, " -R full reset of keyboard\n"); - fprintf(stderr, " -d delay until a key is repeated (range: 0...3 => 250...1000ms)\n"); - fprintf(stderr, " -l produce listing of current keyboard mapping\n"); - fprintf(stderr, " -m set keyboard remapping from a keycap entry\n"); - fprintf(stderr, " -o set octal output for listing\n"); - fprintf(stderr, " -p pure, don't display escape as 'ESC' for listing\n"); - fprintf(stderr, " -r chars/second repeat value (range: 0...31 => 30...2 chars/sec)\n"); - fprintf(stderr, " -s show, display the current keyboard typematic values\n"); - fprintf(stderr, " -t switch repeat on(+) or off(-)\n"); - fprintf(stderr, " -x set hexadecimal output for listing\n\n"); - exit(1); -} - -/*---------------------------------------------------------------------------* - * convert control char in string to printable values - *---------------------------------------------------------------------------*/ -char *showcntrl(s) -u_char *s; -{ - static char res_str[80]; - static char conv_buf[80]; - int i; - - res_str[0] = '\0'; - - for(i = 0; s[i]; i++) - { - if(((s[i] > 0x20) && (s[i] <= 0x7e)) || ((s[i] >= 0xa0) && (s[i] <= 0xff))) - { - conv_buf[0] = s[i]; - conv_buf[1] = '\0'; - } - else if((s[i] == 0x1b) && (pf == 0)) - { - strcpy(conv_buf,"ESC "); - } - else if(of) - { - sprintf(conv_buf,"\\%03.3o ", s[i]); - } - else - { - sprintf(conv_buf,"0x%02.2X ", s[i]); - } - strcat(res_str, conv_buf); - } - return(res_str); -} - -/*---------------------------------------------------------------------------* - * list the current keyboard mapping - *---------------------------------------------------------------------------*/ -listcurrent(kbfd) -int kbfd; -{ - static char *keytypetab[] = { - "NONE ", - "SHIFT ", - "ALT/META ", - "NUMLOCK ", - "CONTROL ", - "CAPSLOCK ", - "ASCII ", - "SCROLL ", - "FUNCTION ", - "KEYPAD ", - "BREAK ", - "ALTGR ", - "SHIFTLOCK", - "CURSOR ", - "RETURN " - }; - - struct kbd_ovlkey keyboardmap[KBDMAXKEYS]; - struct kbd_ovlkey *kbmapp; - int keytype; - int altgr_defined; - int i; - - altgr_defined = 0; - kbmapp = keyboardmap; - - for (i = 0; i < KBDMAXKEYS; i++) - { - kbmapp->keynum = i; - - if(ioctl(kbfd, KBDGCKEY, kbmapp) < 0) - { - perror("kcon: ioctl KBDGCKEY failed"); - exit(1); - } - - if((kbmapp->type & KBD_MASK) == KBD_ALTGR) - altgr_defined = i; - - kbmapp++; - } - - if(altgr_defined) - { - printf("S Key KeyType Normal Shift Control Altgr \n"); - printf("- --- --------- --------------- --------------- --------------- ---------------\n"); - } - else - { - printf("S Key KeyType Normal Shift Control \n"); - printf("- --- --------- --------------- --------------- ---------------\n"); - } - - kbmapp = &keyboardmap[1]; - - for(i = 1; i < KBDMAXKEYS; i++) - { - keytype = kbmapp->type; - - if(keytype) - { - if(keytype & KBD_OVERLOAD) - printf("! %3.3d %9.9s ", i, keytypetab[keytype & KBD_MASK]); - else - printf("- %3.3d %9.9s ", i, keytypetab[keytype & KBD_MASK]); - - switch(keytype & KBD_MASK) - { - - case KBD_NUM: - case KBD_ASCII: - case KBD_FUNC: - case KBD_KP: - case KBD_CURSOR: - case KBD_RETURN: /* ??? */ - - if(kbmapp->subu == KBD_SUBT_STR) - printf("%-15s ",showcntrl(kbmapp->unshift)); - else - printf("Function() "); - - if(kbmapp->subs == KBD_SUBT_STR) - printf("%-15s ",showcntrl(kbmapp->shift)); - else - printf("Function() "); - - if(kbmapp->subc == KBD_SUBT_STR) - printf("%-15s ",showcntrl(kbmapp->ctrl)); - else - printf("Function() "); - - if(altgr_defined) - { - if(kbmapp->suba == KBD_SUBT_STR) - printf("%-15s ",showcntrl(kbmapp->altgr)); - else - printf("Function() "); - } - break; - } - putchar('\n'); - } - kbmapp++; - } -} - -/*---------------------------------------------------------------------------* - * show delay and rate values for keyboard - *---------------------------------------------------------------------------*/ -showtypeamatic(kbfd) -int kbfd; -{ - static char *delaytab[] = { - "250", - "500", - "750", - "1000" - }; - - static char *ratetab[] = { - "30.0", - "26.7", - "24.0", - "21.8", - "20.0", - "18.5", - "17.1", - "16.0", - "15.0", - "13.3", - "12.0", - "10.9", - "10.0", - "9.2", - "8.6", - "8.0", - "7.5", - "6.7", - "6.0", - "5.5", - "5.0", - "4.6", - "4.3", - "4.0", - "3.7", - "3.3", - "3.0", - "2.7", - "2.5", - "2.3", - "2.1", - "2.0" - }; - - int cur_typemat_val; - int delay, rate; - - if((ioctl(kbfd, KBDGTPMAT, &cur_typemat_val)) < 0) - { - perror("kcon: ioctl KBDGTPMAT failed"); - exit(1); - } - - delay = ((cur_typemat_val & 0x60) >> 5); - rate = cur_typemat_val & 0x1f; - - printf("\nDisplaying the current keyboard typematic values:\n\n"); - printf("The delay-until-repeat time is [ %s ] milliseconds\n",delaytab[delay]); - printf("The repeat-rate is [ %s ] characters per second\n\n",ratetab[rate]); -} - -/*---------------------------------------------------------------------------* - * set repeat feature on/off - *---------------------------------------------------------------------------*/ -setrepeat(kbfd, tf) -int kbfd; -int tf; -{ - int srepsw_val; - - if(tf == 1) - srepsw_val = KBD_REPEATON; - else - srepsw_val = KBD_REPEATOFF; - - if(ioctl(kbfd, KBDSREPSW, &srepsw_val) < 0) - { - perror("kcon: ioctl KBDREPSW failed"); - exit(1); - } -} - -/*---------------------------------------------------------------------------* - * set delay and rate values for keyboard - *---------------------------------------------------------------------------*/ -settypeam(kbfd, delay, rate) -int kbfd; -int delay; -int rate; -{ - int cur_typemat_val; - int new_typemat_val; - - if((ioctl(kbfd, KBDGTPMAT, &cur_typemat_val)) < 0) - { - perror("kcon: ioctl KBDGTPMAT failed"); - exit(1); - } - - if(delay == -1) - delay = (cur_typemat_val & 0x60); - else - delay = ((delay << 5) & 0x60); - - if(rate == -1) - rate = (cur_typemat_val & 0x1f); - else - rate &= 0x1f; - - new_typemat_val = delay | rate; - - if((ioctl(kbfd, KBDSTPMAT, &new_typemat_val)) < 0) - { - perror("kcon: ioctl KBDSTPMAT failed"); - exit(1); - } -} - -/*---------------------------------------------------------------------------* - * remap keyboard from keycap entry - *---------------------------------------------------------------------------*/ -remapkeys(kbfd, map) -int kbfd; -char *map; -{ - char cap_entry[1024]; - int ret; - char keyflag[128]; - int i; - - /* try to find the entry */ - - ret = kgetent(cap_entry, map); - - if(ret == -1) - { - fprintf(stderr, "kcon: keycap database not found or not accessible!\n"); - exit(1); - } - else if(ret == 0) - { - fprintf(stderr, "kcon: keycap entry [%s] not found in database!\n", map); - exit(1); - } - - /* set default mapping */ - - if((ioctl(kbfd, KBDDEFAULT)) < 0) - { - perror("kcon: ioctl KBDDEFAULT failed"); - exit(1); - } - - /* DE flag present? */ - - if(kgetflag("de")) - return; - - for(i = 0; i < KBDMAXKEYS; i++) - keyflag[i] = 0; - - set_lock(keyflag, kbfd); - - set_shift(keyflag, kbfd); - - set_char(keyflag, kbfd); -} - -/*---------------------------------------------------------------------------* - * care for lock keys - *---------------------------------------------------------------------------*/ -set_lock(keyflag, kbfd) -char keyflag[]; -int kbfd; -{ - int i, j; - char cap[16]; - struct kbd_ovlkey entry; - - struct { - char *ch; - u_short typ; - } lock[] = - { - "ca", KBD_CAPS, - "sh", KBD_SHFTLOCK, - "nl", KBD_NUMLOCK, - "sc", KBD_SCROLL - }; - - - for(i = 0; i < 4; i++) - { - int n; - - sprintf(cap, "%s", lock[i].ch); - - n = kgetnum(cap); - - if(n > 0) - { - if (keyflag[n]) - { - fprintf(stderr,"kcon: duplicate key definition for key [%d]!\n",n); - exit(1); - } - keyflag[n] = 1; - - entry.keynum = n; - entry.type = lock[i].typ; - - if((ioctl(kbfd, KBDSCKEY, &entry)) < 0) - { - perror("kcon: ioctl KBDSCKEY failed"); - exit(1); - } - } - } -} - -/*---------------------------------------------------------------------------* - * care for shifting keys - *---------------------------------------------------------------------------*/ -set_shift(keyflag, kbfd) -char keyflag[]; -int kbfd; -{ - int i, j; - char cap[16]; - struct kbd_ovlkey entry; - - struct { - char ch; - u_short typ; - } shift[] = - { - 'm', KBD_META, - 'l', KBD_ALTGR, - 'h', KBD_SHIFT, - 't', KBD_CTL - }; - - for(i = 0; i < 4; i++) - { - for(j = 1; j < 10; j++) - { - int n; - - sprintf(cap, "%c%d", shift[i].ch,j); - - n = kgetnum(cap); - - if (n >= 0) - { - if (keyflag[n]) - { - fprintf(stderr,"kcon: duplicate key definition for key [%d]!\n",n); - exit(1); - } - keyflag[n] = 1; - - entry.keynum = n; - entry.type = shift[i].typ; - if((ioctl(kbfd, KBDSCKEY, &entry)) < 0) - { - perror("kcon: ioctl KBDSCKEY failed"); - exit(1); - } - } - } - } -} - -/*---------------------------------------------------------------------------* - * care for normal keys - *---------------------------------------------------------------------------*/ -set_char(keyflag, kbfd) -char keyflag[]; -int kbfd; -{ - int i, j; - char cap[16]; - int setflag; - char *addr_str; - char *new_str; - struct kbd_ovlkey entry; - - struct { - char *addr; - char ch; - } standard[] = { - 0, 'D', - &entry.unshift[0], 'K', - &entry.shift[0], 'S', - &entry.ctrl[0], 'C', - &entry.altgr[0], 'A' - }; - - for(i = 1; i < KBDMAXKEYS; i++) - { - setflag = 0; - - entry.keynum = i; - - if((ioctl(kbfd, KBDGOKEY, &entry)) < 0) - { - perror("kcon: ioctl KBDGOKEY failed"); - exit(1); - } - - entry.type = KBD_ASCII; - - for(j = 0; j < 5; j++) - { - sprintf(cap, "%c%d", standard[j].ch,i); - - if((j == 0) && (kgetflag(cap))) - { - /* delete a key */ - - entry.type = KBD_NONE; - setflag = 1; - goto setit; - - } - else - { - addr_str = standard[j].addr; - if(new_str = kgetstr(cap, &addr_str)) - { - if(strlen(new_str) > KBDMAXOVLKEYSIZE) - { - fprintf(stderr, "kcon: database entry string [%s] longer than max [%d]!\n",new_str,KBDMAXOVLKEYSIZE); - exit(1); - } - setflag = 1; - } - } - } - -setit: if (setflag) - { - if (keyflag[i]) - { - fprintf(stderr,"kcon: duplicate key definition for key [%d]!\n",i); - exit(1); - } - keyflag[i] = 1; - - if((ioctl(kbfd, KBDSCKEY, &entry)) < 0) - { - perror("kcon: ioctl KBDSCKEY failed"); - exit(1); - } - } - } -} - -/*------------------- EOF ------------------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/Util/keycap/Makefile b/sys/arch/i386/isa/pcvt/Util/keycap/Makefile deleted file mode 100644 index 69412e96d01d..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/keycap/Makefile +++ /dev/null @@ -1,17 +0,0 @@ -LIB = keycap -CAPDIR = /usr/share/pcvt -CAPPATH = $(CAPDIR)/keycap.pcvt -KEYCAPSRC= keycap.src -CPPFLAGS+= -DKEYCAP_PATH=\"$(CAPPATH)\" -SRCS = keycap.c - -MKMAN= no - -beforeinstall: - @if [ ! -d ${DESTDIR}${CAPDIR} ]; then mkdir ${DESTDIR}${CAPDIR};fi - @${ECHO} "Saving old keycap database" - -mv -f ${DESTDIR}${CAPPATH} ${DESTDIR}${CAPPATH}.BAK - ${INSTALL} -c -m ${LIBMODE} -o ${LIBOWN} -g ${LIBGRP} \ - ${.CURDIR}/${KEYCAPSRC} ${DESTDIR}${CAPPATH} - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/keycap/keycap.c b/sys/arch/i386/isa/pcvt/Util/keycap/keycap.c deleted file mode 100644 index 299a6466314d..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/keycap/keycap.c +++ /dev/null @@ -1,377 +0,0 @@ -/*- - * Copyright (c) 1992, 1993 The Regents of the University of California. - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * Holger Veit - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Berkeley and its contributors. - * 4. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * - */ - -#ifndef lint -static char *id = - "@(#)keycap.c, 3.20, Last Edit-Date: [Tue Dec 20 14:51:50 1994]"; -#endif - -/*---------------------------------------------------------------------------* - * - * keycap.c Keyboard capabilities database handling - * ------------------------------------------------------- - * - * converted from printcap by Holger Veit (veit@du9ds3.uni-duisburg.de) - * - * BUG: Should use a "last" pointer in tbuf, so that searching - * for capabilities alphabetically would not be a n**2/2 - * process when large numbers of capabilities are given. - * - * Note: If we add a last pointer now we will screw up the - * tc capability. We really should compile termcap. - * - * modified by Hellmuth Michaelis (hm@hcshh.hcs.de) to fit into the - * vt220 driver pcvt 2.0 distribution - * - * -hm header conversion & cosmetic changes for pcvt 2.0 distribution - * -hm debugging remapping - * -hm cleaning up from termcap .... - * -hm split off header file keycap.h - * - *---------------------------------------------------------------------------*/ - -#include -#include - -#include "keycap.h" - -#define KEYCAP_BUFSIZ 1024 - -#define MAXHOP 32 /* max number of tc= indirections */ - -char *getenv(); - -static char *tbuf; -static int hopcount; /* detect infinite loops in keycap, init 0 */ - -static int knchktc(); -static int knamatch(); -static char *kdecode(); - -/*---------------------------------------------------------------------------* - * match a name - *---------------------------------------------------------------------------*/ -static char *nmatch(id,cstr) -char *id,*cstr; -{ - register n = strlen(id); - register char *c = cstr+n; - - if (strncmp(id,cstr,n)==0 && - (*c==':' || *c=='|' || *c=='=' || *c=='#' || *c=='@')) - return c; - return 0; -} - -/*---------------------------------------------------------------------------* - * Get an entry for keyboard name in buffer bp from the keycap file. - * Parse is very rudimentary, we just notice escaped newlines. - *---------------------------------------------------------------------------*/ -int kgetent(bp, name) -char *bp, *name; -{ - register char *cp; - register int c; - register int i = 0, cnt = 0; - char ibuf[KEYCAP_BUFSIZ]; - int tf; - - tbuf = bp; - tf = 0; - - tf = open(KEYCAP_PATH, 0); - - if (tf < 0) - return (-1); - for (;;) { - cp = bp; - for (;;) { - if (i == cnt) { - cnt = read(tf, ibuf, KEYCAP_BUFSIZ); - if (cnt <= 0) { - close(tf); - return (0); - } - i = 0; - } - c = ibuf[i++]; - if (c == '\n') { - if (cp > bp && cp[-1] == '\\'){ - cp--; - continue; - } - break; - } - if (cp >= bp+KEYCAP_BUFSIZ) { - write(2,"Keycap entry too long\n", 23); - break; - } else - *cp++ = c; - } - *cp = 0; - - /* - * The real work for the match. - */ - if (knamatch(name)) { - close(tf); - return(knchktc()); - } - } -} - -/*---------------------------------------------------------------------------* - * knchktc: check the last entry, see if it's tc=xxx. If so, recursively - * find xxx and append that entry (minus the names) to take the place of - * the tc=xxx entry. Note that this works because of the left to right scan. - *---------------------------------------------------------------------------*/ -static int knchktc() -{ - register char *p, *q; - char tcname[16]; /* name of similar keyboard */ - char tcbuf[KEYCAP_BUFSIZ]; - char *holdtbuf = tbuf; - int l; - - p = tbuf + strlen(tbuf) - 2; /* before the last colon */ - while (*--p != ':') - if (p MAXHOP) { - write(2, "Infinite tc= loop\n", 18); - return (0); - } - if (kgetent(tcbuf, tcname) != 1) - return(0); - for (q=tcbuf; *q != ':'; q++) - ; - l = p - holdtbuf + strlen(q); - if (l > KEYCAP_BUFSIZ) { - write(2, "Keycap entry too long\n", 23); - q[KEYCAP_BUFSIZ - (p-tbuf)] = 0; - } - strcpy(p, q+1); - tbuf = holdtbuf; - return(1); -} - -/*---------------------------------------------------------------------------* - * knamatch deals with name matching. The first field of the keycap entry - * is a sequence of names separated by |'s, so we compare against each such - * name. The normal : terminator after the last name (before the first field) - * stops us. - *---------------------------------------------------------------------------*/ -static int knamatch(np) -char *np; -{ - register char *Np, *Bp; - - Bp = tbuf; - if (*Bp == '#' || *Bp == 0) - return(0); - for (;;) { - for (Np = np; *Np && *Bp == *Np; Bp++, Np++) - continue; - if (*Np == 0 && (*Bp == '|' || *Bp == ':' || *Bp == 0)) - return (1); - while (*Bp && *Bp != ':' && *Bp != '|') - Bp++; - if (*Bp == 0 || *Bp == ':') - return (0); - Bp++; - } -} - -/*---------------------------------------------------------------------------* - * Skip to the next field. Notice that this is very dumb, not knowing about - * \: escapes or any such. If necessary, :'s can be put into the keycap file - * in octal. - *---------------------------------------------------------------------------*/ -static char *kskip(bp) -char *bp; -{ - while (*bp && *bp != ':') - bp++; - if (*bp == ':') - bp++; - return (bp); -} - -/*---------------------------------------------------------------------------* - * Return the (numeric) option id. Numeric options look like 'li#80' i.e. - * the option string is separated from the numeric value by a # character. - * If the option is not found we return -1. Note that we handle octal - * numbers beginning with 0. - *---------------------------------------------------------------------------*/ -int kgetnum(id) -char *id; -{ - register int i, base; - register char *bp = tbuf,*xp; - - for (;;) { - bp = kskip(bp); - if (*bp == 0) - return (-1); - if ((xp=nmatch(id,bp)) == 0) - continue; - bp = xp; /* we have an entry */ - if (*bp == '@') - return(-1); - if (*bp != '#') - continue; - bp++; - base = 10; - if (*bp == '0') - base = 8; - i = 0; - while (isdigit(*bp)) - i *= base, i += *bp++ - '0'; - return (i); - } -} - -/*---------------------------------------------------------------------------* - * Handle a flag option. Flag options are given "naked", i.e. followed by - * a : or the end of the buffer. Return 1 if we find the option, or 0 if - * it is not given. - *---------------------------------------------------------------------------*/ -int kgetflag(id) -char *id; -{ - register char *bp = tbuf,*xp; - - for (;;) { - bp = kskip(bp); - if (!*bp) - return (0); - if ((xp=nmatch(id,bp)) != 0) { - bp = xp; - if (!*bp || *bp == ':') - return (1); - else if (*bp == '@') - return(0); - } - } -} - -/*---------------------------------------------------------------------------* - * Get a string valued option. These are given as 'cl=^Z'. Much decoding - * is done on the strings, and the strings are placed in area, which is a - * ref parameter which is updated. No checking on area overflow. - *---------------------------------------------------------------------------*/ -char *kgetstr(id, area) -char *id; -char **area; -{ - register char *bp = tbuf,*xp; - - for (;;) { - bp = kskip(bp); - if (!*bp) - return (0); - if ((xp = nmatch(id,bp)) == 0) - continue; - bp = xp; - if (*bp == '@') - return(0); - if (*bp != '=') - continue; - bp++; - return (kdecode(bp, area)); - } -} - -/*---------------------------------------------------------------------------* - * kdecode does the grung work to decode the string capability escapes. - *---------------------------------------------------------------------------*/ -static char *kdecode(str, area) -char *str; -char **area; -{ - register char *cp; - register int c; - register char *dp; - int i; - - cp = *area; - while ((c = *str++) && c != ':') { - switch (c) { - - case '^': - c = *str++ & 037; - break; - - case '\\': - dp = "E\033^^\\\\::n\nr\rt\tb\bf\f"; - c = *str++; -nextc: - if (*dp++ == c) { - c = *dp++; - break; - } - dp++; - if (*dp) - goto nextc; - if (isdigit(c)) { - c -= '0', i = 2; - do - c <<= 3, c |= *str++ - '0'; - while (--i && isdigit(*str)); - } - break; - } - *cp++ = c; - } - *cp++ = 0; - str = *area; - *area = cp; - return (str); -} - -/*-------------------------------- EOF --------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/Util/keycap/keycap.h b/sys/arch/i386/isa/pcvt/Util/keycap/keycap.h deleted file mode 100644 index 1dc4c3e1e6ef..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/keycap/keycap.h +++ /dev/null @@ -1,49 +0,0 @@ -/*- - * Copyright (c) 1992, 1993 The Regents of the University of California. - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * Holger Veit - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by the University of - * California, Berkeley and its contributors. - * 4. Neither the name of the University nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * - * @(#)keycap.h, 3.20, Last Edit-Date: [Tue Dec 20 14:52:11 1994] - */ - -#ifndef _KEYCAP_H_ -#define _KEYCAP_H_ - -int kgetent( char*, char* ); -int kgetnum( char* ); -int kgetflag( char* ); -char *kgetstr( char*, char** ); - -#endif /* _KEYCAP_H_ */ - -/*-------------------------------- EOF -------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/Util/keycap/keycap.src b/sys/arch/i386/isa/pcvt/Util/keycap/keycap.src deleted file mode 100644 index f80be67fb937..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/keycap/keycap.src +++ /dev/null @@ -1,613 +0,0 @@ -# Copyright (c) 1992, 1993, 1994 Hellmuth Michaelis, Joerg Wunsch and -# Holger Veit. -# -# All rights reserved. -# -# Redistribution and use in source and binary forms, with or without -# modification, are permitted provided that the following conditions -# are met: -# 1. Redistributions of source code must retain the above copyright -# notice, this list of conditions and the following disclaimer. -# 2. Redistributions in binary form must reproduce the above copyright -# notice, this list of conditions and the following disclaimer in the -# documentation and/or other materials provided with the distribution. -# 3. All advertising materials mentioning features or use of this software -# must display the following acknowledgement: -# This product includes software developed by Hellmuth Michaelis, -# Joerg Wunsch and Holger Veit. -# 4. The names of the Authors may not be used to endorse or promote -# products derived from this software without specific prior written -# permission. -# -# THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND -# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -# ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE -# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS -# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) -# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY -# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF -# SUCH DAMAGE. -# -# @(#)keycap.src, 3.20, Last Edit-Date: [Wed Mar 8 20:53:01 1995] -# -#--------------------------------------------------------------------------- -# -# keyboard mappings for vt220 emulator pcvt 3.00 -# ---------------------------------------------- -# -# DEC MCS and/or ISO-Latin-1 Characterset used -# -# MF II Keyboards fully supported -# AT Keyboards lack a ALTGR Key, so they cannot be handled by -# the current driver implementation .... sorry -# -# If you design a new entry for national keyboards, please -# send it to hm@hcshh.hcs.de, thank you ! -# -# Many entries are taken from the 386BSD patchkit 0.2.4 codrv -# -#--------------------------------------------------------------------------- -# -# -hm patch from Thomas Gellekum -# -hm renamed finnish "f8" entry to "f1" -# -#--------------------------------------------------------------------------- - -df|default|default entry:\ - :de: - -tt|test|Test entry which swaps y and z:\ - :K22=z:S22=Z:C22=\032:\ - :K46=y:S46=Y:C46=\031: - -# from codrv, untested -be|belgium|Belgian mapping:\ - :K1=\262:S1=\263:\ - :K2=&:S2=1:A2=|:\ - :K3=\351:S3=2:A3=@:\ - :K4=":S4=3:A4=#:\ - :K5=':S5=4:\ - :K6=(:S6=5:\ - :K7=\247:S7=6:A7=\136:\ - :K8=\350:S8=7:\ - :K9=!:S9=8:\ - :K10=\347:S10=9:A10={:\ - :K11=\340:S11=0:A11=}:\ - :K12=):S12=\260:\ - :K13=-:S13=_:\ - :K17=a:S17=A:C17=^A:\ - :K18=z:S18=Z:C18=^z:\ - :K27=\136:S27=\250:A27=[:p1#27:\ - :K28=$:S28=*:A28=]:\ - :K31=q:S31=Q:C31=^q:\ - :K40=m:S40=M:C40=^m:\ - :K41=\371:S41=%:A41=':p2#41:\ - :K42=\265:S42=\243:A42=\264:p3#42:\ - :K45=<:S45=>:A45=\\:\ - :K46=w:S46=W:C46=^w:\ - :K52=,:S52=\077:\ - :K53=;:S53=.:\ - :K54=\072:S54=/:\ - :K55==:S55=+:A55=~:\ - :l1#62:a0: - -# from codrv, untested -ca|canadafr|Canadian French mapping:\ - :K1=#:S1=|:A1=\\:\ - :A2=\261:S3=":A3=@:S4=/:A4=\243:A5=\242:\ - :A6=\244:S7=\077:A7=\254:S8=&:A8=\246:S9=*:A9=\262:\ - :S10=(:A10=\263:S11=):A11=\274:\ - :K12=-:S12=_:A12=\275:\ - :K13==:S13=+:A13=\276:\ - :A25=\247:A26=\266:\ - :K27=\136:S27=\136:A27=[:\ - :K28=\270:S28=\250:A28=]:p1#28:\ - :A40=~:K41=`:S41=`:A41={:\ - :K42=<:S42=>:A42=}:\ - :K45=\253:S45=\273:A45=\260:\ - :A49=\253:A50=\273:A51=\260:\ - :A52=\265:K53=,:S53=,:A53=-:\ - :K54=\351:S54=\311:A54=':\ - :l1#62:a0: - -# from codrv, untested -c1|swissde|Swiss German mapping:\ - :K1=\247:S1=\260:p1#1:\ - :S2=+:A2=|:S3=":A3=@:S4=*:A4=#:S5=\347:S7=&:A7=\254:\ - :S8=/:A8=\246:S9=(:A9=\242:S10=):S11==:\ - :K12=`:S12=\077:A12=':p2#12:\ - :K13=^:S13=\\:A13=~:p3#13:\ - :K22=z:S22=Z:C22=\032:\ - :S27=\350:K27=\374:A27=[:\ - :K28=\250:S28=!:A28=]:\ - :S40=\351:K40=\366:\ - :S41=\340:K41=\344:A41={:\ - :K42=$:S42=\243:A42=}:\ - :K45=<:S45=>:A45=\\:\ - :K46=y:S46=Y:C46=\031: - :S53=;:S54=\072:K55=-:S55=_:\ - :l1#62:a0: - -# from codrv, untested -c2|swissfr|Swiss French mapping:\ - :K27=\350:S27=\374:A27=[:\ - :K40=\351:S40=\366:\ - :K41=\340:S41=\344:A41={:\ - :tc=swissde: - -# more programmer-like than an original German kbd, you needn't -# have gum-fingers to get `{}' and the like:-) -# maps: ae -> [, oe -> \, ue -> ], Ae -> {, Oe -> |, Ue -> } -# umlaute are available as AltGr- and Control-Mappings -# also maps Pause -> ^Z -# -# (from Joerg Wunsch) -# -# l1/m1 bindings: left Alt is AltGr -# Emacs functions: -# C79/C89: ctrl-{leftarrow,rightarrow} {backward,forward} word -# A79/A89: {backward,forward} sexp -# C83/C84: ctrl-{uparrow,downarrow} {backward,forward} window -# -de-prog|germany-prog|programmer's mapping for german keyboard:\ - :K27=]:S27=}:A27=\374:C27=\334:\ - :K40=\\:S40=|:A40=\366:C40=\326:\ - :K41=[:S41={:A41=\344:C41=\304:\ - :K126=\032:C126=\003:\ - :tc=de: -# :l1#60:l2#62:\ -# :C79=^[B:K79=^[[D:S79=^[OD:A79=^[^B:\ -# :C89=^[F:K89=^[[C:S89=^[OC:A89=^[^F:\ -# :C83=^U-1^XO:K83=^[[A:S84=^[OA:\ -# :C84=^XO:K84=^[[B:S84=^[OB:\ - -de|germany|German mapping for MF II-Keyboard:\ - :K1=\136:S1=\260:\ - :S3=\042:S4=\247:S7=&:S8=/:S9=(:S10=):S11=\075:\ - :A3=\262:A4=\263:A8={:A9=[:A10=]:A11=}:A12=\134:\ - :K12=\337:S12=?:C12=\034:\ - :K13=':S13=`:\ - :A17=\100:\ - :K22=z:S22=Z:C22=\032:\ - :K27=\374:S27=\334:\ - :K28=+:S28=*:A28=\176:\ - :K29=\043:S29=':A29=\174:\ - :K40=\366:S40=\326:\ - :K41=\344:S41=\304:\ - :A45=\174:\ - :K46=y:S46=Y:C46=\031:\ - :A52=\265:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - :l1#62: - -de-at|germany-at|German mapping for AT-Keyboard:\ - :K1=<:S1=>:\ - :S3=\042:\ - :S4=\247:\ - :S7=&:\ - :S8=/:\ - :S9=(:\ - :S10=):\ - :S11=\075:\ - :K12=\337:S12=?:C12=\034:\ - :K13=':S13=`:\ - :K14=#:S14=\136:\ - :K22=z:S22=Z:C22=\032:\ - :K27=\374:S27=\334:\ - :K28=+:S28=*:\ - :K29=\043:S29=':\ - :K40=\366:S40=\326:\ - :K41=\344:S41=\304:\ - :K46=y:S46=Y:C46=\031:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - -# from codrv, untested -# Includes improvements by Thomas Hiller (hiller@fzi.de) -# and Andreas Israel (ai@hrz.tu-chemnitz.de) -de-hi|germany-hiller|yet another German mapping:\ - :K1=\136:S1=\260:C1=|:\ - :S3=\042:S4=#:S7=&:S8=/:S9=(:S10=):S11=\075:\ - :A8={:A9=[:A10=]:A11=}:A17=@:A28=~:\ - :K12=\337:S12=\077:C12=\036:A12=\\:\ - :K13=':S13=`:C13=\134:p1#13:\ - :K22=z:S22=Z:C22=\032:\ - :K27=\374:S27=\334:C27=\035:\ - :K28=+:S28=*:C28=\000:\ - :K29=<:S29=>:C29=\134:\ - :K40=\366:S40=\326:C40=\034:\ - :K41=\344:S41=\304:C41=\033:\ - :K46=y:S46=Y:C46=\031:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - :l1#62:a0: - -# from codrv, untested -# Contribution by Thomas Hiller (hiller@fzi.de) -# "K42 may not work on 102 keys kbds, K29 seems to work" -d1|de-102|german with mf2:\ - :K29=#:\ - :K42=#:\ - :K45=<:S45=>:A45=|:\ - :tc=germany: - -# from codrv, untested -hv|holgi|Holgi's special MF1 keyboard mapping:\ - :K1=<:S1=>:C1=|:\ - :K29=#:S29=\136:A29=\\:C29=~:\ - :tc=germany: - -# from codrv, untested -# Contributed by Andreas Israel (ai@hrz.tu-chemnitz.de) -de-ai|nixmf2|ct22|nix|nix7|German Nixdorf MF2:\ - :A28=~:\ - :K29=#:S29=':\ - :K45=<:S45=>:A45=|:\ - :tc=germany: - -# from codrv, untested -dk|denmark|Danish mapping:\ - :K1=\275:S1=\247:\ - :S3=":A3=@:\ - :A4=\243:\ - :S5=\244:A5=$:\ - :S7=&:S8=/:A8={:S9=(:A9=[:S10=):A10=]:S11==:A11=}:\ - :K12=+:S12=\077:\ - :K13=':S13=`:A13=|:p1#13:\ - :K27=\345:S27=\305:\ - :K28=\250:S28=\136:A28=~:p2#28:\ - :K29=':S29=*:\ - :K40=\346:S40=\306:\ - :K41=\370:S41=\330:\ - :K45=<:S45=>:A45=\\:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - :l1#62:a0: - -# from codrv, untested -# Finnish keyboard map with 7-bit versions of the national -# chars. The Latin1 chars are available with Alt-7, Alt-8, etc -# (where normally you would have the 7-bit ones). -# Makes C/C++ programming more comfortable, since the 7-bit chars -# (|\{[}]) are needed much more often than the Latin1 chars. -# -- Petri.Wessman@hut.fi -fi|finland|finland7b|finland-ascii|Finnish ASCII mapping:\ - :l1#60:l2#62:\ - :A8=\344:A9=\304:A10=\305:A11=\345:A12=\326:A13=\366:\ - :K40=|:S40=\\:K41={:S41=[:K27=}:S27=]:\ - :S1=\275:K1=\247:\ - :S3=":A3=@:\ - :A4=\243:\ - :S5=$:A5=$:\ - :S7=&:S8=/:S9=(:S10=):S11==:\ - :K12=+:S12=\077:\ - :K13=':S13=`:\ - :K28=~:S28=\136:A28=~:\ - :K29=':S29=*:\ - :K45=<:S45=>:A45=|:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - :a0: - -# from codrv, untested -# Finnish keyboard map with the Latin1 national chars in -# their "right" place. --Petri.Wessman@hut.fi -f1|finland8b|finland-latin1|Finnish Latin1 mapping:\ - :A8={:A9=[:A10=]:A11=}:A12=\\:\ - :K40=\366:S40=\326:K41=\344:S41=\304:K27=\345:S27=\305:\ - :tc=finland: - - -# French keyboard mapping -# From Matthieu Herrb -# For 102 keys keyboards, produces 8 bits characters -# with ISO Latin-1 encoding -f8|france-iso-8859-1|French ISO 8859-1 102 keys keyboard:\ - :l1#62:\ - :K1=\262:S1=:\ - :K2=&:S2=1:\ - :K3=\351:S3=2:C3=\211:A3=~:\ - :K4=":S4=3:A4=#:\ - :K5=':S5=4:A5={:\ - :K6=(:S6=5:A6=[:\ - :K7=-:S7=6:C7=\036:A7=|:\ - :K8=\350:S8=7:C8=\210:A8=`:\ - :K9=_:S9=8:C9=\037:A9=\\:\ - :K10=\347:S10=9:C10=\207:A10=\136:\ - :K11=\340:S11=0:C11=\340:A11=@:\ - :K12=):S12=\260:A12=]:\ - :A13=}:\ - :K17=a:S17=A:C17=\001:\ - :K18=z:S18=Z:C18=\032:\ - :D27:\ - :K28=$:S28=\243:\ - :K29=*:S29=\265:\ - :K31=q:S31=Q:C31=\021:\ - :K40=m:S40=M:C40=\015;\ - :K41=\371:C41=\231:S41=%:\ - :K42=*:S42=\265:\ - :K46=w:S46=W:C46=\027:\ - :K52=,:S52=?:\ - :K53=;:S53=.:\ - :K54=\072:S54=/:C54=\037\ - :K55=!:S55=\266: - -# fr|france|French mapping:\ -# :de: -# -# from codrv, untested -# f1|france120|French 120 mapping:\ -# :tc=belgium: -# -# -# from codrv, untested -#f2|france189|French 189 mapping:\ -# :S1=:A1=':p3#1:\ -# :A2=:A3=~:A5={:A6=[:A7=|:A8=`:\ -# :S9=_:A9=\\:A10=\136:A11=@:A12=]:A13=}:\ -# :A27=:A28=\244:A41=:A42=:\ -# :A45=:!:S45=\247:\ -# :tc=belgium: - -# From: Andy Duplain, duplain@rtf.bt.co.uk -gb|greatbritain|British mapping for MF-2 keyboard:\ - :S1=|:S3=":C3=2:C12=-:S41=@:K42=#:S42=~:C42=#:K45=\\:S45=|:C45=\\: - -# from codrv, untested -# This entry has been corrected by Mike Trim (mtrim@crucible.demon.co.uk) -# (hv's comment: For the keys # and ~ you might also check the following -# line -# :K42=#:S42=~:\ -# Also I think I was wrong with the ALTGR key. If you need one, add this: -# :l1#62: -g1|greatbritain166|British 166 mapping:\ - :K1=`:S1=\254:A1=|:\ - :S3=":S4=\243:\ - :K41=':S41=@:\ - :K29=#:S29=~:\ - :K45=\\:S45=|: - -# from codrv, untested -g2|greatbritain168|British 168 mapping:\ - :K1=\\:S1=|:\ - :S3=":S4=\243:S7=&:S8=:S9=(:S10=):A10=\261:\ - :S11=#:A11=\260:S12=:K13=\254:S13=-:\ - :K27=@:S27=`:\ - :K28=[:S28={:A28=~:\ - :K40=;:S40=+:\ - :K41=\072:S41=*:A41=\136:\ - :K42=]:S42=}:\ - :K45=|:S45=_:\ - :A52=\265:\ - :l1#62:a0: - -# from codrv, untested -is:iceland:Island mapping:\ - :K1=\260:S1=\250:p1#1:\ - :S2=":S7=&:S8=/:A8={:S9=(:A9=[:S10=):A10=]:S11==:A11=}:\ - :K12=\\:S12=\326:\ - :K13=':S13=`:A13=|:\ - :A17=@:K27=\360:S27=\320:\ - :K28=':S28=\077:A28=~:\ - :K40=\346:S40=\306:\ - :K41=':S41=':A41=\136:p2#41:\ - :K42=+:S42=*:A42=`:p3#42:\ - :K45=<:S45=>:A45=|:\ - :S53=;:S54=\072:\ - :K54=\376:S54=\336:\ - :K104=,:104=,:\ - :l1#62:a0: - -# from codrv, untested -i1|italy141|Italian 141 mapping:\ - :K1=\\:S1=|:\ - :S3=":S4=\243:S7=&:S8=/:S9=(:S10=):S11==:\ - :K12=':S12=\077:\ - :K13=\354:S13=\136:\ - :K27=\350:S27=\351:\A27=[:\ - :K28=+:S28=*:A28=]:\ - :K40=\362:S40=\347:A40=@:\ - :K41=\340:S41=\260:A41=#:\ - :K42=\371:S42=\247:\ - :K45=<:S45=>:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - :l1#62:a0: - -# from codrv, untested -i2|italy142|Italian 142 mapping:\ - :A8={:A9=[:A10=]:A11=}:\ - :A17=@:A27=:A28=~:A40=:A41=:\ - :tc=italy141:a0: - -# from codrv, untested -nl|netherlands|Dutch mapping:\ - :K1=@:S1=\247:A1=\254:\ - :A2=\271:S3=":A3=\262:S4=#:A4=\263:A5=\274:A6=\275:S7=&:\ - :A7=\276:S8=_:A8=\243:S9=(:A9={:S10=):A10=}:S11=':\ - :K12=/:S12=\077:A12=\\:\ - :K13=\260:S13=~:A13=\270:p1#13:\ - :K20=\266:K27=\250:S27=^:p2#27:\ - :K28=*:S28=|:\ - :K40=+:S40=\261:\ - :K41=':S41=`:\ - :K42=<:S42=>:\ - :K45=[:S45=]:A45=|:\ - :S53=;:S54=\072:K55=-:S55=_:\ - :K104=,:S104=,:\ - :l1#62:a0: - -# from codrv, untested -no|norway|Norwegian mapping:\ - :K1=|:\ - :K13=\\:S13=`:A13=':p1#13:\ - :K41=\346:S41=\306:\ - :K40=\370:S40=\330:\ - :A45=:\ - :tc=denmark: - -# from codrv, untested -pt|portugal|Portugesian mapping:\ - :K1=\\:S1=|:\ - :S3=":A3=@:A4=\243:A5=\247:S7=&:S8=/:A8={:S9=(:A9=[:\ - :S10=):A10=]:S11=}:A11==:\ - :K12=':S12=\077:\ - :K13=\253:S13=\273:\ - :K40=\347:S40=\307:\ - :K41=\272:S41=\252:\ - :K42=~:S42=^:p1#42:\ - :K45=<:S45=>:\ - :S53=;:S54=\072:K55=-:S55=_:\ - :l1#62:a0: - -# from codrv, untested -es|spain|Spainish mapping:\ - :K1=\272:S1=\252:A1=\\:\ - :A2=|:S3=":A3=@:S4=:A4=#:S7=&:A7=\254:S8=/:S9=(:S10=):S11==:\ - :K12=':S12=\077:p1#12:\ - :K13=\277:S13=\241:\ - :K27=`:S27=^:A27=[:p2#27:\ - :K28=+:S28=*:A28=]:\ - :K40=\361:S41=\321:\ - :K41=/:S41=\250:A41={:p3#41:\ - :K42=\347:S42=\307:A42=}:\ - :K45=<:S45=>:\ - :S53=;:S54=\072:\ - :K55=-:S55=_:\ - :K104=,:S104=,:\ - :l1#62:a0: - -# from codrv, untested -# Contributed by Mats O Jansson, moj@stacken.kth.se -# "Here is my map, rather large, but i want ALTGR normaly to be dead. -# Only seven bit national characters have been placed where national characters -# is on the keyboard." -# We can help this man, just use the 'a0' capability -hv- -s1|sweden1|Swedish mapping:\ - :l1#62:a0:\ - :D1:\ - :K12=+:K13=':K29=':\ - :S2=!:S3=":S4=#:S5=$:S6=%:S7=&:S8=/:\ - :S9=(:S10=):S11=\075:S12=\077:S13=`:S29=*:\ - :C2=:C3=\000:C4=\033:C5=\034:C6=\035:C7=:C8=:C9=:\ - :C10=:C11=:C12=:C13=:C29=:\ - :A3=\100:A5=$:A8={:\ - :A9=[:A10=]:A11=}:A12=\134:\ - :K27=]:K28=:\ - :S27=}:S28=\136:\ - :C27=\035:C28=:\ - :A28=\176:\ - :K40=\134:K41=[:\ - :S40=|:S41={:\ - :C40=\034:C41=\033:\ - :K45=<:K53=,:K54=.:K55=-:\ - :S45=>:S53=;:S54=\072:S55=_:\ - :C45=\034:C53=:C54=:C55=:\ - :A45=|:\ - :C61=\000: - -# from codrv, untested -# Contributed by Mats O Jansson, moj@stacken.kth.se -# "Here is my map, rather large, but i want ALTGR normaly to be dead. -# Only seven bit national characters have been placed where national -# characters is on the keyboard." -# We can help this man, just use the 'a0' capability -hv- -# Corrected by Paul Pries, 5322@msg.abc.se (Some national shifts were -# wrong). -sa|sweden1a|Swedish 7bit mapping ISO 646:\ - :l1#62:a0:\ - :D1:\ - :K12=+:K13=':K29=':\ - :S2=!:S3=":S4=#:S5=$:S6=%:S7=&:S8=/:\ - :S9=(:S10=):S11=\075:S12=\077:S13=`:S29=*:\ - :C2=:C3=\000:C4=\033:C5=\034:C6=\035:C7=:C8=:C9=:\ - :C10=:C11=:C12=:C13=:C29=:\ - :A3=\100:A5=$:A8={:\ - :A9=[:A10=]:A11=}:A12=\134:\ - :K27=}:K28=:\ - :S27=]:S28=\136:\ - :C27=\035:C28=:\ - :A28=\176:\ - :S40=\134:S41=[:\ - :K40=|:K41={:\ - :C40=\034:C41=\033:\ - :K45=<:K53=,:K54=.:K55=-:\ - :S45=>:S53=;:S54=\072:S55=_:\ - :C45=\034:C53=:C54=:C55=:\ - :A45=|:\ - :C61=\000: - -# from codrv, untested -# Swedish keyboard map with national characters. -# Paul Pries, 5322@msg.abc.se -s2|sweden2|Swedish 8bit mapping ISO 8859-1:\ - :l1#62:\ - :K1=\247:S1=:\ - :K12=+:K13=':K29=':\ - :S2=!:S3=":S4=#:S5=$:S6=%:S7=&:S8=/:\ - :S9=(:S10=):S11=\075:S12=\077:S13=`:S29=*:\ - :C2=:C3=\000:C4=\033:C5=\034:C6=\035:C7=:C8=:C9=:\ - :C10=:C11=:C12=:C13=:C29=:\ - :A3=\100:A4=\234:A5=$:A8={:\ - :A9=[:A10=]:A11=}:A12=\134:\ - :K27=\206:K28=:\ - :S27=\217:S28=\136:\ - :C27=\035:C28=:\ - :A28=\176:\ - :S40=\231:S41=\216:\ - :K40=\224:K41=\204:\ - :C40=\034:C41=\033:\ - :K45=<:K53=,:K54=.:K55=-:\ - :S45=>:S53=;:S54=\072:S55=_:\ - :C45=\034:C53=:C54=:C55=:\ - :A45=|:\ - :C61=\000: - -# -# tg: my idiosyncratic mappings (thomas@ghpc8.ihf.rwth-aachen.de) -# -# the six function keys above the cursor keys are arranged -# identical to a real VT220: -# -# find insert remove -# select up down -# -# since i don't have a use for the numbers on the keypad, -# i map NumLock, /, *, - to PF1-PF4; -# + is mapped to SS3 l, shifted + is mapped to SS3 m -# -# they convinced me finally to add some support for german umlauts. -# so, i stole the mapping from jörg wunsch's de-prog entry. -# -# tg -# - -tg:\ - :l1#62:\ - :A12=\337:\ - :A27=\374:C27=\334:\ - :A40=\366:C40=\326:\ - :A41=\344:C41=\304:\ - :K126=\032:C126=\003:\ - :K75=[1~:S75=[1~:C75=[1~:\ - :K76=[4~:S76=[4~:C76=[4~:\ - :K80=[2~:S80=[2~:C80=[2~:\ - :K81=[5~:S81=[5~:C81=[5~:\ - :K85=[3~:S85=[3~:C85=[3~:\ - :K86=[6~:S86=[6~:C86=[6~:\ - :K90=OP:S90=OP:C90=OP:\ - :K95=OQ:S95=OQ:C95=OQ:\ - :K100=OR:S100=OR:C100=OR:\ - :K104=On:S104=On:C104=On:\ - :K105=OS:S105=OS:C105=OS:\ - :K106=Ol:S106=Om:\ - :K108=OM:S108=OM:C108=OM: - -us|usa|United States mapping:\ - :de: - -# EOF diff --git a/sys/arch/i386/isa/pcvt/Util/keycap/shlib_version b/sys/arch/i386/isa/pcvt/Util/keycap/shlib_version deleted file mode 100644 index 4b87ef0afa83..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/keycap/shlib_version +++ /dev/null @@ -1,4 +0,0 @@ -# $NetBSD: shlib_version,v 1.1 1998/11/01 17:14:27 hubertf Exp $ -# -major=0 -minor=0 diff --git a/sys/arch/i386/isa/pcvt/Util/loadfont/Makefile b/sys/arch/i386/isa/pcvt/Util/loadfont/Makefile deleted file mode 100644 index be52b6dee400..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/loadfont/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -PROG= loadfont - -MKMAN= no - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/loadfont/loadfont.c b/sys/arch/i386/isa/pcvt/Util/loadfont/loadfont.c deleted file mode 100644 index bf64832f8f68..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/loadfont/loadfont.c +++ /dev/null @@ -1,392 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis - * - * Copyright (c) 1992, 1994 Brian Dunford-Shore - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis and Brian Dunford-Shore - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - */ - -static char *id = - "@(#)loadfont.c, 3.31, Last Edit-Date: [Thu Aug 24 10:40:50 1995]"; - -/*---------------------------------------------------------------------------* - * - * load a font into vga character font memory - * - * -hm removing explicit HGC support (same as MDA ..) - * -hm new pcvt_ioctl.h SIZ_xxROWS - * -hm add -d option - * -hm patch from Joerg, -s scanlines option - * - *---------------------------------------------------------------------------*/ - -#include -#include -#include -#include -#include -#include - -struct screeninfo screeninfo; - -#define DEFAULTFD 0 -int fd; - -static int roundrows(int scrrow); -static int codetosize(int code); -static void setfont(int charset, int fontloaded, int charscan, - int scrscan, int scrrow); -static void loadfont(int fontset, int charscanlines, - unsigned char *font_table); -static void printvgafontattr(int charset); -static void printheader(void); -static void usage(void); - -main(int argc, char **argv) -{ - extern int optind; - extern int opterr; - extern char *optarg; - - FILE *in; - struct stat sbuf, *sbp; - unsigned char *fonttab; - int ret; - int chr_height; - int scr_scan; - int scr_rows; - int scan_lines = -1; - int c; - int chr_set = -1; - char *filename; - int fflag = -1; - int info = -1; - int dflag = 0; - char *device; - - while( (c = getopt(argc, argv, "c:d:f:is:")) != -1) - { - switch(c) - { - case 'c': - chr_set = atoi(optarg); - break; - - case 'd': - device = optarg; - dflag = 1; - break; - - case 'f': - filename = optarg; - fflag = 1; - break; - - case 'i': - info = 1; - break; - - case 's': - scan_lines = atoi(optarg); - if(scan_lines == 0) - usage(); - break; - - case '?': - default: - usage(); - break; - } - } - - if(chr_set == -1 || fflag == -1) - info = 1; - - if(dflag) - { - if((fd = open(device, O_RDWR)) == -1) - { - char buffer[80]; - strcpy(buffer,"ERROR opening "); - strcat(buffer,device); - perror(buffer); - exit(1); - } - } - else - { - fd = DEFAULTFD; - } - - if(ioctl(fd, VGAGETSCREEN, &screeninfo) == -1) - { - perror("ioctl VGAGETSCREEN failed"); - exit(1); - } - - if(info == 1) - { - int i; - - switch(screeninfo.adaptor_type) - { - case UNKNOWN_ADAPTOR: - case MDA_ADAPTOR: - case CGA_ADAPTOR: - fprintf(stderr, - "Adaptor does not support Downloadable Fonts!\n"); - break; - case EGA_ADAPTOR: - printheader(); - for(i = 0;i < 4;i++) - { - printvgafontattr(i); - } - break; - case VGA_ADAPTOR: - printheader(); - for(i = 0;i < 8;i++) - { - printvgafontattr(i); - } - } - printf("\n"); - exit(0); - } - - switch(screeninfo.adaptor_type) - { - case UNKNOWN_ADAPTOR: - case MDA_ADAPTOR: - case CGA_ADAPTOR: - fprintf(stderr, - "Adaptor does not support " - "Downloadable Fonts!\n"); - exit(1); - - case EGA_ADAPTOR: - if(scan_lines == -1) scan_lines = 350; - else if(scan_lines != 350) { - fprintf(stderr, - "EGA adaptors can only operate with " - "350 scan lines.\n"); - exit(1); - } - break; - - case VGA_ADAPTOR: - if(scan_lines == -1) scan_lines = 400; - else if(scan_lines != 400 && scan_lines != 480) { - fprintf(stderr, - "VGA adaptors can only operate with " - "400/480 scan lines.\n"); - exit(1); - } - break; - } - - if(chr_set < 0 || chr_set > 7) - usage(); - - sbp = &sbuf; - - if((in = fopen(filename, "r")) == NULL) - { - char buffer[80]; - sprintf(buffer, "cannot open file %s for reading", filename); - perror(buffer); - exit(1); - } - - if((fstat(fileno(in), sbp)) != 0) - { - char buffer[80]; - sprintf(buffer, "cannot fstat file %s", filename); - perror(buffer); - exit(1); - } - - chr_height = sbp->st_size / 256; /* 256 chars per font */ - - if(chr_height * 256 != sbp->st_size || - chr_height < 8 || chr_height > 20) { - fprintf(stderr, - "File is no valid font file, size = %d.\n", - sbp->st_size); - exit(1); - } - - scr_rows = codetosize(roundrows(scan_lines / chr_height)); - scr_scan = scr_rows * chr_height - 256 - 1; - - if((fonttab = (unsigned char *)malloc((size_t)sbp->st_size)) == NULL) - { - fprintf(stderr,"error, malloc failed\n"); - exit(1); - } - - if((ret = fread(fonttab, sizeof(*fonttab), sbp->st_size, in)) != - sbp->st_size) - { - fprintf(stderr, - "error reading file %s, size = %d, read = %d, " - "errno %d\n", - argv[1], sbp->st_size, ret, errno); - exit(1); - } - - loadfont(chr_set, chr_height, fonttab); - setfont(chr_set, 1, chr_height - 1, scr_scan, scr_rows); - - exit(0); -} - -static int -roundrows(int scrrow) -{ - if(scrrow >= 50) return SIZ_50ROWS; - else if(scrrow >= 43) return SIZ_43ROWS; - else if(scrrow >= 40) return SIZ_40ROWS; - else if(scrrow >= 35) return SIZ_35ROWS; - else if(scrrow >= 28) return SIZ_28ROWS; - else return SIZ_25ROWS; -} - -static int -codetosize(int code) -{ - static int sizetab[] = { 25, 28, 35, 40, 43, 50 }; - if(code < 0 || code >= sizeof sizetab / sizeof(int)) - return -1; - return sizetab[code]; -} - -static void -setfont(int charset, int fontloaded, int charscan, int scrscan, int scrrow) -{ - struct vgafontattr vfattr; - - vfattr.character_set = charset; - vfattr.font_loaded = fontloaded; - vfattr.character_scanlines = charscan; - vfattr.screen_scanlines = scrscan; - vfattr.screen_size = scrrow; - - if(ioctl(fd, VGASETFONTATTR, &vfattr) == -1) - { - perror("loadfont - ioctl VGASETFONTATTR failed, error"); - exit(1); - } -} - -static void -loadfont(int fontset, int charscanlines, unsigned char *font_table) -{ - int i, j; - struct vgaloadchar vlc; - - vlc.character_set = fontset; - vlc.character_scanlines = charscanlines; - - for(i = 0; i < 256; i++) - { - vlc.character = i; - for (j = 0; j < charscanlines; j++) - { - vlc.char_table[j] = font_table[j]; - } - font_table += charscanlines; - if(ioctl(fd, VGALOADCHAR, &vlc) == -1) - { - perror("loadfont - ioctl VGALOADCHAR failed, error"); - exit(1); - } - } -} - -static void -printvgafontattr(int charset) -{ - struct vgafontattr vfattr; - - vfattr.character_set = charset; - - if(ioctl(fd, VGAGETFONTATTR, &vfattr) == -1) - { - perror("loadfont - ioctl VGAGETFONTATTR failed, error"); - exit(1); - } - printf(" %d ",charset); - if(vfattr.font_loaded) - { - - printf("Loaded "); - printf(" %2.2d ", codetosize(vfattr.screen_size)); - printf(" %2.2d ", - (((int)vfattr.character_scanlines) & 0x1f) + 1); - printf(" %3.3d", - ((int)vfattr.screen_scanlines+0x101)); - } - else - { - printf("Empty"); - } - printf("\n"); -} - -static void -printheader(void) -{ - printf("\nEGA/VGA Charactersets Status Info:\n\n"); - printf("Set Status Lines CharScanLines ScreenScanLines\n"); - printf("--- ------ ----- ------------- ---------------\n"); -} - -static void -usage(void) -{ - fprintf(stderr, - "\nloadfont - " - "load a font into EGA/VGA font ram for the pcvt video driver\n"); - fprintf(stderr, - "usage: loadfont -c -d -f " - " -i -s \n"); - fprintf(stderr, - " -c characterset to load (EGA 0..3, VGA 0..7)\n"); - fprintf(stderr, - " -d specify device\n"); - fprintf(stderr, - " -f filename containing binary font data\n"); - fprintf(stderr, - " -i print status and types of loaded fonts\n"); - fprintf(stderr, - " -s number of scan lines on screen\n"); - exit(2); -} diff --git a/sys/arch/i386/isa/pcvt/Util/mcon/Makefile b/sys/arch/i386/isa/pcvt/Util/mcon/Makefile deleted file mode 100644 index 43b740d0052e..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/mcon/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -PROG= mcon - -MKMAN= no - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/mcon/mcon.c b/sys/arch/i386/isa/pcvt/Util/mcon/mcon.c deleted file mode 100644 index 0ac9700bf7f8..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/mcon/mcon.c +++ /dev/null @@ -1,193 +0,0 @@ -/* - * Copyright (c) 1994, 1995 Joerg Wunsch - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Joerg Wunsch - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)mcon.c, 3.30, Last Edit-Date: [Fri Jun 30 20:15:02 1995] - */ - -/*---------------------------------------------------------------------------* - * - * history: - * - * -jw initial version; includes a basic mapping between PeeCee - * scan codes and key names - * -hm changed sys/pcvt_ioctl.h -> machine/pcvt_ioctl.h - * - *---------------------------------------------------------------------------*/ - -/* - * Utility program to wire the mouse emulator control ioctl to the - * user level. Allows setting of any configurable parameter, or - * display the current configuration. - */ - -#include -#include -#include -#include -#include -#include - -static const char *keynames[] = { - "", "esc", "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", - "-", "+", "bksp", "tab", "q", "w", "e", "r", "t", "y", "u", - "i", "o", "p", "[", "]", "enter", "ctrl", "a", "s", "d", "f", - "g", "h", "j", "k", "l", ";", "\"", "`", "lshift", "\\", - "z", "x", "c", "v", "b", "n", "m", ",", ".", "/", "rshift", - "prtscr", "alt", "space", "caps", "f1", "f2", "f3", "f4", - "f5", "f6", "f7", "f8", "f9", "f10", "numlock", "scrolllock", - "kp7", "kp8", "kp9", "kp-", "kp4", "kp5", "kp6", "kp+", - "kp1", "kp2", "kp3", "kp0", "kp." -}; - - -const char *scantoname(int scan) { - if(scan >= sizeof keynames / sizeof(const char *)) - return "???"; - else - return keynames[scan]; -} - -int nametoscan(const char *name) { - int i; - for(i = 0; i < sizeof keynames / sizeof(const char *); i++) - if(strcmp(keynames[i], name) == 0) - return i; - return -1; -} - - -int main(int argc, char **argv) { - int c, errs = 0, fd, do_set = 0; - int left = 0, mid = 0, right = 0, accel = 0, sticky = -1; - struct mousedefs mdef; - - while((c = getopt(argc, argv, "l:m:r:a:s:")) != -1) - switch(c) { - case 'l': - left = nametoscan(optarg); - do_set = 1; - if(left == -1) goto keynameerr; - break; - - case 'm': - mid = nametoscan(optarg); - do_set = 1; - if(mid == -1) goto keynameerr; - break; - - case 'r': - right = nametoscan(optarg); - do_set = 1; - if(right == -1) goto keynameerr; - break; - - keynameerr: - { - fprintf(stderr, "unknown key name: %s\n", - optarg); - errs++; - } - break; - - case 'a': - accel = 1000 * strtol(optarg, 0, 10); - do_set = 1; - break; - - case 's': - if(strcmp(optarg, "0") == 0 - || strcmp(optarg, "false") == 0 - || strcmp(optarg, "no") == 0) - sticky = 0; - else if(strcmp(optarg, "1") == 0 - || strcmp(optarg, "true") == 0 - || strcmp(optarg, "yes") == 0) - sticky = 1; - else { - fprintf(stderr, "invalid argument to -s: %s\n", - optarg); - errs++; - } - do_set = 1; - break; - - default: - errs++; - } - - argc -= optind; - argv += optind; - - if(errs || argc != 1) { - fprintf(stderr, "usage: " - "mouse [-l key][-m key][-r key][-a acctime][-s 0|1] " - "mousedev\n"); - return 2; - } - - if((fd = open(argv[0], O_RDONLY)) < 0) { - perror("open(mousedev)"); - return 2; - } - if(ioctl(fd, KBDMOUSEGET, &mdef) < 0) { - perror("ioctl(KBDMOUSEGET)"); - return 1; - } - - if(!do_set) { - printf("Current mouse emulator definitions:\n" - "left button: %s\n" - "middle button: %s\n" - "right button: %s\n" - "acceleration limit: %d msec\n" - "sticky buttons: %s\n", - scantoname(mdef.leftbutton), - scantoname(mdef.middlebutton), - scantoname(mdef.rightbutton), - mdef.acceltime / 1000, - mdef.stickybuttons? "yes": "no"); - return 0; - } - - if(left) mdef.leftbutton = left & 0x7f; - if(mid) mdef.middlebutton = mid & 0x7f; - if(right) mdef.rightbutton = right & 0x7f; - - if(accel) mdef.acceltime = accel; - if(sticky != -1) mdef.stickybuttons = sticky; - - if(ioctl(fd, KBDMOUSESET, &mdef) < 0) { - perror("ioctl(KBDMOUSESET)"); - return 1; - } - - return 0; -} diff --git a/sys/arch/i386/isa/pcvt/Util/scon/Makefile b/sys/arch/i386/isa/pcvt/Util/scon/Makefile deleted file mode 100644 index 3015544a88fd..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/scon/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -PROG= scon - -MKMAN= no - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/scon/scon.c b/sys/arch/i386/isa/pcvt/Util/scon/scon.c deleted file mode 100644 index e1863ddb548a..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/scon/scon.c +++ /dev/null @@ -1,860 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis and Joerg Wunsch - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - */ - -static char *id = - "@(#)scon.c, 3.30, Last Edit-Date: [Wed Aug 30 13:57:10 1995]"; - -/*---------------------------------------------------------------------------* - * - * history: - * - * -hm moving fd for default device from 1 -> 0 for such things - * as "scon -p list | more" to be possible - * (reported by Gordon L. Burditt, gordon@sneaky.lonestar.org) - * -hm adding option "a" for just returning the type of video adaptor - * -hm removing explicit HGC support, same as MDA ... - * -hm vga type/family/132col support info on -l - * -hm force 24 lines in DEC 25 lines mode and HP 28 lines mode - * -hm fixed bug with 132 column mode display status display - * -jw added 132/80 col mode switching - * -hm removed -h flag, use -? now ... ;-) - * -hm S3 chipsets .. - * -hm Cirrus chipsets support from Onno van der Linden - * -hm -m option, display monitor type - * -hm bugfix, scon -c cleared dest screen, fixed - * -hm patch to support Cirrus CL-GD62x5 from Martin - * - *---------------------------------------------------------------------------*/ - -#include -#include -#include - -#define DEFAULTFD 0 - -int aflag = -1; -int lflag = -1; -int mflag = -1; -int current = -1; -int pflag = -1; -int hflag = -1; -int res = -1; -char *device; -int dflag = -1; -int vflag = 0; -int Pflag = 0; -int tflag = 0; -int fflag = -1; -int colms = 0; -char *onoff; - -unsigned timeout; -struct screeninfo screeninfo; - -#define NVGAPEL 256 - -struct rgb { - unsigned r, g, b; - int dothis; -}; - -static struct rgb palette[NVGAPEL] = { - { 0x00, 0x00, 0x00, 0}, /* 0 - black */ - { 0x00, 0x00, 0x2a, 0}, /* 1 - blue */ - { 0x00, 0x2a, 0x00, 0}, /* 2 - green */ - { 0x00, 0x2a, 0x2a, 0}, /* 3 - cyan */ - { 0x2a, 0x00, 0x00, 0}, /* 4 - red */ - { 0x2a, 0x00, 0x2a, 0}, /* 5 - magenta */ - { 0x2a, 0x2a, 0x00, 0}, /* 6 */ - { 0x2a, 0x2a, 0x2a, 0}, /* 7 - lightgray */ - { 0x00, 0x00, 0x15, 0}, /* 8 */ - { 0x00, 0x00, 0x3f, 0}, /* 9 */ - { 0x00, 0x2a, 0x15, 0}, /* 10 */ - { 0x00, 0x2a, 0x3f, 0}, /* 11 */ - { 0x2a, 0x00, 0x15, 0}, /* 12 */ - { 0x2a, 0x00, 0x3f, 0}, /* 13 */ - { 0x2a, 0x2a, 0x15, 0}, /* 14 */ - { 0x2a, 0x2a, 0x3f, 0}, /* 15 */ - { 0x00, 0x15, 0x00, 0}, /* 16 */ - { 0x00, 0x15, 0x2a, 0}, /* 17 */ - { 0x00, 0x3f, 0x00, 0}, /* 18 */ - { 0x00, 0x3f, 0x2a, 0}, /* 19 */ - { 0x2a, 0x15, 0x00, 0}, /* 20 - brown */ - { 0x2a, 0x15, 0x2a, 0}, /* 21 */ - { 0x2a, 0x3f, 0x00, 0}, /* 22 */ - { 0x2a, 0x3f, 0x2a, 0}, /* 23 */ - { 0x00, 0x15, 0x15, 0}, /* 24 */ - { 0x00, 0x15, 0x3f, 0}, /* 25 */ - { 0x00, 0x3f, 0x15, 0}, /* 26 */ - { 0x00, 0x3f, 0x3f, 0}, /* 27 */ - { 0x2a, 0x15, 0x15, 0}, /* 28 */ - { 0x2a, 0x15, 0x3f, 0}, /* 29 */ - { 0x2a, 0x3f, 0x15, 0}, /* 30 */ - { 0x2a, 0x3f, 0x3f, 0}, /* 31 */ - { 0x15, 0x00, 0x00, 0}, /* 32 */ - { 0x15, 0x00, 0x2a, 0}, /* 33 */ - { 0x15, 0x2a, 0x00, 0}, /* 34 */ - { 0x15, 0x2a, 0x2a, 0}, /* 35 */ - { 0x3f, 0x00, 0x00, 0}, /* 36 */ - { 0x3f, 0x00, 0x2a, 0}, /* 37 */ - { 0x3f, 0x2a, 0x00, 0}, /* 38 */ - { 0x3f, 0x2a, 0x2a, 0}, /* 39 */ - { 0x15, 0x00, 0x15, 0}, /* 40 */ - { 0x15, 0x00, 0x3f, 0}, /* 41 */ - { 0x15, 0x2a, 0x15, 0}, /* 42 */ - { 0x15, 0x2a, 0x3f, 0}, /* 43 */ - { 0x3f, 0x00, 0x15, 0}, /* 44 */ - { 0x3f, 0x00, 0x3f, 0}, /* 45 */ - { 0x3f, 0x2a, 0x15, 0}, /* 46 */ - { 0x3f, 0x2a, 0x3f, 0}, /* 47 */ - { 0x15, 0x15, 0x00, 0}, /* 48 */ - { 0x15, 0x15, 0x2a, 0}, /* 49 */ - { 0x15, 0x3f, 0x00, 0}, /* 50 */ - { 0x15, 0x3f, 0x2a, 0}, /* 51 */ - { 0x3f, 0x15, 0x00, 0}, /* 52 */ - { 0x3f, 0x15, 0x2a, 0}, /* 53 */ - { 0x3f, 0x3f, 0x00, 0}, /* 54 */ - { 0x3f, 0x3f, 0x2a, 0}, /* 55 */ - { 0x15, 0x15, 0x15, 0}, /* 56 - darkgray */ - { 0x15, 0x15, 0x3f, 0}, /* 57 - lightblue */ - { 0x15, 0x3f, 0x15, 0}, /* 58 - lightgreen */ - { 0x15, 0x3f, 0x3f, 0}, /* 59 - lightcyan */ - { 0x3f, 0x15, 0x15, 0}, /* 60 - lightred */ - { 0x3f, 0x15, 0x3f, 0}, /* 61 - lightmagenta */ - { 0x3f, 0x3f, 0x15, 0}, /* 62 - yellow */ - { 0x3f, 0x3f, 0x3f, 0}, /* 63 - white */ - { 0x00, 0x00, 0x00, 0} /* 64 ... - empty */ -}; - -static struct colname { - const char *name; - unsigned idx; -} colnames[] = { - {"black", 0}, - {"blue", 1}, - {"green", 2}, - {"cyan", 3}, - {"red", 4}, - {"magenta", 5}, - {"brown", 20}, - {"lightgray", 7}, - {"lightgrey", 7}, - {"darkgray", 56}, - {"darkgrey", 56}, - {"lightblue", 57}, - {"lightgreen", 58}, - {"lightcyan", 59}, - {"lightred", 60}, - {"lightmagenta", 61}, - {"yellow", 62}, - {"white", 63}, - /* must be terminator: */ {(const char *)NULL, 0} -}; - - -static void parsepopt(char *arg, unsigned *idx, - unsigned *r, unsigned *g, unsigned *b); -static void printpalette(int fd); - -main(argc,argv) -int argc; -char *argv[]; -{ - extern int optind; - extern int opterr; - extern char *optarg; - - int c; - int fd; - - while( (c = getopt(argc, argv, "ac:d:f:HVlms:t:vp:18")) != -1) - { - switch(c) - { - case 'a': - aflag = 1; - break; - - case 'l': - lflag = 1; - break; - - case 'm': - mflag = 1; - break; - - case 'c': - current = atoi(optarg); - break; - - case 'd': - device = optarg; - dflag = 1; - break; - - case 'f': - onoff = optarg; - fflag = 1; - break; - - case 'V': - pflag = 1; - break; - - case 'H': - hflag = 1; - break; - - case 's': - if (!strncmp(optarg, "25", 2)) - res = SIZ_25ROWS; - else if(!strncmp(optarg, "28", 2)) - res = SIZ_28ROWS; - else if(!strncmp(optarg, "35", 2)) - res = SIZ_35ROWS; - else if(!strncmp(optarg, "40", 2)) - res = SIZ_40ROWS; - else if(!strncmp(optarg, "43", 2)) - res = SIZ_43ROWS; - else if(!strncmp(optarg, "50", 2)) - res = SIZ_50ROWS; - break; - - case 'v': - vflag++; - break; - - case 'p': - if(!strcmp(optarg, "list")) - { - if(Pflag) - { - fprintf(stderr, - "-p list is mutual exclusive " - "with other -p options\n"); - return 2; - } - Pflag = 3; - } - else if(!strcmp(optarg, "default")) - { - if(Pflag) - { - fprintf(stderr, - "multiple -p default not " - "allowed\n"); - return 2; - } - Pflag = 2; - } else { - unsigned idx, r, g, b; - - if(Pflag > 1) - { - fprintf(stderr, - "-p default and -p i,r,g,b " - "ambiguous\n"); - return 2; - } - Pflag = 1; - parsepopt(optarg, &idx, &r, &g, &b); - if(idx >= NVGAPEL) - { - fprintf(stderr, - "index %u in -p option " - "out of range\n", idx); - return 2; - } - palette[idx].r = r; - palette[idx].g = g; - palette[idx].b = b; - palette[idx].dothis = 1; - } - break; - - case 't': - tflag++; - timeout = atoi(optarg); - break; - - case '1': - colms = 132; - break; - - case '8': - colms = 80; - break; - - case '?': - default: - usage(); - break; - } - } - - if((pflag == 1) && (hflag == 1)) - usage(); - - if(dflag == -1 && lflag == -1 && current == -1 && pflag == -1 && - hflag == -1 && res == -1 && Pflag == 0 && tflag == 0 && fflag == -1 - && colms == 0 && mflag == -1) - { - lflag = 1; - } - - if(dflag == -1) - { - if(vflag) - printf("using current device\n"); - fd = DEFAULTFD; /* -hm, Feb 12 1993 */ - } - else - { - if((fd = open(device, O_RDWR)) == -1) - { - char buffer[80]; - strcpy(buffer,"ERROR opening "); - strcat(buffer,device); - perror(buffer); - exit(1); - } - if(vflag) - printf("using device %s\n",device); - } - - if(aflag == 1) /* return adaptor type */ - { - printadaptor(fd); - exit(0); - } - - if(mflag == 1) /* return monitor type */ - { - printmonitor(fd); - exit(0); - } - - if(lflag == 1) /* list information */ - { - if(vflag) - printf("processing option -l, listing screen info\n"); - printinfo(fd); - exit(0); - } - - if(tflag) /* set screen saver timeout */ - { - if(vflag) - { - printf( - "processing option -t, setting screen saver timeout: " - ); - if(timeout) - printf("new timeout = %d s\n", timeout); - else - printf("turned off\n"); - } - - if(ioctl(fd, VGASCREENSAVER, &timeout) < 0) - { - perror("ioctl(VGASCREENSAVER)"); - fprintf(stderr, "Check the driver, the screensaver is probably not compiled in!\n"); - exit(2); - } - goto success; - } - - if(colms) - { - if(vflag) - printf("Setting number of columns to %d\n", colms); - if(ioctl(fd, VGASETCOLMS, &colms) < 0) - { - perror("ioctl(VGASETCOLMS)"); - exit(2); - } - goto success; - } - - if(Pflag == 3) - { - /* listing VGA palette */ - if(vflag) - printf("processing option -p list, " - "listing VGA palette\n"); - - printpalette(fd); - goto success; - } - - if(Pflag) - { - unsigned int idx; - - /* setting VGA palette */ - if(vflag) - printf("processing option -p, setting VGA palette%s\n", - Pflag == 2? " to default": ""); - - for(idx = 0; idx < NVGAPEL; idx++) - if(Pflag == 2 || palette[idx].dothis) - { - struct vgapel p; - p.idx = idx; - p.r = palette[idx].r; - p.g = palette[idx].g; - p.b = palette[idx].b; - if(ioctl(fd, VGAWRITEPEL, (caddr_t)&p) < 0) - { - perror("ioctl(fd, VGAWRITEPEL)"); - return 2; - } - } - goto success; - } - - screeninfo.screen_no = -1; /* We are using fd */ - screeninfo.current_screen = current; - screeninfo.pure_vt_mode = -1; - screeninfo.screen_size = res; - screeninfo.force_24lines = -1; - - if(current != -1) /* set current screen */ - { - if(vflag) - printf("processing option -c, setting current screen to %d\n",current); - - if(ioctl(1, VGASETSCREEN, &screeninfo) == -1) - { - perror("ioctl VGASETSCREEN failed"); - exit(1); - } - exit(0); - } - - if(pflag == 1) - { - if(vflag) - printf("processing option -V, setting emulation to pure VT220\n"); - screeninfo.pure_vt_mode = M_PUREVT; - } - else if(hflag == 1) - { - if(vflag) - printf("processing option -H, setting emulation to VT220 + HP Labels\n"); - screeninfo.pure_vt_mode = M_HPVT; - } - else - { - if(vflag) - printf("no change in terminal emulation\n"); - } - - if(vflag) - { - if(res == -1) - printf("no change in screen resolution\n"); - else if(res == SIZ_25ROWS) - printf("change screen resolution to 25 lines\n"); - else if(res == SIZ_28ROWS) - printf("change screen resolution to 28 lines\n"); - else if(res == SIZ_35ROWS) - printf("change screen resolution to 35 lines\n"); - else if(res == SIZ_40ROWS) - printf("change screen resolution to 40 lines\n"); - else if(res == SIZ_43ROWS) - printf("change screen resolution to 43 lines\n"); - else if(res == SIZ_50ROWS) - printf("change screen resolution to 50 lines\n"); - } - - if(fflag == 1) /* force 24 lines on/off */ - { - if(!strcmp(onoff, "on")) - { - fflag = 1; - } - else if(!strcmp(onoff, "off")) - { - fflag = 0; - } - else - { - fprintf(stderr,"you must specify 'on' or 'off' with -f option!\n"); - exit(1); - } - } - screeninfo.force_24lines = fflag; - - if(ioctl(fd, VGASETSCREEN, &screeninfo) == -1) - { - perror("ioctl VGASETSCREEN failed"); - exit(1); - } -success: - if(vflag) - printf("successful execution of ioctl VGASETSCREEN!\n"); - exit(0); -} - -usage() -{ - fprintf(stderr,"\nscon - screen control utility for the pcvt video driver\n"); - fprintf(stderr,"usage: scon -a -l -m -v -c [n] -d [dev] -f [on|off] -V -H -s [n]\n"); - fprintf(stderr,"usage: scon -p [default | list | i,r,g,b] | -t [sec] | -1 | -8\n"); - fprintf(stderr," -a list video adaptor type (MDA,CGA,EGA or VGA)\n"); - fprintf(stderr," -c switch current virtual screen to \n"); - fprintf(stderr," -d set parameters(-V|-H|-s) for virtual device\n"); - fprintf(stderr," -f force 24 lines in VT 25 lines and HP 28 lines mode\n"); - fprintf(stderr," -H set VT220/HP emulation mode for a virtual screen\n"); - fprintf(stderr," -l list current parameters for a virtual screen\n"); - fprintf(stderr," -m report monitor type (MONO/COLOR)\n"); - fprintf(stderr," -p default set default VGA palette\n"); - fprintf(stderr," -p list list current VGA palette\n"); - fprintf(stderr," -p set VGA palette entry i to r/g/b\n"); - fprintf(stderr," -p set VGA palette entry for color name to r/g/b\n"); - fprintf(stderr," -s set 25, 28, 35, 40, 43 or 50 lines for a virtual screen\n"); - fprintf(stderr," -t set screen saver timeout [seconds]\n"); - fprintf(stderr," -1 set 132 columns mode\n"); - fprintf(stderr," -8 set 80 columns mode\n"); - fprintf(stderr," -v verbose mode\n"); - fprintf(stderr," -V set pure VT220 emulation for a virtual screen\n"); - fprintf(stderr," -? display help (this message)\n\n"); - exit(1); -} - -printadaptor(fd) -int fd; -{ - if(ioctl(fd, VGAGETSCREEN, &screeninfo) == -1) - { - perror("ioctl VGAGETSCREEN failed"); - exit(1); - } - switch(screeninfo.adaptor_type) - { - default: - case UNKNOWN_ADAPTOR: - printf("UNKNOWN\n"); - break; - - case MDA_ADAPTOR: - printf("MDA\n"); - break; - - case CGA_ADAPTOR: - printf("CGA\n"); - break; - - case EGA_ADAPTOR: - printf("EGA\n"); - break; - - case VGA_ADAPTOR: - printf("VGA\n"); - break; - } -} - -printmonitor(fd) -int fd; -{ - if(ioctl(fd, VGAGETSCREEN, &screeninfo) == -1) - { - perror("ioctl VGAGETSCREEN failed"); - exit(1); - } - switch(screeninfo.monitor_type) - { - default: - printf("UNKNOWN\n"); - break; - - case MONITOR_MONO: - printf("MONO\n"); - break; - - case MONITOR_COLOR: - printf("COLOR\n"); - break; - } -} - -char *vga_type(int number) -{ - static char *vga_tab[] = { - "Generic VGA", - "ET4000", - "ET3000", - "PVGA1A", - "WD90C00", - "WD90C10", - "WD90C11", - "VIDEO 7 VEGA", - "VIDEO 7 FAST", - "VIDEO 7 VER5", - "VIDEO 7 1024I", - "Unknown VIDEO 7", - "TVGA 8800BR", - "TVGA 8800CS", - "TVGA 8900B", - "TVGA 8900C", - "TVGA 8900CL", - "TVGA 9000", - "TVGA 9100", - "TVGA 9200", - "Unknown TRIDENT", - "S3 80C911", - "S3 80C924", - "S3 80C801/80C805", - "S3 80C928", - "Unknown S3", - "CL-GD5402", - "CL-GD5402r1", - "CL-GD5420", - "CL-GD5420r1", - "CL-GD5422", - "CL-GD5424", - "CL-GD5426", - "CL-GD5428", - "CL-GD5430", - "CL-GD62x5", - "Unknown Cirrus", - - }; - return(vga_tab[number]); -} - -char *vga_family(int number) -{ - static char *vga_tab[] = { - "Generic VGA", - "Tseng Labs", - "Western Digital", - "Video Seven", - "Trident", - "S3 Incorporated", - "Cirrus Logic", - }; - return(vga_tab[number]); -} - -printinfo(fd) -int fd; -{ - if(ioctl(fd, VGAGETSCREEN, &screeninfo) == -1) - { - perror("ioctl VGAGETSCREEN failed"); - exit(1); - } - - printf( "\nVideo Adaptor Type = "); - - switch(screeninfo.adaptor_type) - { - default: - case UNKNOWN_ADAPTOR: - printf("UNKNOWN Video Adaptor\n"); - break; - - case MDA_ADAPTOR: - printf("MDA - Monochrome Display Adaptor\n"); - break; - - case CGA_ADAPTOR: - printf("CGA - Color Graphics Adaptor\n"); - break; - - case EGA_ADAPTOR: - printf("EGA - Enhanced Graphics Adaptor\n"); - break; - - case VGA_ADAPTOR: - printf("VGA - Video Graphics Adaptor/Array\n"); - printf(" VGA Chipset Manufacturer = %s\n", - vga_family(screeninfo.vga_family)); - printf(" VGA Chipset Type = %s\n", - vga_type(screeninfo.vga_type)); - printf(" Support for 132 Column Mode = %s\n", - screeninfo.vga_132 ? "Yes" : "No"); - break; - } - - printf( "Display Monitor Type = "); - - switch(screeninfo.monitor_type) - { - default: - printf("UNKNOWN Monitor Type\n"); - break; - - case MONITOR_MONO: - printf("Monochrome Monitor\n"); - break; - - case MONITOR_COLOR: - printf("Color Monitor\n"); - break; - } - - printf( "Number of Downloadable Fonts = %d\n",screeninfo.totalfonts); - printf( "Number of Virtual Screens = %d\n",screeninfo.totalscreens); - printf( "Info Request Screen Number = %d\n",screeninfo.screen_no); - printf( "Current Displayed Screen = %d\n",screeninfo.current_screen); - - if(screeninfo.pure_vt_mode == M_PUREVT) - printf( "Terminal Emulation Mode = VT220\n"); - else - printf( "Terminal Emulation Mode = VT220 with HP Features\n"); - - printf( "Lines = "); - - switch(screeninfo.screen_size) - { - case SIZ_25ROWS: - printf( "25\n"); - break; - - case SIZ_28ROWS: - printf( "28\n"); - break; - - case SIZ_35ROWS: - printf( "35\n"); - break; - - case SIZ_40ROWS: - printf( "40\n"); - break; - - case SIZ_43ROWS: - printf( "43\n"); - break; - - case SIZ_50ROWS: - printf( "50\n"); - break; - - default: - printf( "UNKNOWN\n"); - break; - } - printf( "Force 24 Lines = %s", - screeninfo.force_24lines ? "Yes" : "No"); - - printf("\n\n"); -} - -static const char *findname(unsigned idx) -{ - /* try to find a name for palette entry idx */ - /* if multiple names exist, returns first matching */ - register struct colname *cnp; - - for(cnp = colnames; cnp->name; cnp++) - if(cnp->idx == idx) - return cnp->name; - - /* not found */ - return (const char *)NULL; -} - -static void printpalette(int fd) -{ - register unsigned idx, last; - - for(idx = 0; idx < NVGAPEL; idx++) - { - struct vgapel p; - p.idx = idx; - if(ioctl(fd, VGAREADPEL, &p) < 0) - { - perror("ioctl(VGAREADPEL)"); - exit(2); - } - palette[idx].r = p.r; - palette[idx].g = p.g; - palette[idx].b = p.b; - } - - /* find last non-empty entry */ - for(last = NVGAPEL - 1; last; last--) - if(palette[last].r || palette[last].g || palette[last].b) - break; - - if(last != NVGAPEL - 1) - last++; - - /* now, everything's collected. print out table */ - printf("VGA palette status\n"); - printf("index red green blue name\n"); - for(idx = 0; idx < last; idx++) - { - const char *cp; - printf("%5d %5d %5d %5d", - idx, palette[idx].r, palette[idx].g, palette[idx].b); - if(cp = findname(idx)) - printf(" %s\n", cp); - else - putchar('\n'); - } - putchar('\n'); -} - - -static void parsepopt(char *arg, unsigned *idx, - unsigned *r, unsigned *g, unsigned *b) -{ - char firstarg[21]; - register unsigned i; - - if(sscanf(arg, "%20[a-zA-Z0-9]%*[,:]%u,%u,%u", firstarg, r, g, b) < 4 - || strlen(firstarg) == 0) { - fprintf(stderr, "too few args in -p i,r,g,b\n"); - exit(2); - } - - if(firstarg[0] >= '0' && firstarg[0] <= '9') { - *idx = strtoul(firstarg, NULL, 10); - return; - } - - for(i = 0; colnames[i].name; i++) - if(strcasecmp(colnames[i].name, firstarg) == 0) { - *idx = colnames[i].idx; - return; - } - fprintf(stderr, "arg ``%s'' in -p option not recognized\n", - firstarg); - exit(2); -} diff --git a/sys/arch/i386/isa/pcvt/Util/set2061/CAUTION b/sys/arch/i386/isa/pcvt/Util/set2061/CAUTION deleted file mode 100644 index e1eba06aaa4e..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/set2061/CAUTION +++ /dev/null @@ -1,28 +0,0 @@ -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION - - THE USE OF THIS PROGRAM MAY DESTROY YOUR MONITOR !!! - ==================================================== - - IF YOU DON'T KNOW WHAT YOU ARE DOING, STAY AWAY FROM IT !!! - =========================================================== - - THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND - ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY - AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, - INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, - EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION - diff --git a/sys/arch/i386/isa/pcvt/Util/set2061/ICD2061Aalt.c b/sys/arch/i386/isa/pcvt/Util/set2061/ICD2061Aalt.c deleted file mode 100644 index 248476ad7284..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/set2061/ICD2061Aalt.c +++ /dev/null @@ -1,297 +0,0 @@ -/* - * This code is derived from code available from the STB bulletin board - */ - -/* $XFree86: mit/server/ddx/x386/common_hw/ICD2061Aalt.c,v 2.6 1994/04/15 05:10:30 dawes Exp $ */ - -#ifndef KERNEL -#include "compiler.h" -#else -#define GCCUSESGAS -#define PCVT_STANDALONE 1 -#endif - -#define SEQREG 0x03C4 -#define MISCREG 0x03C2 -#define MISCREAD 0x03CC - -double fref = 14.31818 * 2.0; -char ascclk[] = "VIDEO CLOCK ?"; - -unsigned short clknum; -unsigned short vlbus_flag; -unsigned short card; -unsigned short crtcaddr; -unsigned short clockreg; - -static double range[15] = {50.0, 51.0, 53.2, 58.5, 60.7, 64.4, 66.8, 73.5, - 75.6, 80.9, 83.2, 91.5, 100.0, 120.0, 120.0}; - -#ifdef __STDC__ -static double genratio(unsigned int *p, unsigned int *q, double tgt); -static double f(unsigned int p, unsigned int q, double basefreq); -#if 0 -static void prtbinary(unsigned int size, unsigned int val); -#endif -static void wait_vb(); -static void wrt_clk_bit(unsigned int value); -static void init_clock(unsigned long setup, unsigned short crtcport); -#else -static double genratio(); -static double f(); -#if 0 -static void prtbinary(); -#endif -static void wait_vb(); -static void wrt_clk_bit(); -static void init_clock(); -#endif - -void AltICD2061SetClock(frequency, select) -register long frequency; /* in Hz */ -int select; -{ - unsigned int m, mval, ival; - int i; - long dwv; - double realval; - double freq, fvco; - double dev, devx; - double delta, deltax; - unsigned int p, q; - unsigned int bestp, bestq; - unsigned char tmp; - - crtcaddr=(inb(0x3CC) & 0x01) ? 0x3D4 : 0x3B4; - - - outb(crtcaddr, 0x11); /* Unlock CRTC registers */ - tmp = inb(crtcaddr + 1); - outb(crtcaddr + 1, tmp & ~0x80); - - outw(crtcaddr, 0x4838); /* Unlock S3 register set */ - outw(crtcaddr, 0xA039); - - clknum = select; - - freq = ((double)frequency)/1000000.0; - if (freq > range[14]) - freq =range[14]; - else if (freq <= 6.99) - freq = 7.0; - -/* - * Calculate values to load into ICD 2061A clock chip to set frequency - */ - delta = 999.0; - dev = 999.0; - ival = 99; - mval = 99; - - fvco = freq / 2; - for (m = 0; m < 8; m++) { - fvco *= 2.0; - for (i = 14; i >= 0; i--) - if (fvco >= range[i]) - break; - if (i < 0) - continue; - if (i == 14) - break; - devx = (fvco - (range[i] + range[i+1])/2)/fvco; - if (devx < 0) - devx = -devx; - deltax = genratio(&p, &q, fvco); - if (delta < deltax) - continue; - if (deltax < delta || devx < dev) { - bestp = p; - bestq = q; - delta = deltax; - dev = devx; - ival = i; - mval = m; - } - } - fvco = fref; - for (m=0; m 128) - mmax = 128; - while (m < mmax) { - test = f(m, k, fref) - tgt; - if (test < 0) test = -test; - if (mindiff > test) { - mindiff = test; - *p = m; - *q = k; - } - m++; - } - } - return (mindiff); - } - -#if 0 -static void prtbinary(size, val) - unsigned int size; - unsigned int val; - { - unsigned int mask; - int k; - - mask = 1; - - for (k=size; --k > 0 || mask <= val/2;) - mask <<= 1; - - while (mask) { - fputc((mask&val)? '1': '0' , stderr); - mask >>= 1; - } - } -#endif - -static void wait_vb() - { - while ((inb(crtcaddr+6) & 0x08) == 0) - ; - while (inb(crtcaddr+6) & 0x08) - ; - } - - -#ifdef __STDC__ -static void init_clock(unsigned long setup, unsigned short crtcport) -#else -static void init_clock(setup, crtcport) - unsigned long setup; - unsigned short crtcport; -#endif - { - unsigned char nclk[2], clk[2]; - unsigned short restore42; - unsigned short oldclk; - unsigned short bitval; - int i; - unsigned char c; - -#ifndef PCVT_STANDALONE - (void)xf86DisableInterrupts(); -#endif - - oldclk = inb(0x3CC); - - outb(crtcport, 0x42); - restore42 = inb(crtcport+1); - - outw(0x3C4, 0x0100); - - outb(0x3C4, 1); - c = inb(0x3C5); - outb(0x3C5, 0x20 | c); - - outb(crtcport, 0x42); - outb(crtcport+1, 0x03); - - outw(0x3C4, 0x0300); - - nclk[0] = oldclk & 0xF3; - nclk[1] = nclk[0] | 0x08; - clk[0] = nclk[0] | 0x04; - clk[1] = nclk[0] | 0x0C; - - outb(crtcport, 0x42); - i = inw(crtcport); - - outw(0x3C4, 0x0100); - - wrt_clk_bit(oldclk | 0x08); - wrt_clk_bit(oldclk | 0x0C); - for (i=0; i<5; i++) { - wrt_clk_bit(nclk[1]); - wrt_clk_bit(clk[1]); - } - wrt_clk_bit(nclk[1]); - wrt_clk_bit(nclk[0]); - wrt_clk_bit(clk[0]); - wrt_clk_bit(nclk[0]); - wrt_clk_bit(clk[0]); - for (i=0; i<24; i++) { - bitval = setup & 0x01; - setup >>= 1; - wrt_clk_bit(clk[1-bitval]); - wrt_clk_bit(nclk[1-bitval]); - wrt_clk_bit(nclk[bitval]); - wrt_clk_bit(clk[bitval]); - } - wrt_clk_bit(clk[1]); - wrt_clk_bit(nclk[1]); - wrt_clk_bit(clk[1]); - - outb(0x3C4, 1); - c = inb(0x3C5); - outb(0x3C5, 0xDF & c); - - outb(crtcport, 0x42); - outb(crtcport+1, restore42); - - outb(0x3C2, oldclk); - - outw(0x3C4, 0x0300); - -#ifndef PCVT_STANDALONE - xf86EnableInterrupts(); -#endif - - } - -static void wrt_clk_bit(value) - unsigned int value; - { - int j; - - outb(0x3C2, value); - for (j=2; --j; ) - inb(0x200); - } diff --git a/sys/arch/i386/isa/pcvt/Util/set2061/Makefile b/sys/arch/i386/isa/pcvt/Util/set2061/Makefile deleted file mode 100644 index 8a586a75a3e6..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/set2061/Makefile +++ /dev/null @@ -1,10 +0,0 @@ -PROG= set2061 -SRCS= main.c ICD2061Aalt.c -CFLAGS+= -DGCCUSESGAS -DPCVT_STANDALONE -MKMAN= no - -all: $(PROG) - -.include - -$(PROG): compiler.h diff --git a/sys/arch/i386/isa/pcvt/Util/set2061/README b/sys/arch/i386/isa/pcvt/Util/set2061/README deleted file mode 100644 index fd5ec8689352..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/set2061/README +++ /dev/null @@ -1,22 +0,0 @@ -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION - - THE USE OF THIS PROGRAM MAY DESTROY YOUR MONITOR !!! - ==================================================== - - IF YOU DON'T KNOW WHAT YOU ARE DOING, STAY AWAY FROM IT !!! - =========================================================== - -Read the file "CAUTION" before proceeding !!! - -The files: - - ICD2061Aalt.c and - compiler.h - -come from the Xfree86 2.1 distribution and have been slightly modified to -fit into a non-XFree environment. - -I use it to program the clock generator ICD2061a on my S3 928 based ELSA -Winner VGA board to 40MHz for clock generator #2: set2061 -n2 -f40000000. - -This enables me to use 132 columns mode on this VGA board. diff --git a/sys/arch/i386/isa/pcvt/Util/set2061/compiler.h b/sys/arch/i386/isa/pcvt/Util/set2061/compiler.h deleted file mode 100644 index 84b38b8d5a2b..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/set2061/compiler.h +++ /dev/null @@ -1,340 +0,0 @@ -/* $NetBSD: compiler.h,v 1.3 1997/10/13 14:22:29 lukem Exp $ */ -/* $XFree86: mit/server/ddx/x386/common/compiler.h,v 2.3 1993/10/03 14:55:28 dawes Exp $ */ -/* - * Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany. - * - * Permission to use, copy, modify, distribute, and sell this software and its - * documentation for any purpose is hereby granted without fee, provided that - * the above copyright notice appear in all copies and that both that - * copyright notice and this permission notice appear in supporting - * documentation, and that the name of Thomas Roell not be used in - * advertising or publicity pertaining to distribution of the software without - * specific, written prior permission. Thomas Roell makes no representations - * about the suitability of this software for any purpose. It is provided - * "as is" without express or implied warranty. - * - * THOMAS ROELL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, - * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO - * EVENT SHALL THOMAS ROELL BE LIABLE FOR ANY SPECIAL, INDIRECT OR - * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, - * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER - * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR - * PERFORMANCE OF THIS SOFTWARE. - */ - - -#ifndef _COMPILER_H -#define _COMPILER_H - -#ifndef __STDC__ -# ifdef signed -# undef signed -# endif -# ifdef volatile -# undef volatile -# endif -# ifdef const -# undef const -# endif -# define signed /**/ -# ifdef __GNUC__ -# define volatile __volatile__ -# define const __const__ -# else -# define const /**/ -# endif /* __GNUC__ */ -#endif /* !__STDC__ */ - -#ifdef NO_INLINE - -extern void outb(); -extern void outw(); -extern unsigned int inb(); -extern unsigned int inw(); -#if NeedFunctionPrototypes -extern unsigned char rdinx(unsigned short, unsigned char); -extern void wrinx(unsigned short, unsigned char, unsigned char); -extern void modinx(unsigned short, unsigned char, unsigned char, unsigned char); -extern int testrg(unsigned short, unsigned char); -extern int textinx2(unsigned short, unsigned char, unsigned char); -extern int textinx(unsigned short, unsigned char); -#else /* NeedFunctionProtoypes */ -extern unsigned char rdinx(); -extern void wrinx(); -extern void modinx(); -extern int testrg(); -extern int textinx2(); -extern int textinx(); -#endif /* NeedFunctionProtoypes */ - -#else /* NO_INLINE */ - -#ifdef __GNUC__ - -#ifndef FAKEIT -#ifdef GCCUSESGAS - -/* - * If gcc uses gas rather than the native assembler, the syntax of these - * inlines has to be different. DHD - */ - -static __inline__ void -outb(port, val) -short port; -char val; -{ - __asm__ __volatile__("outb %0,%1" : :"a" (val), "d" (port)); -} - - -static __inline__ void -outw(port, val) -short port; -short val; -{ - __asm__ __volatile__("outw %0,%1" : :"a" (val), "d" (port)); -} - -static __inline__ unsigned int -inb(port) -short port; -{ - unsigned char ret; - __asm__ __volatile__("inb %1,%0" : - "=a" (ret) : - "d" (port)); - return ret; -} - -static __inline__ unsigned int -inw(port) -short port; -{ - unsigned short ret; - __asm__ __volatile__("inw %1,%0" : - "=a" (ret) : - "d" (port)); - return ret; -} - -#else /* GCCUSESGAS */ - -static __inline__ void -outb(port, val) - short port; - char val; -{ - __asm__ __volatile__("out%B0 (%1)" : :"a" (val), "d" (port)); -} - -static __inline__ void -outw(port, val) - short port; - short val; -{ - __asm__ __volatile__("out%W0 (%1)" : :"a" (val), "d" (port)); -} - -static __inline__ unsigned int -inb(port) - short port; -{ - unsigned char ret; - __asm__ __volatile__("in%B0 (%1)" : - "=a" (ret) : - "d" (port)); - return ret; -} - -static __inline__ unsigned int -inw(port) - short port; -{ - unsigned short ret; - __asm__ __volatile__("in%W0 (%1)" : - "=a" (ret) : - "d" (port)); - return ret; -} - -#endif /* GCCUSESGAS */ - -#else /* FAKEIT */ - -static __inline__ void -outb(port, val) - short port; - char val; -{ -} - -static __inline__ void -outw(port, val) - short port; - short val; -{ -} - -static __inline__ unsigned int -inb(port) - short port; -{ - return 0; -} - -static __inline__ unsigned int -inw(port) - short port; -{ - return 0; -} - -#endif /* FAKEIT */ - -#else /* __GNUC__ */ -#if !defined(AMOEBA) && !defined(_MINIX) -# if defined(__STDC__) && (__STDC__ == 1) -# define asm __asm -# endif -# ifdef SVR4 -# include -# ifndef __USLC__ -# define __USLC__ -# endif -# endif -# include -#endif -#endif - -/* - *----------------------------------------------------------------------- - * Port manipulation convenience functions - *----------------------------------------------------------------------- - */ - -#ifndef __GNUC__ -#define __inline__ /**/ -#endif - -/* - * rdinx - read the indexed byte port 'port', index 'ind', and return its value - */ -static __inline__ unsigned char -#ifdef __STDC__ -rdinx(unsigned short port, unsigned char ind) -#else -rdinx(port, ind) -unsigned short port; -unsigned char ind; -#endif -{ - if (port == 0x3C0) /* reset attribute flip-flop */ - (void) inb(0x3DA); - outb(port, ind); - return(inb(port+1)); -} - -/* - * wrinx - write 'val' to port 'port', index 'ind' - */ -static __inline__ void -#ifdef __STDC__ -wrinx(unsigned short port, unsigned char ind, unsigned char val) -#else -wrinx(port, ind, val) -unsigned short port; -unsigned char ind, val; -#endif -{ - outb(port, ind); - outb(port+1, val); -} - -/* - * modinx - in register 'port', index 'ind', set the bits in 'mask' as in 'new'; - * the other bits are unchanged. - */ -static __inline__ void -#ifdef __STDC__ -modinx(unsigned short port, unsigned char ind, - unsigned char mask, unsigned char new) -#else -modinx(port, ind, mask, new) -unsigned short port; -unsigned char ind, mask, new; -#endif -{ - unsigned char tmp; - - tmp = (rdinx(port, ind) & ~mask) | (new & mask); - wrinx(port, ind, tmp); -} - -/* - * tstrg - returns true iff the bits in 'mask' of register 'port' are - * readable & writable. - */ - -static __inline__ int -#ifdef __STDC__ -testrg(unsigned short port, unsigned char mask) -#else -tstrg(port, mask) -unsigned short port; -unsigned char mask; -#endif -{ - unsigned char old, new1, new2; - - old = inb(port); - outb(port, old & ~mask); - new1 = inb(port) & mask; - outb(port, old | mask); - new2 = inb(port) & mask; - outb(port, old); - return((new1 == 0) && (new2 == mask)); -} - -/* - * testinx2 - returns true iff the bits in 'mask' of register 'port', index - * 'ind' are readable & writable. - */ -static __inline__ int -#ifdef __STDC__ -testinx2(unsigned short port, unsigned char ind, unsigned char mask) -#else -testinx2(port, ind, mask) -unsigned short port; -unsigned char ind, mask; -#endif -{ - unsigned char old, new1, new2; - - old = rdinx(port, ind); - wrinx(port, ind, old & ~mask); - new1 = rdinx(port, ind) & mask; - wrinx(port, ind, old | mask); - new2 = rdinx(port, ind) & mask; - wrinx(port, ind, old); - return((new1 == 0) && (new2 == mask)); -} - -/* - * testinx - returns true iff all bits of register 'port', index 'ind' are - * readable & writable. - */ -static __inline__ int -#ifdef __STDC__ -testinx(unsigned short port, unsigned char ind) -#else -testinx(port, ind, mask) -unsigned short port; -unsigned char ind; -#endif -{ - return(testinx2(port, ind, 0xFF)); -} - -#endif /* NO_INLINE */ -#endif /* _COMPILER_H */ diff --git a/sys/arch/i386/isa/pcvt/Util/set2061/main.c b/sys/arch/i386/isa/pcvt/Util/set2061/main.c deleted file mode 100644 index a7a020d6e28e..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/set2061/main.c +++ /dev/null @@ -1,112 +0,0 @@ -/* - * Copyright (c) 1994 Hellmuth Michaelis - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - */ - -static char *id = - "@(#)set2061.c, 1.00, Last Edit-Date: [Sun Jan 15 19:52:05 1995]"; - -/*---------------------------------------------------------------------------* - * - * history: - * - * -hm start using 132 columns on my Elsa Winner - * - *---------------------------------------------------------------------------*/ - -#include -#include -#include - -#define DEFAULTFD 0 - -void AltICD2061SetClock(long frequency, int select); - -main(argc,argv) -int argc; -char *argv[]; -{ - extern int optind; - extern int opterr; - extern char *optarg; - - int fd; - int c; - long freq = -1; - int no = -1; - - while( (c = getopt(argc, argv, "f:n:")) != -1) - { - switch(c) - { - case 'f': - freq = atoi(optarg); - break; - - case 'n': - no = atoi(optarg); - break; - - case '?': - default: - usage(); - break; - } - } - - if(freq == -1 || no == -1) - usage(); - - if((fd = open("/dev/console", O_RDONLY)) < 0) - fd = DEFAULTFD; - - if(ioctl(fd, KDENABIO, 0) < 0) - { - perror("ioctl(KDENABIO)"); - return 1; - } - - AltICD2061SetClock(freq, no); - - (void)ioctl(fd, KDDISABIO, 0); - - exit(0); -} - -usage() -{ - fprintf(stderr,"\nset2061 - program the ICD2061 video clock chip\n"); - fprintf(stderr,"usage: set2061 -f -n \n"); - fprintf(stderr," -f frequency in Hz\n"); - fprintf(stderr," -n clock generator number\n"); - exit(1); -} - diff --git a/sys/arch/i386/isa/pcvt/Util/userkeys/Makefile b/sys/arch/i386/isa/pcvt/Util/userkeys/Makefile deleted file mode 100644 index e96284bafda8..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/userkeys/Makefile +++ /dev/null @@ -1,5 +0,0 @@ -PROG= vt220keys - -MKMAN= no - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/userkeys/vt220keys.c b/sys/arch/i386/isa/pcvt/Util/userkeys/vt220keys.c deleted file mode 100644 index e879ddf9635c..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/userkeys/vt220keys.c +++ /dev/null @@ -1,297 +0,0 @@ -/* - * Trivial program to load VT220 Function keys with strings, - * note that the values only get sent when the key is shifted - * (shoulda been an option to flip the shift set like the Z19!) - * - * Typing no args gives help, basically pairs of keyname/value - * strings. - * - * Author, Author: Barry Shein, Boston University - * - * HISTORY - {1} 30-Oct-85 Kenneth J. Lester (ken) at ektools - - Added the necessary code to read an initialization file. This - should make it easier to used this program. Also added code - that will set-up the terminal in vt200 (this saves the user the - trouble of checking if the set-up is in vt200). - - Restructed the main function to use getopt, for argument - processing. - - Alterated usage function to include new "i" option (init file) - - - -hm minor modifications for pcvt 2.0 release - -*/ - -#include -#include - -/* - * The default toupper() macro is stupid, will toupper anything - */ - -#ifdef toupper -#undef toupper -#endif -#define toupper(c) (islower(c) ? ((c)-' ') : c) - -#define VT200_7BIT 1 -#define ESC 033 -#define INITFILE ".vt220rc" - -struct keynames { - char *name ; - char *string ; -} keys[] = { - "F6", "17", - "F7", "18", - "F8", "19", - "F9", "20", - "F10", "21", - "F11", "23", - "ESC", "23", - "F12", "24", - "BS", "24", - "F13", "25", - "LF", "25", - "F14", "26", - "HELP", "28", - "DO", "29", - "F17", "31", - "F18", "32", - "F19", "33", - "F20", "34", - NULL, NULL -}; - -char prog[BUFSIZ]; - -main(argc,argv) - int argc; - char *argv[]; -{ - /* these are defined in the getopt routine */ - extern char *optarg; /* argument give to an option */ - extern int optind; /* argv index after option processing */ - - int option; /* option character returned by getopt */ - int initf = 0; /* read initialization file */ - int lockf = 0; /* lock keys after loading strings */ - int clearf = 0; /* clear all keys before loading strings */ - char *strcpy(); - - (void) strcpy(prog, *argv); /* store program name */ - - if(argc == 1) usage(); /* program requires options */ - - /* get options */ - while ((option = getopt(argc, argv, "cli")) != -1) - switch(option) - { - case 'c' : - clearf++; - break; - case 'l' : - lockf++; - break; - case 'i' : - initf++; - break; - case '?' : - usage(); - } - - if (VT200_7BIT) - printf("\033[62;1\"p"); /* vt200 7 bits */ - else - printf("\033[62;2\"p"); /* vt200 8 bits */ - - if(clearf) clearkeys(); - - if (initf) getinit(); - - /* process {key, key string} pairs. Note optind is index to argv - for first pair. By adding 1 to optind insures that a pair exists - i.e. the last key has a key string. */ - - while(optind + 1 < argc) - { - dokey(argv[optind], argv[optind+1]); - optind += 2; - } - - if(lockf) lockkeys(); - - exit(0); -} - -/****************************************************************************/ - -/* - * Load the VT220 SHIFT-FNKEY value, the basic pattern is - * "\EP1;1|"+KEYNAME+"/"+VAL_AS_HEX+"\E\\" - * that is, literally what is in quotes (w/o quotes) then the - * name of the key from the keytable above (a numeric string) - * then a slash, then the string value as hex pairs then ESC-BACKSLASH - * - * Note: you can gang together key defns with semicolons but that - * would complicate things, especially error handling, so do it all - * for each pair, who cares, really. - */ - -dokey(nm,val) char *nm, *val; -{ - register char *scr; - register struct keynames *kp; - - for(scr = nm; *scr = toupper(*scr); scr++) - ; - for(kp = keys; kp->name != NULL; kp++) - if(strcmp(nm,kp->name) == 0) { - printf("%cP1;1|%s/",ESC,kp->string); - while(*val) printf("%02x",*val++); - printf("%c\\",ESC); - fflush(stdout); - return; - } - fprintf(stderr,"Bad key name: %s\n",nm); - usage(); /* bad key name, give up */ -} - -/****************************************************************************/ - -clearkeys() -{ - printf("%cP0;1|%c\\",ESC,ESC); - fflush(stdout); -} - -/****************************************************************************/ - -lockkeys() -{ - printf("%cP1;0|%c\\",ESC,ESC); - fflush(stdout); -} - -/****************************************************************************/ - -usage() -{ - int i; - - fprintf(stderr,"Usage: %s [-cil] [keyname string keyname string...]\n\n",prog); - fprintf(stderr,"The following options are available\n"); - fprintf(stderr,"\t-c\tclears keys first\n"); - fprintf(stderr,"\t-l\t[sets then] locks further setting\n"); - fprintf(stderr,"\t-i\tfirst read initialization file $HOME/%s\n",INITFILE); - fprintf(stderr,"(note that the only way to unlock is via Set-Up)\n\n"); - fprintf(stderr,"Keyname is one of:\n\t"); - for(i=0; keys[i].name != NULL; i++) - fprintf(stderr,"%s ",keys[i].name); - fprintf(stderr,"\nKeyname is SHIFTED function key that sends the string\n\n"); - fprintf(stderr,"Strings may need quoting to protect from shell\n"); - fprintf(stderr,"You must specify an option or key,string pairs\n\n"); - exit(1); -} - -/****************************************************************************/ - -/* This routine process the INITFILE. This file expects lines in the format - - keyname ws string - - Where ws is white space (spaces or tabs) and is optional white space. - The string may include spaces or tabs and need not be quoted. If the - string has the sequence of "\n" then a newline character is included in - the string. - - examples: - - F6 ls -lg\n - F7 uulog -s - -*/ - -#include -#include - -getinit() -{ - char *home; /* user's home directory */ - char path[BUFSIZ]; /* full path name of init file */ - char buf[BUFSIZ]; /* buffer to hold 1 line from init file */ - char key[BUFSIZ]; /* buffer, to hold specified fcn key */ - char keystr[BUFSIZ]; /* string associated with fcn key */ - char *ptr; /* pointer to transverse buf */ - int i, j; /* array indices */ - int statflag; /* whether init file is regular & readable */ - struct stat statbuf; /* stat of the init file */ - FILE *fp; /* file pointer to init file */ - - /* system calls and subroutines */ - FILE *fopen(); - char *strcpy(); - char *strcat(); - char *fgets(); - char *getenv(); - - /* construct full path name for init file */ - home = getenv("HOME"); - (void) strcpy(path, home); - (void) strcat(path,"/"); - (void) strcat(path,INITFILE); - - /* check status if init file */ - if (stat(path, &statbuf) != -1) - { - statflag = statbuf.st_mode & S_IFREG && statbuf.st_mode & S_IREAD; - if (!statflag || (fp = fopen(path, "r")) == NULL) - { - fprintf(stderr, "couldn't open initalization file: %s\n", path); - exit(1); - } - - /* process lines from init file */ - while (fgets(buf, BUFSIZ, fp) != NULL) - { - /* variable initializations */ - i = 0; j = 0; - key[0] = '\0'; keystr[0] = '\0'; - ptr = buf; - - while (*ptr == ' ' || *ptr == '\t') ptr++; /*skip whitespace*/ - - if (*ptr == '\n') break; /* we hit an emtpy line */ - - while (!isspace(*ptr) && *ptr != '\0') /* get keyname */ - key[i++] = *ptr++; - key[i] = '\0'; /* place EOS in buffer */ - - while (*ptr == ' ' || *ptr == '\t') ptr++; /*skip whitespace*/ - - while (*ptr != '\n' && *ptr != '\0') /* get string */ - { - /* check if string is to include newline i.e. \n */ - if (*ptr == '\\' && *(ptr+1) == 'n') - { - keystr[j] = '\012'; - ptr++; - } - else - keystr[j] = *ptr; - j++; ptr++; - } - keystr[j] = '\0'; /* place EOS in buffer */ - dokey(key, keystr); /* load key with string */ - } - } - else - { - fprintf(stderr, "init file %s not found\n\n", path); - usage(); - } -} diff --git a/sys/arch/i386/isa/pcvt/Util/vgaio/CAUTION b/sys/arch/i386/isa/pcvt/Util/vgaio/CAUTION deleted file mode 100644 index e1eba06aaa4e..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vgaio/CAUTION +++ /dev/null @@ -1,28 +0,0 @@ -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION - - THE USE OF THIS PROGRAM MAY DESTROY YOUR MONITOR !!! - ==================================================== - - IF YOU DON'T KNOW WHAT YOU ARE DOING, STAY AWAY FROM IT !!! - =========================================================== - - THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND - ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY - AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, - INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, - EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION -CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION CAUTION - diff --git a/sys/arch/i386/isa/pcvt/Util/vgaio/Makefile b/sys/arch/i386/isa/pcvt/Util/vgaio/Makefile deleted file mode 100644 index d790e8115f82..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vgaio/Makefile +++ /dev/null @@ -1,22 +0,0 @@ -PROG= vgaio -MAN8= vgaio.${MAN8EXT} - -SRCS= vgaio.y lex.l -YACC= yacc - -#YFLAGS+= -yd # Bison -#YFLAGS+= -v # verbose - -LFLAGS+= -I -LDADD= -lm -ly -ll -DPADD= ${LIBM} ${LIBY} ${LIBL} - -CFLAGS+= -I. -g -YFLAGS+= -d - -CLEANFILES+= y.tab.h -CLEANFILES+= y.output # comment file from bison - -MKMAN= no - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/vgaio/lex.l b/sys/arch/i386/isa/pcvt/Util/vgaio/lex.l deleted file mode 100644 index a72e994380d1..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vgaio/lex.l +++ /dev/null @@ -1,67 +0,0 @@ -%{ -/* $NetBSD: lex.l,v 1.4 1997/10/13 14:22:32 lukem Exp $ */ -/* - * Copyright (c) 1994,1995 Joerg Wunsch - * - * All rights reserved. - * - * This program is free software. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Joerg Wunsch - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#include -#include - -#include "vgaio.h" -#include "y.tab.h" - -extern YYSTYPE yylval; - -%} - -D [0-9a-fA-F] - -%% - -cr|CR { return CR; } - -ar|AR { return AR; } - -gr|GR { return GR; } - -sr|SR { return SR; } - -mi|MI { return MI; } - -{D}({D}*) { sscanf(yytext, "%x", &yylval.num); return NUM; } - -[ \t] { /* ignore */ } - -\n { return NEWLINE; } - -. { return yytext[0]; } diff --git a/sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.h b/sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.h deleted file mode 100644 index 463881dc90dd..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.h +++ /dev/null @@ -1,45 +0,0 @@ -/* $NetBSD: vgaio.h,v 1.4 1997/10/13 14:22:34 lukem Exp $ */ -/* - * Copyright (c) 1994 Joerg Wunsch - * - * All rights reserved. - * - * This program is free software. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Joerg Wunsch - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -/* common structure to hold the definition for a VGA register */ - -#ifndef VGAIO_H -#define VGAIO_H - -struct reg { - int group, num; -}; - -#endif /* VGAIO_H */ diff --git a/sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.y b/sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.y deleted file mode 100644 index ca41349d544d..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vgaio/vgaio.y +++ /dev/null @@ -1,262 +0,0 @@ -/* Hello emacs, this should be edited in -*- Fundamental -*- mode */ -%{ -/* $NetBSD: vgaio.y,v 1.5 1997/11/01 06:49:49 lukem Exp $ */ -/* - * Copyright (c) 1994,1995 Joerg Wunsch - * - * All rights reserved. - * - * This program is free software. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Joerg Wunsch - * 4. The name of the developer may not be used to endorse or promote - * products derived from this software without specific prior written - * permission. - * - * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#include -#include -#include -#include -#include - -#ifdef __NetBSD__ -#include -#endif - -#include "vgaio.h" - -void setreg(struct reg r, int val); -void getreg(struct reg r); -void yyerror(const char *msg); - -#define YYDEBUG 1 - -unsigned short vgabase; - -%} - -%union { - int num; - struct reg reg; -} - -%token MI GR CR SR AR NEWLINE -%token NUM - -%type reggroup -%type register - -%% - -interpret: lines ; - -lines: line - | lines line - ; - -line: statements NEWLINE - | NEWLINE - | error NEWLINE { fprintf(stderr, "bing!\n"); } - ; - -statements: statement - | statements ';' statement - ; - -statement: register '?' { getreg($1); } - | register '=' NUM { setreg($1, $3); } - | /* lambda */ - ; - -register: reggroup NUM { $$.num = $2; $$.group = $1; } - /* useful for the MI register: */ - | reggroup { $$.num = 0; $$.group = $1; } - ; - -reggroup: GR { $$ = GR; } - | CR { $$ = CR; } - | SR { $$ = SR; } - | AR { $$ = AR; } - | MI { $$ = MI; } - ; - -%% - -static struct { - int id; - const char *name; -} regnames[] = { - {GR, "gr"}, {CR, "cr"}, {SR, "sr"}, {AR, "ar"}, {MI, "mi"}, - {0, 0} -}; - -const char *getname(struct reg r) { - int idx; - for(idx = 0; regnames[idx].id; idx++) - if(regnames[idx].id == r.group) - return regnames[idx].name; - return "??"; -} - -/* return ptr to string of 1s and 0s for value */ -char * -bin_str(unsigned long val, int length) { - static char buffer[80]; - int i = 0; - - if (length > 32) - length = 32; - - val = val << (32 - length); - - while (length--) - { - if (val & 0x80000000) - buffer[i++] = '1'; - else - buffer[i++] = '0'; - if ((length % 4) == 0 && length) - buffer[i++] = '.'; - val = val << 1; - } - return (buffer); -} - -void getreg(struct reg r) { - int val; /* FreeBSD gcc ONLY accepts an int */ - - switch(r.group) { - case GR: - outb(0x3ce, r.num); - val = inb(0x3cf); - break; - - case AR: - r.num &= 0x1f; - (void)inb(vgabase + 0x0a); - outb(0x3c0, r.num + 0x20); - val = inb(0x3c1); - break; - - case CR: - outb(vgabase + 4, r.num); - val = inb(vgabase + 5); - break; - - case SR: - outb(0x3c4, r.num); - val = inb(0x3c5); - break; - - case MI: - val = inb(0x3cc); - break; - } - - printf("%s%02x = 0x%02x = %sB\n", - getname(r), r.num, val, bin_str(val, 8)); -} - -void setreg(struct reg r, int val) { - switch(r.group) { - case GR: - outb(0x3ce, r.num); - outb(0x3cf, val); - break; - - case AR: - r.num &= 0x1f; - (void)inb(vgabase + 0x0a); - outb(0x3c0, r.num); - outb(0x3c0, val); - outb(0x3c0, r.num + 0x20); - break; - - case CR: - outb(vgabase + 4, r.num); - outb(vgabase + 5, val); - break; - - case SR: - outb(0x3c4, r.num); - outb(0x3c5, val); - break; - - case MI: - outb(0x3c2, val); - break; - } - - printf("%s%02x set to 0x%02x = %sB now\n", - getname(r), r.num, val, bin_str(val, 8)); -} - -void yyerror(const char *msg) { - fprintf(stderr, "yyerror: %s\n", msg); -} - -void usage(void) { - fprintf(stderr, "usage: vgaio [-d] [-f devname]\n"); - exit(2); -} - -int main(int argc, char **argv) { - int fd, c; - const char *devname = "/dev/console"; - - while((c = getopt(argc, argv, "df:")) != -1) - switch(c) { - case 'd': - yydebug = 1; - break; - - case 'f': - devname = optarg; - break; - - case '?': - default: - usage(); - } - argc -= optind; - argv += optind; - if(argc > 0) - usage(); - - if((fd = open(devname, O_RDONLY)) < 0) { - perror("open(vga)"); - return 1; - } - - if(ioctl(fd, KDENABIO, 0) < 0) { - perror("ioctl(KDENABIO)"); - return 1; - } - vgabase = (inb(0x3cc) & 1)? 0x3d0: 0x3b0; - yyparse(); - - (void)ioctl(fd, KDDISABIO, 0); - return 0; -} diff --git a/sys/arch/i386/isa/pcvt/Util/vttest/Makefile b/sys/arch/i386/isa/pcvt/Util/vttest/Makefile deleted file mode 100644 index bae6fb0cf83c..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vttest/Makefile +++ /dev/null @@ -1,6 +0,0 @@ -PROG= vttest -SRCS= main.c esc.c - -MKMAN= no - -.include diff --git a/sys/arch/i386/isa/pcvt/Util/vttest/README b/sys/arch/i386/isa/pcvt/Util/vttest/README deleted file mode 100644 index 589d08f2c1fc..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vttest/README +++ /dev/null @@ -1,57 +0,0 @@ -NOTES FROM THE MOD.SOURCES MODERATOR: -I split the source up into the three separate pieces it now is. -In doing this, I put lines like "int reading;" in a header file -that both C modules include. If your Unix requires one of these -to be "extern int reading;" then you will have some editing to do. -Also note that this program uses FIONREAD, which must be implemented -differently in SystemV, etc., and check out the setjmp() call... - /Rich $alz -Oh, yeah: I also wrote the Makefile and manpage, such as they are. -------------------------------------------------------------------- - -This is a program to test the compatibility (or to demonstrate the -non-compatibility) of so-called "VT100-compatible" terminals. In -conformance of the good old hacker traditions, the only documentation -of this program is the source code itself. To understand it, you also -need a copy of the original VT100 manual from DEC. - -Comments and bug reports: Since this is a release (via USENET) to the -whole world, a lot of people are going to have opinions and fresh -ideas about it. (What -- bugs in MY program? Aww...) I can't deal -with everyone sending me a hacked version, but if you have found a -serious bug, or ported it to VMS, do tell me. I can't promise any new -version release, though. From this version on (1.7b) VTTEST will have -to live its own life without its father holding its hand. - -My adress is: - -Network-mail adress: (mcvax,seismo)!enea!suadb!lindberg - -Real-world-mail address: Per Lindberg - QZ, Stockholm University Computing Center - Box 27322 - S - 102 54 Stockholm - SWEDEN - -The original version of this program is written for the Sargasso C -compiler for the DECsystem-10. Many thanks to all sales persons with -quote VT100-compatible unquote terminals, who prompted me to write -this program, and also to: - --- Bo Kleve, LIDAC, Linkoping University, Sweden - for the portation to DECSYSTEM-20 with the Sargasso C compiler - --- Johan Widen, TTDS, Royal Institute of Technology, Stockholm, Sweden - for the portation to various UNIX systems (incl. System III and Xenix) - --- Russ Herman, AES Data Inc., Missisauga, Ont. Canada - for fixes and code for the VT102 test - -Thanx also to JMR "Gremlin" at KTH, and Goran Wallberg at QZ -for suggestions, bug fixes, etc. - -This program does not have support for all the different variations -of VT100, like VT125, VT131 nor the new VT200 series. Feel free to -add that yourself. Happy Hacking! - - /TMP diff --git a/sys/arch/i386/isa/pcvt/Util/vttest/esc.c b/sys/arch/i386/isa/pcvt/Util/vttest/esc.c deleted file mode 100644 index 520946b5054b..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vttest/esc.c +++ /dev/null @@ -1,398 +0,0 @@ -#include "header.h" - -println(s) char *s; { - printf("%s\n", s); -} - -esc(s) char *s; { - printf("%c%s", 27, s); -} - -esc2(s1, s2) char s1, s2; { - printf("%c%s%s", 27, s1, s2); -} - -brcstr(ps, c) char *ps, c; { - printf("%c[%s%c", 27, ps, c); -} - -brc(pn,c) int pn; char c; { - printf("%c[%d%c", 27, pn, c); -} - -brc2(pn1, pn2 ,c) int pn1, pn2; char c; { - printf("%c[%d;%d%c", 27, pn1, pn2, c); -} - -cub(pn) int pn; { /* Cursor Backward */ - brc(pn,'D'); -} -cud(pn) int pn; { /* Cursor Down */ - brc(pn,'B'); -} -cuf(pn) int pn; { /* Cursor Forward */ - brc(pn,'C'); -} -cup(pn1, pn2) int pn1, pn2; { /* Cursor Position */ - brc2(pn1, pn2, 'H'); -} -cuu(pn) int pn; { /* Cursor Up */ - brc(pn,'A'); -} -da() { /* Device Attributes */ - brc(0,'c'); -} -decaln() { /* Screen Alignment Display */ - esc("#8"); -} -decdhl(lower) int lower; { /* Double Height Line (also double width) */ - if (lower) esc("#4"); - else esc("#3"); -} -decdwl() { /* Double Wide Line */ - esc("#6"); -} -deckpam() { /* Keypad Application Mode */ - esc("="); -} -deckpnm() { /* Keypad Numeric Mode */ - esc(">"); -} -decll(ps) char *ps; { /* Load LEDs */ - brcstr(ps, 'q'); -} -decrc() { /* Restore Cursor */ - esc("8"); -} -decreqtparm(pn) int pn; { /* Request Terminal Parameters */ - brc(pn,'x'); -} -decsc() { /* Save Cursor */ - esc("7"); -} -decstbm(pn1, pn2) int pn1, pn2; { /* Set Top and Bottom Margins */ - if (pn1 || pn2) brc2(pn1, pn2, 'r'); - else esc("[r"); - /* Good for >24-line terminals */ -} -decswl() { /* Single With Line */ - esc("#5"); -} -dectst(pn) int pn; { /* Invoke Confidence Test */ - brc2(2, pn, 'y'); -} -dsr(pn) int pn; { /* Device Status Report */ - brc(pn, 'n'); -} -ed(pn) int pn; { /* Erase in Display */ - brc(pn, 'J'); -} -el(pn) int pn; { /* Erase in Line */ - brc(pn,'K'); -} -hts() { /* Horizontal Tabulation Set */ - esc("H"); -} -hvp(pn1, pn2) int pn1, pn2; { /* Horizontal and Vertical Position */ - brc2(pn1, pn2, 'f'); -} -ind() { /* Index */ - esc("D"); -} -nel() { /* Next Line */ - esc("E"); -} -ri() { /* Reverse Index */ - esc("M"); -} -ris() { /* Reset to Initial State */ - esc("c"); -} -rm(ps) char *ps; { /* Reset Mode */ - brcstr(ps, 'l'); -} -scs(g,c) int g; char c; { /* Select character Set */ - printf("%c%c%c%c%c%c%c", 27, g ? ')' : '(', c, - 27, g ? '(' : ')', 'B', - g ? 14 : 15); -} -sgr(ps) char *ps; { /* Select Graphic Rendition */ - brcstr(ps, 'm'); -} -sm(ps) char *ps; { /* Set Mode */ - brcstr(ps, 'h'); -} -tbc(pn) int pn; { /* Tabulation Clear */ - brc(pn, 'g'); -} - -vt52cup(l,c) int l,c; { - printf("%cY%c%c", 27, l + 31, c + 31); -} - -char inchar() { - - /* - * Wait until a character is typed on the terminal - * then read it, without waiting for CR. - */ - -#ifdef UNIX - int lval, waittime, getpid(); static int val; char ch; - - fflush(stdout); - lval = val; - brkrd = 0; - reading = 1; - read(0,&ch,1); - reading = 0; - if (brkrd) - val = 0177; - else - val = ch; - if ((val==0177) && (val==lval)) - kill(getpid(), (int) SIGTERM); -#endif -#ifdef SARG10 - int val, waittime; - - waittime = 0; - while(!uuo(051,2,&val)) { /* TTCALL 2, (INCHRS) */ - zleep(100); /* Wait 0.1 seconds */ - if ((waittime += ttymode) > 600) /* Time-out, in case */ - return('\177'); /* of hung in ttybin(1) */ - } -#endif -#ifdef SARG20 /* try to fix a time-out function */ - int val, waittime; - - waittime = 0; - while(jsys(SIBE,2,_PRIIN) == 0) { /* Is input empty? */ - zleep(100); - if ((waittime += ttymode) > 600) - return('\177'); - } - ejsys(BIN,_PRIIN); - val = jsac[2]; -#endif - return(val); -} - -char *instr() { - - /* - * Get an unfinished string from the terminal: - * wait until a character is typed on the terminal, - * then read it, and all other available characters. - * Return a pointer to that string. - */ - - - int i, val, crflag; long l1; char ch; - static char result[80]; - - i = 0; - result[i++] = inchar(); -/* Wait 0.1 seconds (1 second in vanilla UNIX) */ -#ifdef SARG10 - if (trmop(01031,0) < 5) zleep(500); /* wait longer if low speed */ - else zleep(100); -#else - zleep(100); -#endif -#ifdef UNIX - fflush(stdout); -#ifdef XENIX - while(rdchk(0)) { - read(0,result+i,1); - if (i++ == 78) break; - } -#else -#ifdef SIII - while(read(2,result+i,1) == 1) - if (i++ == 78) break; -#else - while(ioctl(0,FIONREAD,&l1), l1 > 0L) { - while(l1-- > 0L) { - read(0,result+i,1); - if (i++ == 78) goto out1; - } - } -out1: -#endif -#endif -#endif -#ifdef SARG10 - while(uuo(051,2,&val)) { /* TTCALL 2, (INCHRS) */ - if (!(val == '\012' && crflag)) /* TOPS-10 adds LF to CR */ - result[i++] = val; - crflag = val == '\015'; - if (i == 79) break; - zleep(50); /* Wait 0.05 seconds */ - } -#endif -#ifdef SARG20 - while(jsys(SIBE,2,_PRIIN) != 0) { /* read input until buffer is empty */ - ejsys(BIN,_PRIIN); - result[i++] = jsac[2]; - if (i == 79) break; - zleep(50); /* Wait 0.05 seconds */ - } -#endif - result[i] = '\0'; - return(result); -} - -ttybin(bin) int bin; { -#ifdef SARG10 - #define OPEN 050 - #define IO_MOD 0000017 - #define _IOPIM 2 - #define _IOASC 0 - #define _TOPAG 01021 - #define _TOSET 01000 - - int v; - static int arglst[] = { - _IOPIM, - `TTY`, - 0 - }; - arglst[0] = bin ? _IOPIM : _IOASC; - v = uuo(OPEN, 1, &arglst[0]); - if (!v) { printf("OPEN failed"); exit(); } - trmop(_TOPAG + _TOSET, bin ? 0 : 1); - ttymode = bin; -#endif -#ifdef SARG20 - /* TTYBIN will set the line in BINARY/ASCII mode - * BINARY mode is needed to send control characters - * Bit 28 must be 0 (we don't flip it). - * Bit 29 is used for the mode change. - */ - - #define _TTASC 0000100 - #define _MOXOF 0000043 - - int v; - - ejsys(RFMOD,_CTTRM); - v = ejsys(SFMOD,_CTTRM, bin ? (~_TTASC & jsac[2]) : (_TTASC | jsac[2])); - if (v) { printf("SFMOD failed"); exit(); } - v = ejsys(MTOPR,_CTTRM,_MOXOF,0); - if (v) { printf("MTOPR failed"); exit(); } -#endif -} - -#ifdef SARG20 -/* - * SUPERBIN turns off/on all input character interrupts - * This affects ^C, ^O, ^T - * Beware where and how you use it !!!!!!! - */ - -superbin(bin) int bin; { - int v; - - v = ejsys(STIW,(0//-5), bin ? 0 : -1); - if (v) { printf("STIW superbinary setting failed"); exit(); } - ttymode = bin; -} - -/* - * PAGE affects the ^S/^Q handshake. - * Set bit 34 to turn it on. Clear it for off. - */ - -page(bin) int bin; { - int v; - - #define TT_PGM 0000002 - - ejsys(RFMOD,_CTTRM); /* Get the current terminal status */ - v = ejsys(STPAR,_CTTRM, bin ? (TT_PGM | jsac[2]) : (~TT_PGM & jsac[2])); - if (v) { printf("STPAR failed"); exit(); } -} -#endif - -trmop(fc,arg) int fc, arg; { -#ifdef SARG10 - int retvalp; - int arglst[3]; - - /* TRMOP is a TOPS-10 monitor call that does things to the terminal. */ - - /* Find out TTY nbr (PA1050 barfs if TRMOP get -1 instead of udx) */ - /* A TRMNO monitor call returns the udx (Universal Device Index) */ - - arglst[0] = fc; /* function code */ - arglst[1] = calli(0115, -1); /* udx, TRMNO. UUO */ - arglst[2] = arg; /* Optional argument */ - - if (calli(0116, 3 // &arglst[0], &retvalp)) /* TRMOP. UUO */ - return (retvalp); - else { - printf("?Error return in TRMOP."); - exit(); - } -#endif -} - -inputline(s) char *s; { - scanf("%s",s); -#ifdef SARG10 - readnl(); -#endif -#ifdef SARG20 - readnl(); -#endif -} - -inflush() { - - /* - * Flush input buffer, make sure no pending input character - */ - - int val; - -#ifdef UNIX -#ifdef XENIX - while(rdchk(0)) read(0,&val,1); -#else -#ifdef SIII - while(read(2,&val,1)); -#else - long l1; - ioctl (0, FIONREAD, &l1); - while(l1-- > 0L) read(0,&val,1); -#endif -#endif -#endif -#ifdef SARG10 - while(uuo(051,2,&val)) /* TTCALL 2, (INCHRS) */ - ; -#endif -#ifdef SARG20 - ejsys(CFIBF,_PRIIN); /* Clear input buffer */ -#endif -} - -zleep(t) int t; { - -/* - * Sleep and do nothing (don't waste CPU) for t milliseconds - */ - -#ifdef SARG10 - calli(072,t); /* (HIBER) t milliseconds */ -#endif -#ifdef SARG20 - ejsys(DISMS,t); /* DISMISS for t milliseconds */ -#endif -#ifdef UNIX - t = t / 1000; - if (t == 0) t = 1; - sleep(t); /* UNIX can only sleep whole seconds */ -#endif -} diff --git a/sys/arch/i386/isa/pcvt/Util/vttest/header.h b/sys/arch/i386/isa/pcvt/Util/vttest/header.h deleted file mode 100644 index 4d6e4111ec88..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vttest/header.h +++ /dev/null @@ -1,50 +0,0 @@ -#define VERSION "1.7b 1985-04-19" - -/* Choose one of these */ - -/* #define XENIX /* XENIX implies UNIX */ -/* #define SIII /* SIII implies UNIX, (NDELAY a la System III) */ -#define UNIX /* UNIX */ -/* #define VMS /* VMS not done yet -- send me your version!!!! */ -/* #define SARG20 /* Sargasso C for TOPS-20 */ -/* #define SARG10 /* Sargasso C for TOPS-10 */ - -/* These #ifdef:s are implementation dependent stuff for the Sargasso C */ -/* Unix C barfs on directives like "#strings", so we keep them */ -/* indented. Then unix c can't find them, but Sargasso C *can*. */ -/* Admittedly kludgey, but it works...) */ -#ifdef SARG10 - #define _UNIXCON /* Make UNIX-flavored I/O on TOPS */ - #strings low /* put strings in lowseg mem so we can modify them. */ -#endif -#ifdef SARG20 - #define _UNIXCON /* Make UNIX-flavored I/O on TOPS */ - #strings low /* put strings in lowseg mem so we can modify them. */ - #include -#endif - -#include - - -#ifdef UNIX -# include -# include -# ifndef BSD4_4 -# include -struct sgttyb ttyOrg, ttyNew; -# else -# include -# include -struct termios ttyOrg, ttyNew; -# endif -# include -# include -jmp_buf intrenv; -char stdioBuf[BUFSIZ]; -int brkrd, reading; -extern onterm(), onbrk(); -# ifdef SIII -# include -# endif -#endif -int ttymode; diff --git a/sys/arch/i386/isa/pcvt/Util/vttest/main.c b/sys/arch/i386/isa/pcvt/Util/vttest/main.c deleted file mode 100644 index 0f9ee7e6e939..000000000000 --- a/sys/arch/i386/isa/pcvt/Util/vttest/main.c +++ /dev/null @@ -1,2098 +0,0 @@ -/* - VTTEST.C - - Written Novemeber 1983 - July 1984 by Per Lindberg, - Stockholm University Computer Center (QZ), Sweden. - - THE MAD PROGRAMMER STRIKES AGAIN! - - This software is (c) 1984 by QZ - Non-commercial use and copying allowed. - -If you are developing a commercial product, and use this program to do -it, and that product is successful, please send a sum of money of your -choice to the address below. - -*/ - -#include "header.h" - -char inchar(), *instr(), *lookup(); - -struct table { - int key; - char *msg; -} paritytable[] = { - { 1, "NONE" }, - { 4, "ODD" }, - { 5, "EVEN" }, - { -1, "" } -},nbitstable[] = { - { 1, "8" }, - { 2, "7" }, - { -1,"" } -},speedtable[] = { - { 0, "50" }, - { 8, "75" }, - { 16, "110" }, - { 24, "132.5"}, - { 32, "150" }, - { 40, "200" }, - { 48, "300" }, - { 56, "600" }, - { 64, "1200" }, - { 72, "1800" }, - { 80, "2000" }, - { 88, "2400" }, - { 96, "3600" }, - { 104, "4800" }, - { 112, "9600" }, - { 120, "19200" }, - { -1, "" } -}; - -#ifdef USEMYSTTY -#ifndef stty -int stty(fd,ptr) -int fd; -struct sgttyb *ptr; -{ - return(ioctl(fd, TIOCSETP, ptr)); -} -#endif -#ifndef gtty -int gtty(fd,ptr) -int fd; -struct sgttyb *ptr; -{ - return(ioctl(fd, TIOCGETP, ptr)); -} -#endif -#endif - -main() { - - int menuchoice; - - static char *mainmenu[] = { - "Exit", - "Test of cursor movements", - "Test of screen features", - "Test of character sets", - "Test of double-sized characters", - "Test of keyboard", - "Test of terminal reports", - "Test of VT52 mode", - "Test of VT102 features (Insert/Delete Char/Line)", - "Test of known bugs", - "Test of reset and self-test", - "" - }; - -#ifdef UNIX - initterminal(setjmp(intrenv)); - signal(SIGINT, (void (*) __P((int))) onbrk); - signal(SIGTERM, (void (*) __P((int))) onterm); - reading = 0; -#else - initterminal(0); -#endif - do { -#ifdef SARG20 - ttybin(1); /* set line to binary mode again. It's reset somehow!! */ -#endif - ed(2); - cup(5,10); printf("VT100 test program, version %s", VERSION); - cup(7,10); println("Choose test type:"); - menuchoice = menu(mainmenu); - switch (menuchoice) { - case 1: tst_movements(); break; - case 2: tst_screen(); break; - case 3: tst_characters(); break; - case 4: tst_doublesize(); break; - case 5: tst_keyboard(); break; - case 6: tst_reports(); break; - case 7: tst_vt52(); break; - case 8: tst_insdel(); break; - case 9: tst_bugs(); break; - case 10: tst_rst(); break; - } - } while (menuchoice); - bye(); -} - -tst_movements() { - - /* Test of: - CUF (Cursor Forward) - CUB (Cursor Backward) - CUD (Cursor Down) IND (Index) NEL (Next Line) - CUU (Cursor Up) RI (Reverse Index) - CUP (Cursor Position) HVP (Horizontal and Vertical Position) - ED (Erase in Display) - EL (Erase in Line) - DECALN (Screen Alignment Display) - - Cursor control characters inside CSI sequences - */ - - int i, row, col, pass, width, hlfxtra; - char c, *ctext = "This is a correct sentence"; - - for (pass = 0; pass <= 1; pass++) { - if (pass == 0) { rm("?3"); width = 80; hlfxtra = 0; } - else { sm("?3"); width = 132; hlfxtra = 26; } - - decaln(); - cup( 9,10+hlfxtra); ed(1); - cup(18,60+hlfxtra); ed(0); el(1); - cup( 9,71+hlfxtra); el(0); - for (row = 10; row <= 16; row++) { - cup(row, 10+hlfxtra); el(1); - cup(row, 71+hlfxtra); el(0); - } - cup(17,30); el(2); - for (col = 1; col <= width; col++) { - hvp(24, col); printf("*"); - hvp( 1, col); printf("*"); - } - cup(2,2); - for (row = 2; row <= 23; row++) { - printf("+"); - cub(1); - ind(); - } - cup(23,width-1); - for (row = 23; row >=2; row--) { - printf("+"); - cub(1); ri(); - } - cup(2,1); - for (row = 2; row <= 23; row++) { - printf("*"); - cup(row, width); - printf("*"); - cub(10); - if(row < 10) - nel(); - else - printf("\n"); - } - cup(2,10); - cub(42+hlfxtra); cuf(2); - for (col = 3; col <= width-2; col++) { - printf("+"); - cuf(0); cub(2); cuf(1); - } - cup(23,70+hlfxtra); - cuf(42+hlfxtra); cub(2); - for (col = width-2; col >= 3; col--) { - printf("+"); - cub(1); cuf(1); cub(0); printf("%c", 8); - } - cup( 1, 1); cuu(10); cuu(1); cuu(0); - cup(24,width); cud(10); cud(1); cud(0); - - cup(10,12+hlfxtra); - for (row = 10; row <= 15; row++) { - for (col = 12+hlfxtra; col <= 69+hlfxtra; col++) printf(" "); - cud(1); cub(58); - } - cuu(5); cuf(1); - printf("The screen should be cleared, and have an unbroken bor-"); - cup(12,13+hlfxtra); - printf("der of *'s and +'s around the edge, and exactly in the"); - cup(13,13+hlfxtra); - printf("middle there should be a frame of E's around this text"); - cup(14,13+hlfxtra); - printf("with one (1) free position around it. "); - holdit(); - } - rm("?3"); - - ed(2); - cup(1,1); - println("Test of cursor-control characters inside ESC sequences."); - println("Below should be two identical lines:"); - println(""); - println("A B C D E F G H I J K L M N O P Q R S"); - for (i = 1; i < 20; i++) { - printf("%c", 64 + i); - brcstr("2\010", 'C'); /* Two forward, one backspace */ - } - println(""); - println(""); - holdit(); - - ed(2); - cup(1,1); - println("Test of leading zeros in ESC sequences."); - printf("Two lines below you should see the sentence \"%s\".",ctext); - for (col = 1; *ctext; col++) - printf("\033[00000000004;00000000%dH%c",col,*ctext++); - cup(20,1); - holdit(); -} - -tst_screen() { - - /* Test of: - - DECSTBM (Set Top and Bottom Margins) - - TBC (Tabulation Clear) - - HTS (Horizontal Tabulation Set) - - SM RM (Set/Reset mode): - 80/132 chars - - Origin: Realtive/absolute - - Scroll: Smooth/jump - - Wraparound - - SGR (Select Graphic Rendition) - - SM RM (Set/Reset Mode) - Inverse - - DECSC (Save Cursor) - - DECRC (Restore Cursor) - */ - - int i, j, cset, row, col, down, soft, background; - - static char *tststr = "*qx`"; - static char *attr[5] = { ";0", ";1", ";4", ";5", ";7" }; - - cup(1,1); - sm("?7"); /* Wrap Around ON */ - for (col = 1; col <= 160; col++) printf("*"); - rm("?7"); /* Wrap Around OFF */ - cup(3,1); - for (col = 1; col <= 160; col++) printf("*"); - sm("?7"); /* Wrap Around ON */ - cup(5,1); - println("This should be three identical lines of *'s completely filling"); - println("the top of the screen without any empty lines between."); - println("(Test of WRAP AROUND mode setting.)"); - holdit(); - - ed(2); - tbc(3); - cup(1,1); - for (col = 1; col <= 78; col += 3) { - cuf(3); hts(); - } - cup(1,4); - for (col = 4; col <= 78; col += 6) { - tbc(0); cuf(6); - } - cup(1,7); tbc(1); tbc(2); /* no-op */ - cup(1,1); for (col = 1; col <= 78; col += 6) printf("\t*"); - cup(2,2); for (col = 2; col <= 78; col += 6) printf(" *"); - cup(4,1); - println("Test of TAB setting/resetting. These two lines"); - printf("should look the same. "); - holdit(); - for (background = 0; background <= 1; background++) { - if (background) rm("?5"); - else sm("?5"); - sm("?3"); /* 132 cols */ - ed(2); /* VT100 clears screen on SM3/RM3, but not obviously, so... */ - cup(1,1); tbc(3); - for (col = 1; col <= 132; col += 8) { - cuf(8); hts(); - } - cup(1,1); for (col = 1; col <= 130; col += 10) printf("1234567890"); - printf("12"); - for (row = 3; row <= 20; row++) { - cup(row,row); - printf("This is 132 column mode, %s background.", - background ? "dark" : "light"); - } - holdit(); - rm("?3"); /* 80 cols */ - ed(2); /* VT100 clears screen on SM3/RM3, but not obviously, so... */ - cup(1,1); for (col = 1; col <= 80; col += 10) printf("1234567890"); - for (row = 3; row <= 20; row++) { - cup(row,row); - printf("This is 80 column mode, %s background.", - background ? "dark" : "light"); - } - holdit(); - } - - ed(2); - sm("?6"); /* Origin mode (relative) */ - for (soft = -1; soft <= 0; soft++) { - if (soft) sm("?4"); - else rm("?4"); - for (row = 12; row >= 1; row -= 11) { - decstbm(row, 24-row+1); - ed(2); - for (down = 0; down >= -1; down--) { - if (down) cuu(24); - else cud(24); - for (i = 1; i <= 30; i++) { - printf("%s scroll %s region %d Line %d\n", - soft ? "Soft" : "Jump", - down ? "down" : "up", - 2*(13-row), i); - if (down) { ri(); ri(); } - } - } - holdit(); - } - } - ed(2); - decstbm(23,24); - printf( - "\nOrigin mode test. This line should be at the bottom of the screen."); - cup(1,1); - printf("%s", - "This line should be the one above the bottom of the screeen. "); - holdit(); - ed(2); - rm("?6"); /* Origin mode (absolute) */ - cup(24,1); - printf( - "Origin mode test. This line should be at the bottom of the screen."); - cup(1,1); - printf("%s", "This line should be at the top if the screen. "); - holdit(); - decstbm(1,24); - - ed(2); - cup( 1,20); printf("Graphic rendition test pattern:"); - cup( 4, 1); sgr("0"); printf("vanilla"); - cup( 4,40); sgr("0;1"); printf("bold"); - cup( 6, 6); sgr(";4"); printf("underline"); - cup( 6,45);sgr(";1");sgr("4");printf("bold underline"); - cup( 8, 1); sgr("0;5"); printf("blink"); - cup( 8,40); sgr("0;5;1"); printf("bold blink"); - cup(10, 6); sgr("0;4;5"); printf("underline blink"); - cup(10,45); sgr("0;1;4;5"); printf("bold underline blink"); - cup(12, 1); sgr("1;4;5;0;7"); printf("negative"); - cup(12,40); sgr("0;1;7"); printf("bold negative"); - cup(14, 6); sgr("0;4;7"); printf("underline negative"); - cup(14,45); sgr("0;1;4;7"); printf("bold underline negative"); - cup(16, 1); sgr("1;4;;5;7"); printf("blink negative"); - cup(16,40); sgr("0;1;5;7"); printf("bold blink negative"); - cup(18, 6); sgr("0;4;5;7"); printf("underline blink negative"); - cup(18,45); sgr("0;1;4;5;7"); printf("bold underline blink negative"); - sgr(""); - - rm("?5"); /* Inverse video off */ - cup(23,1); el(0); printf("Dark background. "); holdit(); - sm("?5"); /* Inverse video */ - cup(23,1); el(0); printf("Light background. "); holdit(); - rm("?5"); - ed(2); - cup(8,12); printf("normal"); - cup(8,24); printf("bold"); - cup(8,36); printf("underscored"); - cup(8,48); printf("blinking"); - cup(8,60); printf("reversed"); - cup(10,1); printf("stars:"); - cup(12,1); printf("line:"); - cup(14,1); printf("x'es:"); - cup(16,1); printf("diamonds:"); - for (cset = 0; cset <= 3; cset++) { - for (i = 0; i <= 4; i++) { - cup(10 + 2 * cset, 12 + 12 * i); - sgr(attr[i]); - if (cset == 0 || cset == 2) scs(0,'B'); - else scs(0,'0'); - for (j = 0; j <= 4; j++) { - printf("%c", tststr[cset]); - } - decsc(); - cup(cset + 1, i + 1); sgr(""); scs(0,'B'); printf("A"); - decrc(); - for (j = 0; j <= 4; j++) { - printf("%c", tststr[cset]); - } - } - } - sgr("0"); scs(0,'B'); cup(21,1); - println("Test of the SAVE/RESTORE CURSOR feature. There should"); - println("be ten characters of each flavour, and a rectangle"); - println("of 5 x 4 A's filling the top left of the screen."); - holdit(); -} - -tst_characters() { - /* Test of: - SCS (Select character Set) - */ - - int i, j, g, cset; - char chcode[5], *setmsg[5]; - - chcode[0] = 'A'; - chcode[1] = 'B'; - chcode[2] = '0'; - chcode[3] = '1'; - chcode[4] = '2'; - setmsg[0] = "UK / national"; - setmsg[1] = "US ASCII"; - setmsg[2] = "Special graphics and line drawing"; - setmsg[3] = "Alternate character ROM standard characters"; - setmsg[4] = "Alternate character ROM special graphics"; - - cup(1,10); printf("Selected as G0 (with SI)"); - cup(1,48); printf("Selected as G1 (with SO)"); - for (cset = 0; cset <= 4; cset++) { - scs(1,'B'); - cup(3 + 4 * cset, 1); - sgr("1"); - printf("Character set %c (%s)",chcode[cset], setmsg[cset]); - sgr("0"); - for (g = 0; g <= 1; g++) { - scs(g,chcode[cset]); - for (i = 1; i <= 3; i++) { - cup(3 + 4 * cset + i, 10 + 38 * g); - for (j = 0; j <= 31; j++) { - printf("%c", i * 32 + j); - } - } - } - } - scs(1,'B'); - cup(24,1); printf("These are the installed character sets. "); - holdit(); -} - -tst_doublesize() { - /* Test of: - DECSWL (Single Width Line) - DECDWL (Double Width Line) - DECDHL (Double Height Line) (also implicit double width) - */ - - int col, i, w, w1; - - /* Print the test pattern in both 80 and 132 character width */ - - for(w = 0; w <= 1; w++) { - w1 = 13 * w; - - ed(2); - cup(1, 1); - if (w) { sm("?3"); printf("132 column mode"); } - else { rm("?3"); printf(" 80 column mode"); } - - cup( 5, 3 + 2 * w1); - printf("v------- left margin"); - - cup( 7, 3 + 2 * w1); - printf("This is a normal-sized line"); - decdhl(0); decdhl(1); decdwl(); decswl(); - - cup( 9, 2 + w1); - printf("This is a Double-width line"); - decswl(); decdhl(0); decdhl(1); decdwl(); - - cup(11, 2 + w1); - decdwl(); decswl(); decdhl(1); decdhl(0); - printf("This is a Double-width-and-height line"); - cup(12, 2 + w1); - decdwl(); decswl(); decdhl(0); decdhl(1); - printf("This is a Double-width-and-height line"); - - cup(14, 2 + w1); - decdwl(); decswl(); decdhl(1); decdhl(0); el(2); - printf("This is another such line"); - cup(15, 2 + w1); - decdwl(); decswl(); decdhl(0); decdhl(1); - printf("This is another such line"); - - cup(17, 3 + 2 * w1); - printf("^------- left margin"); - - cup(21, 1); - printf("This is not a double-width line"); - for (i = 0; i <= 1; i++) { - cup(21,6); - if (i) { printf("**is**"); decdwl(); } - else { printf("is not"); decswl(); } - cup(23,1); holdit(); - } - } - /* Set vanilla tabs for next test */ - cup(1,1); tbc(3); for (col = 1; col <= 132; col += 8) { cuf(8); hts(); } - rm("?3"); - ed(2); - scs(0,'0'); - - cup( 8,1); decdhl(0); printf("lqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqk"); - cup( 9,1); decdhl(1); printf("lqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqk"); - cup(10,1); decdhl(0); printf("x%c%c%c%c%cx",9,9,9,9,9); - cup(11,1); decdhl(1); printf("x%c%c%c%c%cx",9,9,9,9,9); - cup(12,1); decdhl(0); printf("x%c%c%c%c%cx",9,9,9,9,9); - cup(13,1); decdhl(1); printf("x%c%c%c%c%cx",9,9,9,9,9); - cup(14,1); decdhl(0); printf("x x"); - cup(15,1); decdhl(1); printf("x x"); - cup(16,1); decdhl(0); printf("mqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqj"); - cup(17,1); decdhl(1); printf("mqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqj"); - scs(0,'B'); sgr("1;5"); - cup(12,3); - printf("* The mad programmer strikes again * "); - cup(13,3); printf("%c",9); cub(6); - printf("* The mad programmer strikes again *"); - sgr("0"); - cup(22,1); - println("Another test pattern... a frame with blinking bold text,"); - printf("all in double-height double-width size. "); - holdit(); - - decstbm(8,24); /* Absolute origin mode, so cursor is set at (1,1) */ - cup(8,1); - for (i = 1; i <= 12; i++) - ri(); - decstbm(0,0); /* No scroll region */ - cup(1,1); - printf("%s", "Exactly half of the box should remain. "); - holdit(); -} - -tst_keyboard() { - -/* Test of: - - DECLL (Load LEDs) - - Keyboard return messages - - SM RM (Set/Reset Mode) - Cursor Keys - - Auto repeat - - DECKPAM (Keypad Application Mode) - - DECKPNM (Keypad Numeric Mode) - -The standard VT100 keayboard layout: - - UP DN LE RI - -ESC 1! 2@ 3# 4$ 5% 6^ 7& 8* 9( 0) -_ =+ `~ BS - -TAB* qQ wW eE rR tT yY uU iI oO pP [{ ]} DEL - -** ** aA sS dD fF gG hH jJ kK lL ;: ," RETN \| - -** **** zZ xX cC vV bB nN mM ,< .> /? **** LF - - ****************SPACE BAR**************** - - PF1 PF2 PF3 PF4 - - *7* *8* *9* *-* - - *4* *5* *6* *,* - - *1* *2* *3* - - ***0*** *.* ENT -*/ - - char *ledmsg[6], *ledseq[6]; - - int i, j, okflag; - int kblayout; - int ckeymode; - int fkeymode; - char kbdc; - char *kbds = " "; - char *curkeystr, *fnkeystr, *abmstr; - char arptstring[500]; - - static struct key { - char c; - int row; - int col; - char *symbol; - } keytab [] = { - { 27, 1, 0, "ESC" }, - { '1', 1, 6, "1" }, { '!', 1, 7, "!" }, - { '2', 1, 11, "2" }, { '@', 1, 12, "@" }, - { '3', 1, 16, "3" }, { '#', 1, 17, "#" }, - { '4', 1, 21, "4" }, { '$', 1, 22, "$" }, - { '5', 1, 26, "5" }, { '%', 1, 27, "%" }, - { '6', 1, 31, "6" }, { '^', 1, 32, "^" }, - { '7', 1, 36, "7" }, { '&', 1, 37, "&" }, - { '8', 1, 41, "8" }, { '*', 1, 42, "*" }, - { '9', 1, 46, "9" }, { '(', 1, 47, "(" }, - { '0', 1, 51, "0" }, { ')', 1, 52, ")" }, - { '-', 1, 56, "-" }, { '_', 1, 57, "_" }, - { '=', 1, 61, "=" }, { '+', 1, 62, "+" }, - { '`', 1, 66, "`" }, { '~', 1, 67, "~" }, - { 8, 1, 70, "BS" }, - { 9, 2, 0, " TAB " }, - { 'q', 2, 8, "q" }, { 'Q', 2, 9, "Q" }, - { 'w', 2, 13, "w" }, { 'W', 2, 14, "W" }, - { 'e', 2, 18, "e" }, { 'E', 2, 19, "E" }, - { 'r', 2, 23, "r" }, { 'R', 2, 24, "R" }, - { 't', 2, 28, "t" }, { 'T', 2, 29, "T" }, - { 'y', 2, 33, "y" }, { 'Y', 2, 34, "Y" }, - { 'u', 2, 38, "u" }, { 'U', 2, 39, "U" }, - { 'i', 2, 43, "i" }, { 'I', 2, 44, "I" }, - { 'o', 2, 48, "o" }, { 'O', 2, 49, "O" }, - { 'p', 2, 53, "p" }, { 'P', 2, 54, "P" }, - { '[', 2, 58, "[" }, { '{', 2, 59, "{" }, - { ']', 2, 63, "]" }, { '}', 2, 64, "}" }, - { 127, 2, 71, "DEL" }, - { 'a', 3, 10, "a" }, { 'A', 3, 11, "A" }, - { 's', 3, 15, "s" }, { 'S', 3, 16, "S" }, - { 'd', 3, 20, "d" }, { 'D', 3, 21, "D" }, - { 'f', 3, 25, "f" }, { 'F', 3, 26, "F" }, - { 'g', 3, 30, "g" }, { 'G', 3, 31, "G" }, - { 'h', 3, 35, "h" }, { 'H', 3, 36, "H" }, - { 'j', 3, 40, "j" }, { 'J', 3, 41, "J" }, - { 'k', 3, 45, "k" }, { 'K', 3, 46, "K" }, - { 'l', 3, 50, "l" }, { 'L', 3, 51, "L" }, - { ';', 3, 55, ";" }, { ':', 3, 56, ":" }, - {'\'', 3, 60, "'" }, { '"', 3, 61,"\"" }, - { 13, 3, 65, "RETN"}, - {'\\', 3, 71,"\\" }, { '|', 3, 72, "|" }, - { 'z', 4, 12, "z" }, { 'Z', 4, 13, "Z" }, - { 'x', 4, 17, "x" }, { 'X', 4, 18, "X" }, - { 'c', 4, 22, "c" }, { 'C', 4, 23, "C" }, - { 'v', 4, 27, "v" }, { 'V', 4, 28, "V" }, - { 'b', 4, 32, "b" }, { 'B', 4, 33, "B" }, - { 'n', 4, 37, "n" }, { 'N', 4, 38, "N" }, - { 'm', 4, 42, "m" }, { 'M', 4, 43, "M" }, - { ',', 4, 47, "," }, { '<', 4, 48, "<" }, - { '.', 4, 52, "." }, { '>', 4, 53, ">" }, - { '/', 4, 57, "/" }, { '?', 4, 58, "?" }, - { 10, 4, 69, "LF" }, - { ' ', 5, 13, " SPACE BAR "}, - {'\0', 0, 0, "" } - }; - - static struct natkey { - char natc; - int natrow; - int natcol; - char *natsymbol; - } natkeytab [][29] = { - { - { '"', 1, 12, "\""}, - { '&', 1, 32, "&" }, - { '/', 1, 37, "/" }, - { '(', 1, 42, "(" }, - { ')', 1, 47, ")" }, - { '=', 1, 52, "=" }, - { '+', 1, 56, "+" }, { '?', 1, 57, "?" }, - { '`', 1, 61, "`" }, { '@', 1, 62, "@" }, - { '<', 1, 66, "<" }, { '>', 1, 67, ">" }, - { '}', 2, 58, "}" }, { ']', 2, 59, "]" }, - { '^', 2, 63, "^" }, { '~', 2, 64, "~" }, - { '|', 3, 55, "|" }, {'\\', 3, 56,"\\" }, - { '{', 3, 60, "{" }, { '[', 3, 61, "[" }, - {'\'', 3, 71, "'" }, { '*', 3, 72, "*" }, - { ',', 4, 47, "," }, { ';', 4, 48, ";" }, - { '.', 4, 52, "." }, { ':', 4, 53, ":" }, - { '-', 4, 57, "-" }, { '_', 4, 58, "_" }, - {'\0', 0, 0, "" } - }, - { - { '"', 1, 12, "\""}, - { '&', 1, 32, "&" }, - { '/', 1, 37, "/" }, - { '(', 1, 42, "(" }, - { ')', 1, 47, ")" }, - { '=', 1, 52, "=" }, - { '+', 1, 56, "+" }, { '?', 1, 57, "?" }, - { '`', 1, 61, "`" }, { '@', 1, 62, "@" }, - { '<', 1, 66, "<" }, { '>', 1, 67, ">" }, - { '}', 2, 58, "}" }, { ']', 2, 59, "]" }, - { '~', 2, 63, "~" }, { '^', 2, 64, "^" }, - { '|', 3, 55, "|" }, {'\\', 3, 56,"\\" }, - { '{', 3, 60, "{" }, { '[', 3, 61, "[" }, - {'\'', 3, 71, "'" }, { '*', 3, 72, "*" }, - { ',', 4, 47, "," }, { ';', 4, 48, ";" }, - { '.', 4, 52, "." }, { ':', 4, 53, ":" }, - { '-', 4, 57, "-" }, { '_', 4, 58, "_" }, - {'\0', 0, 0, "" } - } - }; - - static struct curkey { - char *curkeymsg[3]; - int curkeyrow; - int curkeycol; - char *curkeysymbol; - char *curkeyname; - } curkeytab [] = { - - /* A Reset, A Set, VT52 */ - - {{"\033[A","\033OA","\033A"}, 0, 56, "UP", "Up arrow" }, - {{"\033[B","\033OB","\033B"}, 0, 61, "DN", "Down arrow" }, - {{"\033[D","\033OD","\033D"}, 0, 66, "LT", "Left arrow" }, - {{"\033[C","\033OC","\033C"}, 0, 71, "RT", "Right arrow"}, - {{"", "", "" }, 0, 0, "", "" } - }; - - static struct fnkey { - char *fnkeymsg[4]; - int fnkeyrow; - int fnkeycol; - char *fnkeysymbol; - char *fnkeyname; - } fnkeytab [] = { - - /* ANSI-num,ANSI-app,VT52-nu,VT52-ap, r, c, symb name */ - - {{"\033OP","\033OP","\033P","\033P" }, 6, 59, "PF1", "PF1" }, - {{"\033OQ","\033OQ","\033Q","\033Q" }, 6, 63, "PF2", "PF2" }, - {{"\033OR","\033OR","\033R","\033R" }, 6, 67, "PF3", "PF3" }, - {{"\033OS","\033OS","\033S","\033S" }, 6, 71, "PF4", "PF4" }, - {{"7", "\033Ow","7", "\033?w"}, 7, 59, " 7 ", "Numeric 7" }, - {{"8", "\033Ox","8", "\033?x"}, 7, 63, " 8 ", "Numeric 8" }, - {{"9", "\033Oy","9", "\033?y"}, 7, 67, " 9 ", "Numeric 9" }, - {{"-", "\033Om","-", "\033?m"}, 7, 71, " - ", "Minus" }, - {{"4", "\033Ot","4", "\033?t"}, 8, 59, " 4 ", "Numeric 4" }, - {{"5", "\033Ou","5", "\033?u"}, 8, 63, " 5 ", "Numeric 5" }, - {{"6", "\033Ov","6", "\033?v"}, 8, 67, " 6 ", "Numeric 6" }, - {{",", "\033Ol",",", "\033?l"}, 8, 71, " , ", "Comma" }, - {{"1", "\033Oq","1", "\033?q"}, 9, 59, " 1 ", "Numeric 1" }, - {{"2", "\033Or","2", "\033?r"}, 9, 63, " 2 ", "Numeric 2" }, - {{"3", "\033Os","3", "\033?s"}, 9, 67, " 3 ", "Numeric 3" }, - {{"0", "\033Op","0", "\033?p"},10, 59," O ","Numeric 0"}, - {{".", "\033On",".", "\033?n"},10, 67, " . ", "Point" }, - {{"\015", "\033OM","\015", "\033?M"},10, 71, "ENT", "ENTER" }, - {{"","","",""}, 0, 0, "", "" } - }; - - static struct ckey { - int ccount; - char *csymbol; - } ckeytab [] = { - { 0, "NUL (CTRL-@ or CTRL-Space)" }, - { 0, "SOH (CTRL-A)" }, - { 0, "STX (CTRL-B)" }, - { 0, "ETX (CTRL-C)" }, - { 0, "EOT (CTRL-D)" }, - { 0, "ENQ (CTRL-E)" }, - { 0, "ACK (CTRL-F)" }, - { 0, "BEL (CTRL-G)" }, - { 0, "BS (CTRL-H) (BACK SPACE)" }, - { 0, "HT (CTRL-I) (TAB)" }, - { 0, "LF (CTRL-J) (LINE FEED)" }, - { 0, "VT (CTRL-K)" }, - { 0, "FF (CTRL-L)" }, - { 0, "CR (CTRL-M) (RETURN)" }, - { 0, "SO (CTRL-N)" }, - { 0, "SI (CTRL-O)" }, - { 0, "DLE (CTRL-P)" }, - { 0, "DC1 (CTRL-Q) (X-On)" }, - { 0, "DC2 (CTRL-R)" }, - { 0, "DC3 (CTRL-S) (X-Off)" }, - { 0, "DC4 (CTRL-T)" }, - { 0, "NAK (CTRL-U)" }, - { 0, "SYN (CTRL-V)" }, - { 0, "ETB (CTRL-W)" }, - { 0, "CAN (CTRL-X)" }, - { 0, "EM (CTRL-Y)" }, - { 0, "SUB (CTRL-Z)" }, - { 0, "ESC (CTRL-[) (ESCAPE)" }, - { 0, "FS (CTRL-\\ or CTRL-? or CTRL-_)" }, - { 0, "GS (CTRL-])" }, - { 0, "RS (CTRL-^ or CTRL-~ or CTRL-`)" }, - { 0, "US (CTRL-_ or CTRL-?)" } - }; - - static char *keyboardmenu[] = { - "Standard American ASCII layout", - "Swedish national layout D47", - "Swedish national layout E47", - /* add new keyboard layouts here */ - "" - }; - - static char *curkeymodes[3] = { - "ANSI / Cursor key mode RESET", - "ANSI / Cursor key mode SET", - "VT52 Mode" - }; - - static char *fnkeymodes[4] = { - "ANSI Numeric mode", - "ANSI Application mode", - "VT52 Numeric mode", - "VT52 Application mode" - }; - - ledmsg[0] = "L1 L2 L3 L4"; ledseq[0] = "1;2;3;4"; - ledmsg[1] = " L2 L3 L4"; ledseq[1] = "1;0;4;3;2"; - ledmsg[2] = " L2 L3"; ledseq[2] = "1;4;;2;3"; - ledmsg[3] = "L1 L2"; ledseq[3] = ";;2;1"; - ledmsg[4] = "L1"; ledseq[4] = "1"; - ledmsg[5] = ""; ledseq[5] = ""; - -#ifdef UNIX - fflush(stdout); -#endif - ed(2); - cup(10,1); - println("These LEDs (\"lamps\") on the keyboard should be on:"); - for (i = 0; i <= 5; i++) { - cup(10,52); el(0); printf("%s", ledmsg[i]); - decll("0"); - decll(ledseq[i]); - cup(12,1); holdit(); - } - - ed(2); - cup(10,1); - println("Test of the AUTO REPEAT feature"); - println(""); - println("Hold down an alphanumeric key for a while, then push RETURN."); - printf("%s", "Auto Repeat OFF: "); - rm("?8"); - inputline(arptstring); - if (strlen(arptstring) == 0) println("No characters read!??"); - else if (strlen(arptstring) == 1) println("OK."); - else println("Too many characters read."); - println(""); - println("Hold down an alphanumeric key for a while, then push RETURN."); - printf("%s", "Auto Repeat ON: "); - sm("?8"); - inputline(arptstring); - if (strlen(arptstring) == 0) println("No characters read!??"); - else if (strlen(arptstring) == 1) println("Not enough characters read."); - else println("OK."); - println(""); - holdit(); - - ed(2); - cup(5,10); - println("Choose keyboard layout:"); - kblayout = menu(keyboardmenu); - if (kblayout) { - kblayout--; - for (j = 0; natkeytab[kblayout][j].natc != '\0'; j++) { - for (i = 0; keytab[i].c != '\0'; i++) { - if (keytab[i].row == natkeytab[kblayout][j].natrow && - keytab[i].col == natkeytab[kblayout][j].natcol) { - keytab[i].c = natkeytab[kblayout][j].natc; - keytab[i].symbol = natkeytab[kblayout][j].natsymbol; - break; - } - } - } - } - - ed(2); - for (i = 0; keytab[i].c != '\0'; i++) { - cup(1 + 2 * keytab[i].row, 1 + keytab[i].col); - sgr("7"); - printf("%s", keytab[i].symbol); - sgr(""); - } - cup(22,1); -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag &= ~CRMOD; - ttyNew.sg_flag &= ~ECHO; - stty(0, &ttyNew); -# else - ttyNew.c_lflag &= ~(ECHO|ECHOK|ECHOE|ECHOKE|ECHONL|ECHOPRT|ECHOCTL); - ttyNew.c_iflag &= ~INLCR; - ttyNew.c_oflag &= ~OCRNL; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - inflush(); - printf("Press each key, both shifted and unshifted. Finish with RETURN:"); - do { /* while (kbdc != 13) */ - cup(23,1); kbdc = inchar(); - cup(23,1); el(0); - sprintf(kbds, "%c", kbdc); - chrprint(kbds); - for (i = 0; keytab[i].c != '\0'; i++) { - if (keytab[i].c == kbdc) { - cup(1 + 2 * keytab[i].row, 1 + keytab[i].col); - printf("%s", keytab[i].symbol); - break; - } - } - } while (kbdc != 13); -#ifdef SARG10 - inchar(); /* Local hack: Read LF that TOPS-10 adds to CR */ -#endif - cup(23,1); el(0); - - for (ckeymode = 0; ckeymode <= 2; ckeymode++) { - if (ckeymode) sm("?1"); - else rm("?1"); - for (i = 0; curkeytab[i].curkeysymbol[0] != '\0'; i++) { - cup(1 + 2 * curkeytab[i].curkeyrow, 1 + curkeytab[i].curkeycol); - sgr("7"); - printf("%s", curkeytab[i].curkeysymbol); - sgr(""); - } - cup(20,1); printf("<%s>%20s", curkeymodes[ckeymode], ""); - cup(22,1); el(0); - cup(22,1); printf("%s", "Press each cursor key. Finish with TAB."); - for(;;) { - cup(23,1); - if (ckeymode == 2) rm("?2"); /* VT52 mode */ - curkeystr = instr(); - esc("<"); /* ANSI mode */ - cup(23,1); el(0); - cup(23,1); chrprint(curkeystr); - if (!strcmp(curkeystr,"\t")) break; - for (i = 0; curkeytab[i].curkeysymbol[0] != '\0'; i++) { - if (!strcmp(curkeystr,curkeytab[i].curkeymsg[ckeymode])) { - sgr("7"); - printf(" (%s key) ", curkeytab[i].curkeyname); - sgr(""); - cup(1 + 2 * curkeytab[i].curkeyrow, - 1 + curkeytab[i].curkeycol); - printf("%s", curkeytab[i].curkeysymbol); - break; - } - } - if (i == sizeof(curkeytab) / sizeof(struct curkey) - 1) { - sgr("7"); - printf("%s", " (Unknown cursor key) "); - sgr(""); - } - } - } - - for (fkeymode = 0; fkeymode <= 3; fkeymode++) { - for (i = 0; fnkeytab[i].fnkeysymbol[0] != '\0'; i++) { - cup(1 + 2 * fnkeytab[i].fnkeyrow, 1 + fnkeytab[i].fnkeycol); - sgr("7"); - printf("%s", fnkeytab[i].fnkeysymbol); - sgr(""); - } - cup(20,1); printf("<%s>%20s", fnkeymodes[fkeymode], ""); - cup(22,1); el(0); - cup(22,1); printf("%s", "Press each function key. Finish with TAB."); - for(;;) { - cup(23,1); - if (fkeymode >= 2) rm("?2"); /* VT52 mode */ - if (fkeymode % 2) deckpam(); /* Application mode */ - else deckpnm(); /* Numeric mode */ - fnkeystr = instr(); - esc("<"); /* ANSI mode */ - cup(23,1); el(0); - cup(23,1); chrprint(fnkeystr); - if (!strcmp(fnkeystr,"\t")) break; - for (i = 0; fnkeytab[i].fnkeysymbol[0] != '\0'; i++) { - if (!strcmp(fnkeystr,fnkeytab[i].fnkeymsg[fkeymode])) { - sgr("7"); - printf(" (%s key) ", fnkeytab[i].fnkeyname); - sgr(""); - cup(1 + 2 * fnkeytab[i].fnkeyrow, 1 + fnkeytab[i].fnkeycol); - printf("%s", fnkeytab[i].fnkeysymbol); - break; - } - } - if (i == sizeof(fnkeytab) / sizeof(struct fnkey) - 1) { - sgr("7"); - printf("%s", " (Unknown function key) "); - sgr(""); - } - } - } - -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag |= CRMOD; - stty(0, &ttyNew); -# else - ttyNew.c_iflag |= INLCR; - ttyNew.c_oflag |= OCRNL; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - ed(2); - cup(5,1); - println("Finally, a check of the ANSWERBACK MESSAGE, which can be sent"); - println("by pressing CTRL-BREAK. The answerback message can be loaded"); - println("in SET-UP B by pressing SHIFT-A and typing e.g."); - println(""); - println(" \" H e l l o , w o r l d Return \""); - println(""); - println("(the double-quote characters included). Do that, and then try"); - println("to send an answerback message with CTRL-BREAK. If it works,"); - println("the answerback message should be displayed in reverse mode."); - println("Finish with a single RETURN."); - -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag &= ~CRMOD; - stty(0, &ttyNew); -# else - ttyNew.c_iflag &= ~INLCR; - ttyNew.c_oflag &= ~OCRNL; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - do { - cup(17,1); - inflush(); - abmstr = instr(); - cup(17,1); - el(0); - chrprint(abmstr); - } while (strcmp(abmstr,"\r")); - - ed(2); - for (i = 0; i < 32; i++) { - cup(1 + (i % 16), 1 + 40 * (i / 16)); - sgr("7"); - printf("%s", ckeytab[i].csymbol); - sgr("0"); - } - cup(19,1); -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag |= CRMOD; - stty(0, &ttyNew); -# else - ttyNew.c_iflag |= INLCR; - ttyNew.c_oflag |= OCRNL; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - println( - "Push each CTRL-key TWICE. Note that you should be able to send *all*"); - println( - "CTRL-codes twice, including CTRL-S (X-Off) and CTRL-Q (X-Off)!"); - println( - "Finish with DEL (also called DELETE or RUB OUT), or wait 1 minute."); -#ifdef UNIX -# ifndef BSD4_4 -# ifdef SIII - ttyNew.sg_flag &= ~CBREAK; - stty(0, &ttyNew); -# endif - ttyNew.sg_flag |= RAW; - stty(0, &ttyNew); -# else - ttyNew.c_lflag &= ~(ICANON|ISIG); - ttyNew.c_cc[VMIN] = 1; - ttyNew.c_cc[VTIME] = 0; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - ttybin(1); -#ifdef SARG20 - page(0); /* Turn off all character processing at input */ - superbin(1); /* Turn off ^C (among others). Keep your fingers crossed!! */ -#endif - do { - cup(23,1); kbdc = inchar(); - cup(23,1); el(0); - if (kbdc < 32) printf(" %s", ckeytab[kbdc].csymbol); - else { - sprintf(kbds, "%c", kbdc); - chrprint(kbds); - printf("%s", " -- not a CTRL key"); - } - if (kbdc < 32) ckeytab[kbdc].ccount++; - if (ckeytab[kbdc].ccount == 2) { - cup(1 + (kbdc % 16), 1 + 40 * (kbdc / 16)); - printf("%s", ckeytab[kbdc].csymbol); - } - } while (kbdc != '\177'); -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag &= ~RAW; - ttyNew.sg_flag |= ECHO; - stty(0, &ttyNew); -# ifdef SIII - ttyNew.sg_flag |= CBREAK; - stty(0, &ttyNew); -# endif -# else - ttyNew.c_lflag |= (ECHO|ECHOK|ECHOE|ECHOKE|ECHOPRT|ECHOCTL)|ISIG; - ttyNew.c_lflag &= ~ICANON; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - ttybin(0); -#ifdef SARG20 - superbin(0); /* Puuuh! We made it!? */ - page(1); /* Back to normal input processing */ - ttybin(1); /* This must be the mode for DEC20 */ -#endif - cup(24,1); - okflag = 1; - for (i = 0; i < 32; i++) if (ckeytab[i].ccount < 2) okflag = 0; - if (okflag) printf("%s", "OK. "); - else printf("%s", "You have not been able to send all CTRL keys! "); - holdit(); -} - -tst_reports() { - /* Test of: - (AnswerBack Message) - SM RM (Set/Reset Mode) - LineFeed / Newline - DSR (Device Status Report) - DA (Device Attributes) - DECREQTPARM (Request Terminal Parameters) - */ - - int parity, nbits, xspeed, rspeed, clkmul, flag; - int i, reportpos; - char *report, *report2; - static char *attributes[][2] = { - { "\033[?1;0c", "No options (vanilla VT100)" }, - { "\033[?1;1c", "VT100 with STP" }, - { "\033[?1;2c", "VT100 with AVO (could be a VT102)" }, - { "\033[?1;3c", "VT100 with STP and AVO" }, - { "\033[?1;4c", "VT100 with GPO" }, - { "\033[?1;5c", "VT100 with STP and GPO" }, - { "\033[?1;6c", "VT100 with AVO and GPO" }, - { "\033[?1;7c", "VT100 with STP, AVO and GPO" }, - { "\033[?1;11c", "VT100 with PP and AVO" }, - { "\033[?1;15c", "VT100 with PP, GPO and AVO" }, - { "\033[?4;2c", "VT132 with AVO" }, - { "\033[?4;3c", "VT132 with AVO and STP" }, - { "\033[?4;6c", "VT132 with GPO and AVO" }, - { "\033[?4;7c", "VT132 with GPO, AVO, and STP" }, - { "\033[?4;11c", "VT132 with PP and AVO" }, - { "\033[?4;15c", "VT132 with PP, GPO and AVO" }, - { "\033[?7c", "VT131" }, - { "\033[?12;5c", "VT125" }, /* VT125 also has ROM version */ - { "\033[?12;7c", "VT125 with AVO" }, /* number, so this won't work */ - { "\033[?5;0c", "VK100 (GIGI)" }, - { "\033[?5c", "VK100 (GIGI)" }, - { "", "" } - }; - -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag &= ~ECHO; - stty(0, &ttyNew); -# else - ttyNew.c_lflag &= ~(ECHO|ECHOK|ECHOE|ECHOKE|ECHONL|ECHOPRT|ECHOCTL); - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - cup(5,1); - println("This is a test of the ANSWERBACK MESSAGE. (To load the A.B.M."); - println("see the TEST KEYBOARD part of this program). Below here, the"); - println("current answerback message in your terminal should be"); - println("displayed. Finish this test with RETURN."); - cup(10,1); - inflush(); - printf("%c", 5); /* ENQ */ - report = instr(); - cup(10,1); - chrprint(report); - cup(12,1); - holdit(); - - ed(2); - cup(1,1); - println("Test of LineFeed/NewLine mode."); - cup(3,1); - sm("20"); -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag &= ~CRMOD; - stty(0, &ttyNew); -# else - ttyNew.c_iflag &= ~INLCR; - ttyNew.c_oflag &= ~OCRNL; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - printf("NewLine mode set. Push the RETURN key: "); - report = instr(); - cup(4,1); - el(0); - chrprint(report); - if (!strcmp(report, "\015\012")) printf(" -- OK"); - else printf(" -- Not expected"); - cup(6,1); - rm("20"); - printf("NewLine mode reset. Push the RETURN key: "); - report = instr(); - cup(7,1); - el(0); - chrprint(report); - if (!strcmp(report, "\015")) printf(" -- OK"); - else printf(" -- Not expected"); - cup(9,1); -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag |= CRMOD; - stty(0, &ttyNew); -# else - ttyNew.c_iflag |= INLCR; - ttyNew.c_oflag |= OCRNL; - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif - holdit(); - - ed(2); - cup(1,1); - printf("Test of Device Status Report 5 (report terminal status)."); - cup(2,1); - dsr(5); - report = instr(); - cup(2,1); - el(0); - printf("Report is: "); - chrprint(report); - if (!strcmp(report,"\033[0n")) printf(" -- means \"TERMINAL OK\""); - else if (!strcmp(report,"\033[3n")) printf(" -- means \"TERMINAL OK\""); - else printf(" -- Unknown response!"); - - cup(4,1); - println("Test of Device Status Report 6 (report cursor position)."); - cup(5,1); - dsr(6); - report = instr(); - cup(5,1); - el(0); - printf("Report is: "); - chrprint(report); - if (!strcmp(report,"\033[5;1R")) printf(" -- OK"); - else printf(" -- Unknown response!"); - - cup(7,1); - println("Test of Device Attributes report (what are you)"); - cup(8,1); - da(0); - report = instr(); - cup(8,1); - el(0); - printf("Report is: "); - chrprint(report); - for (i = 0; *attributes[i][0] != '\0'; i++) { - if (!strcmp(report,attributes[i][0])) break; - } - if (*attributes[i][0] == '\0') - printf(" -- Unknown response, refer to the manual"); - else { - printf(" -- means %s", attributes[i][1]); - if (i) { - cup(9,1); - println("Legend: STP = Processor Option"); - println(" AVO = Advanced Video Option"); - println(" GPO = Graphics Processor Option"); - println(" PP = Printer Port"); - } - } - - cup(14,1); - println("Test of the \"Request Terminal Parameters\" feature, argument 0."); - cup(15,1); - decreqtparm(0); - report = instr(); - cup(15,1); - el(0); - printf("Report is: "); - chrprint(report); - if (strlen(report) < 16 - || report[0] != '\033' - || report[1] != '[' - || report[2] != '2' - || report[3] != ';') - println(" -- Bad format"); - else { - reportpos = 4; - parity = scanto(report, &reportpos, ';'); - nbits = scanto(report, &reportpos, ';'); - xspeed = scanto(report, &reportpos, ';'); - rspeed = scanto(report, &reportpos, ';'); - clkmul = scanto(report, &reportpos, ';'); - flag = scanto(report, &reportpos, 'x'); - if (parity == 0 || nbits == 0 || clkmul == 0) println(" -- Bad format"); - else println(" -- OK"); - printf( - "This means: Parity %s, %s bits, xmitspeed %s, recvspeed %s.\n", - lookup(paritytable, parity), - lookup(nbitstable, nbits), - lookup(speedtable, xspeed), - lookup(speedtable, rspeed)); - printf("(CLoCk MULtiplier = %d, STP option flag = %d)\n", clkmul, flag); - } - - cup(19,1); - println("Test of the \"Request Terminal Parameters\" feature, argument 1."); - cup(20,1); - decreqtparm(1); /* Does the same as decreqtparm(0), reports "3" */ - report2 = instr(); - cup(20,1); - el(0); - printf("Report is: "); - chrprint(report2); - if (strlen(report2) < 3 - || report2[2] != '3') - println(" -- Bad format"); - else { - report2[2] = '2'; - if (!strcmp(report,report2)) println(" -- OK"); - else println(" -- Bad format"); - } - cup(24,1); - holdit(); -#ifdef UNIX -# ifndef BSD4_4 - ttyNew.sg_flag |= ECHO; - stty(0, &ttyNew); -# else - ttyNew.c_lflag |= (ECHO|ECHOK|ECHOE|ECHOKE|ECHOPRT|ECHOCTL); - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#endif -} - -tst_vt52() { - - static struct rtabl { - char *rcode; - char *rmsg; - } resptable[] = { - { "\033/K", " -- OK (means Standard VT52)" }, - { "\033/Z", " -- OK (means VT100 emulating VT52)" }, - { "", " -- Unknown response"} - }; - - int i,j; - char *response; - - rm("?2"); /* Reset ANSI (VT100) mode, Set VT52 mode */ - esc("H"); /* Cursor home */ - esc("J"); /* Erase to end of screen */ - esc("H"); /* Cursor home */ - for (i = 0; i <= 23; i++) { - for (j = 0; j <= 9; j++) - printf("%s", "FooBar "); - println("Bletch"); - } - esc("H"); /* Cursor home */ - esc("J"); /* Erase to end of screen */ - - vt52cup(7,47); - printf("nothing more."); - for (i = 1; i <= 10; i++) printf("THIS SHOULD GO AWAY! "); - for (i = 1; i <= 5; i++) { - vt52cup(1,1); - printf("%s", "Back scroll (this should go away)"); - esc("I"); /* Reverse LineFeed (with backscroll!) */ - } - vt52cup(12,60); - esc("J"); /* Erase to end of screen */ - for (i = 2; i <= 6; i++) { - vt52cup(i,1); - esc("K"); /* Erase to end of line */ - } - - for (i = 2; i <= 23; i++) { - vt52cup(i,70); printf("%s", "**Foobar"); - } - vt52cup(23,10); - for (i = 23; i >= 2; i--) { - printf("%s", "*"); - printf("%c", 8); /* BS */ - esc("I"); /* Reverse LineFeed (LineStarve) */ - } - vt52cup(1,70); - for (i = 70; i >= 10; i--) { - printf("%s", "*"); - esc("D"); esc("D"); /* Cursor Left */ - } - vt52cup(24,10); - for (i = 10; i <= 70; i++) { - printf("%s", "*"); - printf("%c", 8); /* BS */ - esc("C"); /* Cursor Right */ - } - vt52cup(2,11); - for (i = 2; i <= 23; i++) { - printf("%s", "!"); - printf("%c", 8); /* BS */ - esc("B"); /* Cursor Down */ - } - vt52cup(23,69); - for (i = 23; i >= 2; i--) { - printf("%s", "!"); - printf("%c", 8); /* BS */ - esc("A"); /* Cursor Up */ - } - for (i = 2; i <= 23; i++) { - vt52cup(i,71); - esc("K"); /* Erase to end of line */ - } - - vt52cup(10,16); - printf("%s", "The screen should be cleared, and have a centered"); - vt52cup(11,16); - printf("%s", "rectangle of \"*\"s with \"!\"s on the inside to the"); - vt52cup(12,16); - printf("%s", "left and right. Only this, and"); - vt52cup(13,16); - holdit(); - - esc("H"); /* Cursor home */ - esc("J"); /* Erase to end of screen */ - printf("%s", "This is the normal character set:"); - for (j = 0; j <= 1; j++) { - vt52cup(3 + j, 16); - for (i = 0; i <= 47; i++) - printf("%c", 32 + i + 48 * j); - } - vt52cup(6,1); - printf("%s", "This is the special graphics character set:"); - esc("F"); /* Select Special Graphics character set */ - for (j = 0; j <= 1; j++) { - vt52cup(8 + j, 16); - for (i = 0; i <= 47; i++) - printf("%c", 32 + i + 48 * j); - } - esc("G"); /* Select ASCII character set */ - vt52cup(12,1); - holdit(); - - esc("H"); /* Cursor home */ - esc("J"); /* Erase to end of screen */ - println("Test of terminal response to IDENTIFY command"); - esc("Z"); /* Identify */ - response = instr(); - println(""); - printf("Response was"); - esc("<"); /* Enter ANSI mode (VT100 mode) */ - chrprint(response); - for(i = 0; resptable[i].rcode[0] != '\0'; i++) - if (!strcmp(response, resptable[i].rcode)) - break; - printf("%s", resptable[i].rmsg); - println(""); - println(""); - holdit(); -} - -tst_insdel() { - - /* Test of: - SM/RM(4) (= IRM (Insertion/replacement mode)) - ICH (Insert Character) - DCH (Delete character) - IL (Insert line) - DL (Delete line) - */ - - int i, row, col, sw, dblchr, scr132; - - for(scr132 = 0; scr132 <= 1; scr132++) { - if (scr132) { sm("?3"); sw = 132; } - else { rm("?3"); sw = 80; } - ed(2); - cup(1,1); - for (row=1; row<=24; row++) { - cup(row,1); - for (col=1; col<=sw; col++) - printf("%c", 'A'-1+row); - } - cup(4,1); - printf("Screen accordion test (Insert & Delete Line). "); holdit(); - ri(); el(2); - decstbm( 2,23); - sm("?6"); - cup(1,1); - for (row=1; row<=24; row++) { - il(row); - dl(row); - } - rm("?6"); - decstbm( 0, 0); - cup(2,1); - printf( - "Top line: A's, bottom line: X's, this line, nothing more. "); - holdit(); - cup(2,1); ed(0); - cup(1,2); - printf("B"); - cub(1); - sm("4"); - for (col=2; col<=sw-1; col++) - printf("*"); - rm("4"); - cup(4,1); - printf("Test of 'Insert Mode'. The top line should be 'A*** ... ***B'. "); - holdit(); ri(); el(2); - cup(1,2); - dch(sw-2); - cup(4,1); - printf("Test of 'Delete Character'. The top line should be 'AB'. "); - holdit(); - - for(dblchr = 1; dblchr <= 2; dblchr++) { - ed(2); - for (row=1; row<=24; row++) { - cup(row,1); - if (dblchr == 2) decdwl(); - for (col=1; col<=sw/dblchr; col++) - printf("%c", 'A'-1+row); - cup(row,sw/dblchr-row); - dch(row); - } - cup(4,1); - println("The right column should be staggered "); - printf("by one. "); - holdit(); - } - ed(2); - cup(1,1); - println("If your terminal has the ANSI 'Insert Character' function"); - println("(the VT102 does not), then you should see a line like this"); - println(" A B C D E F G H I J K L M N O P Q R S T U V W X Y Z"); - println("below:"); - println(""); - for (i = 'Z'; i >= 'A'; i--) { - printf("%c\010",i); - ich(2); - } - cup(10,1); - holdit(); - - if (sw == 132) rm("?3"); - } -} - -dch(pn) int pn; { brc(pn, 'P'); } /* Delete character */ -ich(pn) int pn; { brc(pn, '@'); } /* Insert character -- not in VT102 */ -dl(pn) int pn; { brc(pn, 'M'); } /* Delete line */ -il(pn) int pn; { brc(pn, 'L'); } /* Insert line */ - -/* Test of some known VT100 bugs and misfeatures */ - -tst_bugs() { - - int i, menuchoice; - - static char *menutable[] = { - "Exit to main menu", - "Bug A: Smooth scroll to jump scroll", - "Bug B: Scrolling region", - "Bug C: Wide to narrow screen", - "Bug D: Narrow to wide screen", - "Bug E: Cursor move from double- to single-wide line", - "Bug F: Column mode escape sequence", - "Wrap around with cursor addressing", - "Erase right half of double width lines", - "Funny scroll regions", - /* Add more here */ - "" - }; - - static char *hmsg[] = { - "Test of known bugs in the DEC VT100 series. The numbering of some of", - "the bugs (A-F) refers to the article 'VT100 MAGIC' by Sami Tabih in", - "the 'Proceedings of the DEC Users Society' at St. Louis, Missouri, May", - "1983. To understand some of the tests, you have to look at the source", - "code or the article. Of course, a good VT100-compatible terminal", - "should not have these bugs (or have some means of disabling them)! If", - "a bug appears, you might want to RESET the terminal before continuing", - "the test. There is a test of the RESET function in the main menu.", - "" }; - - do { - ed(2); cup(1,1); - for (i = 0; *hmsg[i]; i++) println(hmsg[i]); - println(""); - println(" Choose bug test number:"); - menuchoice = menu(menutable); - switch (menuchoice) { - case 1: bug_a(); break; - case 2: bug_b(); break; - case 3: bug_c(); break; - case 4: bug_d(); break; - case 5: bug_e(); break; - case 6: bug_f(); break; - case 7: bug_w(); break; - case 8: bug_l(); break; - case 9: bug_s(); break; - } - } while (menuchoice); -} - -/* Bug A: Smooth scroll to jump scroll */ - -bug_a() { - int i; - - cup (10, 1); - println("This is a test of the VT100 'Scroll while toggle softscroll'"); - println("bug. The cursor may disappear, or move UP the screen, or"); - println("multiple copies of some lines may appear."); - holdit(); - - /* Invoke the bug */ - - esc ("[24H"); /* Simplified cursor movement */ - rm("?4"); for (i = 1; i <= 20; i++) printf("\n"); - sm("?4"); for (i = 1; i <= 10; i++) printf("\n"); - rm("?4"); for (i = 1; i <= 5; i++) printf("\n"); - - /* That should be enough to show the bug. But we'll try another way: */ - sm ("?4"); /* Set soft scroll */ - nel (); /* "NextLine", move down */ - rm ("?4"); /* Reset soft scroll */ - nel (); /* "NextLine", move down */ - for (i = 1; i <= 10; i++) { /* Show the bug */ - printf ("Softscroll bug test, line %d. ", i); - holdit(); - } - println("That should have been enough to show the bug, if present."); - holdit(); -} - -/* Bug B: Scrolling region */ - -bug_b() { - char c; - - decaln(); - cup( 1,1); el(0); - printf("Line 11 should be double-wide, line 12 should be cleared."); - cup( 2,1); el(0); - printf("Then, the letters A-P should be written at the beginning"); - cup( 3,1); el(0); - printf("of lines 12-24, and the empty line and A-E are scrolled away."); - cup( 4,1); el(0); - printf("If the bug is present, some lines are confused, look at K-P."); - cup(11,1); decdwl(); - decstbm(12,24); - cup(12,1); el(0); printf("Here we go... "); holdit(); - cup(12,1); ri(); /* Bug comes here */ - for (c = 'A'; c <= 'P'; c++) printf("%c\n",c); /* Bug shows here */ - holdit(); - decstbm(0,0); /* No scr. region */ -} - -/* Bug C: Wide to narrow screen */ - -bug_c() { - sm("?3"); /* 132 column mode */ - cup(1,81); - rm("?3"); /* 80 column mode */ - cup(12,5); - printf("Except for this line, the screen should be blank. "); - holdit(); -} - -/* Bug D: Narrow to wide screen */ - -bug_d() { - int i; - char result; - /* Make the bug appear */ - do { - cup(14,1); - - /* The original code in the article says - * PRINT ESC$; "[13;1H"; CHR$(10%); - * but I guess a cup(14,1); would do. - * (To output a pure LF might be tricky). - */ - - sm("?3"); /* Make the bug visible */ - cup(1,9); decdwl(); - println("You should see blinking text at the bottom line."); - cup(3,9); decdwl(); - println("Enter 0 to exit, 1 to try to invoke the bug again."); - cup(24,9); decdwl(); sgr("1;5;7"); - printf("If you can see this then the bug did not appear."); sgr(""); - cup(4,9); decdwl(); - result = inchar(); readnl(); - rm("?3"); - } while (result == '1'); - sm("?4"); /* Syrup scroll */ - cup(23,1); - for (i = 1; i <= 5; i++) - println("If the bug is present, this should make things much worse!"); - holdit(); - rm("?4"); /* Jump scroll */ -} - -/* Bug E: Cursor move from double- to single-wide line */ - -bug_e() { - int i; - static char *rend[2] = { "\033[m", "\033[7m" }; - sm("?3"); - cup(1,1); decdwl(); - println("This test should put an 'X' at line 3 column 100."); - for (i = 1; i <= 12; i++) printf("1234567890%s",rend[i & 1]); - cup(1,1); /* The bug appears when we jump from a dobule-wide line */ - cup(3,100); /* to a single-wide line, column > 66. */ - printf("X"); - cup(4, 66); printf("! !"); - cup(5,1); - printf("--------------------------- The 'X' should NOT be above here -"); - printf("---+------------ but above here -----+"); - cup(10,1); decdwl(); holdit(); - rm("?3"); -} - -/* Bug F: Column mode escape sequence */ - -bug_f() { - int i, row, col; - - /* - * VT100 "toggle origin mode, forget rest" bug. If you try to set - * (or clear) parameters and one of them is the "origin mode" - * ("?6") parameter, parameters that appear after the "?6" - * remain unaffected. This is also true on CIT-101 terminals. - */ - sm ("?5"); /* Set reverse mode */ - sm ("?3"); /* Set 132 column mode */ - println("Test VT100 'Toggle origin mode, forget rest' bug, part 1."); - println("The screen should be in reverse, 132 column mode."); - holdit(); - ed (2); - rm ("?6;5;3"); /* Reset (origin, reverse, 132 col) */ - println("Test VT100 'Toggle origin mode, forget rest' bug, part 2.\n"); - println("The screen should be in non-reverse, 80 column mode."); - holdit(); -} - - /* Bug W: - * The dreaded "wraparound" bug! You CUP to col 80, write a char, - * CUP to another line in col 80, write a char. And the brain-damaged - * terminal thinks that "Hokay, so he's written a char in col 80, so - * I stay in col 80 and wait for next character. Let's see now, here - * comes another character, and I'm still in col 80, so I must make - * a NewLine first." -- It doesn't clear that "still in col 80" flag - * on a CUP. Argh! - */ - -bug_w() { - int row, col; - - cup (16,1); - println(" This illustrates the \"wrap around bug\" which exists on a"); - println(" standard VT100. At the top of the screen there should be"); - println(" a row of +'s, and the rightmost column should be filled"); - println(" with *'s. But if the bug is present, some of the *'s may"); - println(" be placed in other places, e.g. in the leftmost column,"); - println(" and the top line of +'s may be scrolled away."); - - cup(1,1); - for (col = 1; col <= 79; col++) - printf ("+"); - for (row = 1; row <= 24; row++) { - hvp (row, 80); - printf ("*"); - } - cup(24,1); - holdit(); -} - - /* Bug L: - * Check if the right half of double-width lines comes back - * when a line is first set to single-width, filled with stuff, - * set to double-width, and finally reset to single-width. - * - * A VT100 has this misfeature, and many others. Foo! - */ - -bug_l() { - cup(15, 1); - printf("This-is-a-long-line-This-is-a-long-line-"); - printf("This-is-a-long-line-This-is-a-long-line-"); - cup(1, 1); - printf("This is a test of what happens to the right half of double-width"); - println(" lines."); - printf("A common misfeature is that the right half does not come back"); - println(" when a long"); - printf("single-width line is set to double-width and then reset to"); - println(" single-width."); - - cup(5, 1); - println("Now the line below should contain 80 characters in single width."); - holdit(); - cup(15, 1); decdwl(); - cup(8, 1); - println("Now the line below should contain 40 characters in double width."); - holdit(); - cup(15, 1); decswl(); - cup(11, 1); - println("Now the line below should contain 80 characters in single width."); - holdit(); - - /* ...and in 132 column mode */ - - sm("?3"); - ed(2); - cup(15, 1); - printf("This-is-a-long-line-This-is-a-long-line-"); - printf("This-is-a-long-line-This-is-a-long-line-"); - printf("This-is-a-long-line-This-is-a-long-line-"); - printf("ending-here-"); - - cup(1, 1); - printf("This is the same test in 132 column mode."); - - cup(5, 1); - println("Now the line below should contain 132 characters in single width."); - holdit(); - cup(15, 1); decdwl(); - cup(8, 1); - println("Now the line below should contain 66 characters in double width."); - holdit(); - cup(15, 1); decswl(); - cup(11, 1); - println("Now the line below should contain 132 characters in single width."); - holdit(); - rm("?3"); -} - -bug_s() { - int i; - decstbm(20,10); /* 20-10=-10, < 2, so no scroll region. */ - cup(1,1); - for (i=1; i<=20; i++) - printf("This is 20 lines of text (line %d), no scroll region.\n", i); - holdit(); - ed(2); - decstbm(0,1); /* Should be interpreted as decstbm(1,1) = none */ - cup(1,1); - for (i=1; i<=20; i++) - printf("This is 20 lines of text (line %d), no scroll region.\n", i); - holdit(); - decstbm(0,0); /* No scroll region (just in case...) */ -} - -tst_rst() { - - /* - * Test of - * - RIS (Reset to Initial State) - * - DECTST (invoke terminal test) - */ - - cup(10,1); - printf ("The terminal will now be RESET. "); - holdit(); - ris(); -#ifdef UNIX - fflush(stdout); -#endif - zleep(5000); /* Wait 5.0 seconds */ - cup(10,1); - println("The terminal is now RESET. Next, the built-in confidence test"); - printf("%s", "will be invoked. "); - holdit(); - ed(2); - dectst(1); -#ifdef UNIX - fflush(stdout); -#endif - zleep(5000); /* Wait 5.0 seconds */ - cup(10,1); - println("If the built-in confidence test found any errors, a code"); - printf("%s", "is visible above. "); - holdit(); -} - -initterminal(pn) int pn; { - -#ifdef UNIX - if (pn==0) { - fflush(stdout); -# ifndef BSD4_4 - gtty(0,&ttyOrg); - gtty(0,&ttyNew); - ttyNew.sg_flag |= CBREAK; -# else - tcgetattr(0, &ttyOrg); - tcgetattr(0, &ttyNew); - ttyNew.c_lflag &= ~ICANON; - ttyNew.c_cc[VMIN] = 1; - ttyNew.c_cc[VTIME] = 0; -# endif - } - else { - fflush(stdout); - inflush(); - sleep(2); -# ifndef BSD4_4 - ttyNew.sg_flag = ttyOrg.sg_flag | CBREAK; -# else - ttyNew.c_lflag &= ~ICANON; - ttyNew.c_cc[VMIN] = 1; - ttyNew.c_cc[VTIME] = 0; -# endif - } -# ifndef BSD4_4 - stty(0,&ttyNew); -# else - tcsetattr(0, TCSADRAIN, &ttyNew); -# endif -#ifdef SIII - close(2); - open("/dev/tty",O_RDWR|O_NDELAY); -#endif -#endif -#ifdef SARG10 - /* Set up neccesary TOPS-10 terminal parameters */ - - trmop(02041, `VT100`); /* tty type vt100 */ - trmop(02002, 0); /* tty no tape */ - trmop(02003, 0); /* tty lc */ - trmop(02005, 1); /* tty tab */ - trmop(02010, 1); /* tty no crlf */ - trmop(02020, 0); /* tty no tape */ - trmop(02021, 1); /* tty page */ - trmop(02025, 0); /* tty blanks */ - trmop(02026, 1); /* tty no alt */ - trmop(02040, 1); /* tty defer */ -#endif -#ifdef SARG20 - ttybin(1); /* set line to binary mode */ -#endif - /* Set up my personal prejudices */ - - esc("<"); /* Enter ANSI mode (if in VT52 mode) */ - rm("?1"); /* cursor keys normal */ - rm("?3"); /* 80 col mode */ - rm("?4"); /* Jump scroll */ - rm("?5"); /* Normal screen */ - rm("?6"); /* Absolute origin mode */ - sm("?7"); /* Wrap around on */ - rm("?8"); /* Auto repeat off */ - decstbm(0,0); /* No scroll region */ - sgr("0"); /* Normal character attributes */ - -} - -bye () { - /* Force my personal prejudices upon the poor luser */ - - esc("<"); /* Enter ANSI mode (if in VT52 mode) */ - rm("?1"); /* cursor keys normal */ - rm("?3"); /* 80 col mode */ - rm("?5"); /* Normal screen */ - rm("?6"); /* Absolute origin mode */ - sm("?7"); /* Wrap around on */ - sm("?8"); /* Auto repeat on */ - decstbm(0,0); /* No scroll region */ - sgr("0"); /* Normal character attributes */ - - /* Say goodbye */ - - ed(2); - cup(12,30); - printf("That's all, folks!\n"); - printf("\n\n\n"); - inflush(); -#ifdef SARG20 - ttybin(0); /* reset line to normal mode */ -#endif -#ifdef UNIX -# ifndef BSD4_4 - stty(0,&ttyOrg); -# else - tcsetattr(0, TCSADRAIN, &ttyOrg); -# endif -#endif - exit(); -} - -#ifdef UNIX -onbrk() { - signal(SIGINT, (void (*) __P((int))) onbrk); - if (reading) - brkrd = 1; - else - longjmp(intrenv, 1); -} - -onterm() { - signal(SIGTERM, (void (*) __P((int))) onterm); - longjmp(intrenv, 1); -} -#endif - -holdit() { - inflush(); - printf("Push "); - readnl(); -} - -readnl() { -#ifdef UNIX - char ch; - fflush(stdout); - brkrd = 0; - reading = 1; - do { read(0,&ch,1); } while(ch != '\n' && !brkrd); - if (brkrd) - kill(getpid(), SIGTERM); - reading = 0; -#endif -#ifdef SARG10 - while (getchar() != '\n') - ; -#endif -#ifdef SARG20 - while (getchar() != '\n') - ; -#endif -} - -scanto(str, pos, toc) char *str; int *pos; char toc; { - char c; - int result = 0; - - while (toc != (c = str[(*pos)++])) { - if (isdigit(c)) result = result * 10 + c - '0'; - else break; - } - if (c == toc) return(result); - else return(0); -} - -char *lookup(t, k) struct table t[]; int k; { - - int i; - for (i = 0; t[i].key != -1; i++) { - if (t[i].key == k) return(t[i].msg); - } - return("BAD VALUE"); -} - -menu(table) char *table[]; { - - int i, tablesize, choice; - char c; - char storage[80]; - char *s = storage; - println(""); - tablesize = 0; - for (i = 0; *table[i] != '\0'; i++) { - printf(" %d. %s\n", i, table[i]); - tablesize++; - } - tablesize--; - - printf("\n Enter choice number (0 - %d): ", tablesize); - for(;;) { - inputline(s); - choice = 0; - while (c = *s++) choice = 10 * choice + c - '0'; - if (choice >= 0 && choice <= tablesize) { - ed(2); - return (choice); - } - printf(" Bad choice, try again: "); - } -} - -chrprint (s) char *s; { - - int i; - - printf(" "); - sgr("7"); - printf(" "); - for (i = 0; s[i] != '\0'; i++) { - if (s[i] <= ' ' || s[i] == '\177') - printf("<%d> ", s[i]); - else printf("%c ", s[i]); - } - sgr(""); -} diff --git a/sys/arch/i386/isa/pcvt/pcvt_conf.h b/sys/arch/i386/isa/pcvt/pcvt_conf.h deleted file mode 100644 index 3903b6a97706..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_conf.h +++ /dev/null @@ -1,385 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1994 Brian Dunford-Shore. - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis, Brian Dunford-Shore and Joerg Wunsch. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_conf.h, 3.32, Last Edit-Date: [Tue Oct 3 11:19:47 1995] - * - */ - -/*--------------------------------------------------------------------------- - * - * pcvt_conf.h VT220 driver global configuration file - * ------------------------------------------------------ - * -hm introduced pcvt_conf.h - * -hm re-integrated selfconfiguration for NetBSD from Onno - * -hm patch from Onno for NetBSD-current - * -hm removed PCVT_FAKE_SYSCONS10 - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Ulf Kieber to support changeable kernel msg colors - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -/*--------------------------------------------------------------------------- - * Note that each of the options below should rather be overriden by the - * kernel config file instead of this .h file - this allows for different - * definitions in different kernels compiled at the same machine - * - * The convention is as follows: - * - * options "PCVT_FOO=1" - enables the option - * options "PCVT_FOO" - is a synonym for the above - * options "PCVT_FOO=0" - disables the option - * - * omitting an option defaults to what is shown below - * - * exceptions from this rule are i.e.: - * - * options "PCVT_NSCREENS=x" - * options "PCVT_SCANSET=x" - * options "PCVT_SYSBEEPF=x" - * - * which are always numeric! - *---------------------------------------------------------------------------*/ - -/* -------------------------------------------------------------------- */ -/* ---------------- USER PREFERENCE DRIVER OPTIONS -------------------- */ -/* -------------------------------------------------------------------- */ - -/*----------------------------------------------------------------------*/ -/* NOTE: if FAT_CURSOR is defined, a block cursor is used instead of */ -/* the cursor shape we got from the BIOS, see pcvt_out.c */ -/*----------------------------------------------------------------------*/ - -#if !defined PCVT_NSCREENS /* ---------- DEFAULT: 8 -------------- */ -# define PCVT_NSCREENS 8 /* this option defines how many virtual */ -#endif /* screens you want to have in your */ - /* system. each screen allocates memory,*/ - /* so you can't have an unlimited num- */ - /* ber...; the value is intented to be */ - /* compile-time overridable by a config */ - /* options "PCVT_NSCREENS=x" line */ - -#if !defined PCVT_VT220KEYB /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_VT220KEYB 0 /* this compiles a more vt220-like */ -#elif PCVT_VT220KEYB != 0 /* keyboardlayout as described in the */ -# undef PCVT_VT220KEYB /* file Keyboard.VT220. */ -# define PCVT_VT220KEYB 1 /* if undefined, a more HP-like */ -#endif /* keyboardlayout is compiled */ - /* try to find out what YOU like ! */ - -#if !defined PCVT_SCREENSAVER /* ---------- DEFAULT: ON ------------- */ -# define PCVT_SCREENSAVER 1 /* enable screen saver feature - this */ -#elif PCVT_SCREENSAVER != 0 /* just blanks the display screen. */ -# undef PCVT_SCREENSAVER /* see PCVT_PRETTYSCRNS below ... */ -# define PCVT_SCREENSAVER 1 -#endif - -#if !defined PCVT_PRETTYSCRNS /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_PRETTYSCRNS 0 /* for the cost of some microseconds of */ -#elif PCVT_PRETTYSCRNS != 0 /* cpu time this adds a more "pretty" */ -# undef PCVT_PRETTYSCRNS /* version to the screensaver, an "*" */ -# define PCVT_PRETTYSCRNS 1 /* in random locations of the display. */ -#endif /* NOTE: this should not be defined if */ - /* you have an energy-saving monitor */ - /* which turns off the display if its */ - /* black !!!!!! */ - -#if !defined PCVT_CTRL_ALT_DEL /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_CTRL_ALT_DEL 0 /* this enables the execution of a cpu */ -#elif PCVT_CTRL_ALT_DEL != 0 /* reset by pressing the CTRL, ALT and */ -# undef PCVT_CTRL_ALT_DEL /* DEL keys simultanously. Because this */ -# define PCVT_CTRL_ALT_DEL 1 /* is a feature of an ancient simple */ -#endif /* bootstrap loader, it does not belong */ - /* into modern operating systems and */ - /* was commented out by default ... */ - -#if !defined PCVT_KBD_FIFO /* ---------- DEFAULT: ON ------------- */ -# define PCVT_KBD_FIFO 1 /* this enables Keyboad fifo so that we */ -#elif PCVT_KBD_FIFO != 0 /* are not any longer forced to switch */ -# undef PCVT_KBD_FIFO /* off tty interrupts while switching */ -# define PCVT_KBD_FIFO 1 /* virtual screens - AND loosing chars */ -#endif /* on the serial lines is gone :-) */ - -#if PCVT_KBD_FIFO - -# if !defined PCVT_KBD_FIFO_SZ /* ---------- DEFAULT: 256 ------------ */ -# define PCVT_KBD_FIFO_SZ 256 /* this specifies the size of the above */ -# elif PCVT_KBD_FIFO_SZ < 16 /* mentioned keyboard buffer. buffer */ -# undef PCVT_KBD_FIFO_SZ /* overflows are logged via syslog, so */ -# define PCVT_KBD_FIFO_SZ 256 /* have a look at /var/log/messages */ -# endif - -#endif /* PCVT_KBD_FIFO */ - -#if !defined PCVT_USEKBDSEC /* ---------- DEFAULT: ON ------------- */ -# define PCVT_USEKBDSEC 1 /* do not set the COMMAND_INHOVR bit */ -#elif PCVT_USEKBDSEC != 0 /* (1 = override security lock inhibit) */ -# undef PCVT_USEKBDSEC /* when initializing the keyboard, so */ -# define PCVT_USEKBDSEC 1 /* that security locking should work */ -#endif /* now. I guess this has to be done also*/ - /* in the boot code to prevent single */ - /* user startup .... */ - -#if !defined PCVT_24LINESDEF /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_24LINESDEF 0 /* use 24 lines in VT 25 lines mode and */ -#elif PCVT_24LINESDEF != 0 /* HP 28 lines mode by default to have */ -# undef PCVT_24LINESDEF /* the the better compatibility to the */ -# define PCVT_24LINESDEF 1 /* real VT220 - you can switch between */ -#endif /* the maximum possible screensizes in */ - /* those two modes (25 lines) and true */ - /* compatibility (24 lines) by using */ - /* the scon utility at runtime */ - -#if !defined PCVT_EMU_MOUSE /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_EMU_MOUSE 0 /* emulate a mouse systems mouse via */ -#elif PCVT_EMU_MOUSE != 0 /* the keypad; this is experimental */ -# undef PCVT_EMU_MOUSE /* code intented to be used on note- */ -# define PCVT_EMU_MOUSE 1 /* books in conjunction with XFree86; */ -#endif /* look at the comments in pcvt_kbd.c */ - /* if you are interested in testing it. */ - -#if !defined PCVT_META_ESC /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_META_ESC 0 /* if ON, send the sequence "ESC key" */ -#elif PCVT_META_ESC != 0 /* for a meta-shifted key; if OFF, */ -# undef PCVT_META_ESC /* send the normal key code with 0x80 */ -# define PCVT_META_ESC 1 /* added. */ -#endif - -#if !defined PCVT_SW0CNOUTP /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_SW0CNOUTP 0 /* if ON, on console/kernel output the */ -#elif PCVT_SW0CNOUTP != 0 /* current screen is switched to screen */ -# undef PCVT_SW0CNOUTP /* 0 if not already at screen 0. */ -# define PCVT_SW0CNOUTP 1 /* CAUTION: CURRENTLY THIS CAUSES AN X- */ -#endif /* SESSION TO CLUTTER VIDEO MEMORY !!!! */ - -/* -------------------------------------------------------------------- */ -/* -------------------- DRIVER DEBUGGING ------------------------------ */ -/* -------------------------------------------------------------------- */ - -#if !defined PCVT_SHOWKEYS /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_SHOWKEYS 0 /* this replaces the system load line */ -#elif PCVT_SHOWKEYS != 0 /* on the vt 0 in hp mode with a display*/ -# undef PCVT_SHOWKEYS /* of the most recent keyboard scan- */ -# define PCVT_SHOWKEYS 1 /* and status codes received from the */ -#endif /* keyboard controller chip. */ - /* this is just for some hardcore */ - /* keyboarders .... */ - -/* -------------------------------------------------------------------- */ -/* -------------------- DRIVER OPTIONS -------------------------------- */ -/* -------------------------------------------------------------------- */ -/* it is unlikely that anybody wants to change anything below */ - -#if !defined PCVT_NO_LED_UPDATE /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_NO_LED_UPDATE 0 /* On some (Notebook?) keyboards it is */ -#elif PCVT_NO_LED_UPDATE != 0 /* not possible to update the LED's */ -# undef PCVT_NO_LED_UPDATE /* without hanging the keyboard after- */ -# define PCVT_NO_LED_UPDATE 1 /* wards. If you experience Problems */ -#endif /* like this, try to enable this option */ - -#if !defined PCVT_PORTIO_DELAY /* ---------- DEFAULT: ON ------------- */ -# define PCVT_PORTIO_DELAY 1 /* Defining PCVT_PORTIO_DELAY lets pcvt */ -#elif PCVT_PORTIO_DELAY != 0 /* use multiple accesses to port 0x84 */ -# undef PCVT_PORTIO_DELAY /* to produce a delay of 7 us needed for*/ -# define PCVT_PORTIO_DELAY 1 /* accessing the keyboard controller, */ -#endif /* otherwise the system delay functions */ - /* are used. */ - -#if !defined PCVT_PCBURST /* ---------- DEFAULT: 256 ------------ */ -# define PCVT_PCBURST 256 /* NETBSD and FreeBSD >= 2.0 only: this */ -#endif /* is the number of output characters */ - /* handled together as a burst in */ - /* routine pcstart(), file pcvt_drv.c */ - -#if !defined PCVT_SCANSET /* ---------- DEFAULT: 1 -------------- */ -# define PCVT_SCANSET 1 /* define the keyboard scancode set you */ -#endif /* want to use: */ - /* 1 - code set 1 (supported) */ - /* 2 - code set 2 (supported) */ - /* 3 - code set 3 (UNsupported) */ - -#if !defined PCVT_KEYBDID /* ---------- DEFAULT: ON ------------- */ -# define PCVT_KEYBDID 1 /* check type of keyboard connected. at */ -#elif PCVT_KEYBDID != 0 /* least HP-keyboards send an id other */ -# undef PCVT_KEYBDID /* than the industry standard, so it */ -# define PCVT_KEYBDID 1 /* CAN lead to problems. if you have */ -#endif /* problems with this, TELL ME PLEASE ! */ - -#if !defined PCVT_SIGWINCH /* ---------- DEFAULT: ON ------------- */ -# define PCVT_SIGWINCH 1 /* this sends a SIGWINCH signal in case */ -#elif PCVT_SIGWINCH != 0 /* the window size is changed. to try, */ -# undef PCVT_SIGWINCH /* issue "scons -s" while in elvis*/ -# define PCVT_SIGWINCH 1 /* and you'll see the effect. */ -#endif /* i'm not sure, whether this feature */ - /* has to be in the driver or has to */ - /* move as an ioctl call to scon .... */ - -#if !defined PCVT_NULLCHARS /* ---------- DEFAULT: ON ------------- */ -# define PCVT_NULLCHARS 1 /* allow the keyboard to send null */ -#elif PCVT_NULLCHARS != 0 /* (0x00) characters to the calling */ -# undef PCVT_NULLCHARS /* program. this has the side effect */ -# define PCVT_NULLCHARS 1 /* that every undefined key also sends */ -#endif /* out nulls. take it as experimental */ - /* code, this behaviour will change in */ - /* a future release */ - -#if !defined PCVT_BACKUP_FONTS /* ---------- DEFAULT: ON ------------- */ -# define PCVT_BACKUP_FONTS 1 /* fonts are always kept memory-backed; */ -#elif PCVT_BACKUP_FONTS != 0 /* otherwise copies are only made if */ -# undef PCVT_BACKUP_FONTS /* they are needed. */ -# define PCVT_BACKUP_FONTS 1 -#endif - -#ifndef PCVT_SYSBEEPF /* timer chip value to be used for the */ -# define PCVT_SYSBEEPF 1193182 /* sysbeep frequency value. */ -#endif /* this should really go somewhere else,*/ - /* e.g. in isa.h; but it used to be in */ - /* each driver, sometimes even with */ - /* different values (:-) */ - -#if !defined PCVT_SETCOLOR /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_SETCOLOR 0 /* enable making colors settable. this */ -#elif PCVT_SETCOLOR != 0 /* introduces a new escape sequence */ -# undef PCVT_SETCOLOR /* which is (i think) not */ -# define PCVT_SETCOLOR 1 /* standardized, so this is an option */ -#endif /* (Birthday present for Bruce ! :-) */ - -#if !defined PCVT_132GENERIC /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_132GENERIC 0 /* if you #define this, you enable */ -#elif PCVT_132GENERIC != 0 /* EXPERIMENTAL (!!!!!!!!!!!!) */ -# undef PCVT_132GENERIC /* USE-AT-YOUR-OWN-RISK, */ -# define PCVT_132GENERIC 1 /* MAY-DAMAGE-YOUR-MONITOR */ -#endif /* code to switch generic VGA boards/ */ - /* chipsets to 132 column mode. Since */ - /* i could not verify this option, i */ - /* prefer to NOT generally enable this, */ - /* if you want to play, look at the */ - /* hints and the code in pcvt_sup.c and */ - /* get in contact with Joerg Wunsch, who*/ - /* submitted this code. Be careful !!! */ - -#if !defined PCVT_PALFLICKER /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_PALFLICKER 0 /* this option turns off the screen */ -#elif PCVT_PALFLICKER != 0 /* during accesses to the VGA DAC */ -# undef PCVT_PALFLICKER /* registers. why: on one fo the tested */ -# define PCVT_PALFLICKER 1 /* pc's (WD-chipset), accesses to the */ -#endif /* vga dac registers caused distortions */ - /* on the screen. Ferraro says, one has */ - /* to blank the screen. the method used */ - /* to accomplish this stopped the noise */ - /* but introduced another flicker, so */ - /* this is for you to experiment ..... */ - /* - see also PCVT_WAITRETRACE below -- */ - -#if !defined PCVT_WAITRETRACE /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_WAITRETRACE 0 /* this option waits for being in a */ -#elif PCVT_WAITRETRACE != 0 /* retrace window prior to accessing */ -# undef PCVT_WAITRETRACE /* the VGA DAC registers. */ -# define PCVT_WAITRETRACE 1 /* this is the other method Ferraro */ -#endif /* mentioned in his book. this option */ - /* did eleminate the flicker noticably */ - /* but not completely. besides that, it */ - /* is implemented as a busy-wait loop */ - /* which is a no-no-no in environments */ - /* like this - VERY BAD PRACTICE !!!!! */ - /* the other method implementing it is */ - /* using the vertical retrace irq, but */ - /* we get short of irq-lines on pc's. */ - /* this is for you to experiment ..... */ - /* -- see also PCVT_PALFLICKER above -- */ - -#if !defined PCVT_INHIBIT_NUMLOCK /* --------- DEFAULT: OFF ----------- */ -# define PCVT_INHIBIT_NUMLOCK 0 /* A notebook hack: since i am getting */ -#elif PCVT_INHIBIT_NUMLOCK != 0 /* tired of the numlock LED always */ -# undef PCVT_INHIBIT_NUMLOCK /* being turned on - which causes the */ -# define PCVT_INHIBIT_NUMLOCK 1 /* right half of my keyboard being */ -#endif /* interpreted as a numeric keypad and */ - /* thus going unusable - i want to */ - /* have a better control over it. If */ - /* this option is enabled, only the */ - /* numlock key itself and the related */ - /* ioctls will modify the numlock */ - /* LED. (The ioctl is needed for the */ - /* ServerNumLock feature of XFree86.) */ - /* The default state is changed to */ - /* numlock off, and the escape */ - /* sequences to switch between numeric */ - /* and application mode keypad are */ - /* silently ignored. */ - -#if !defined PCVT_NOFASTSCROLL /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_NOFASTSCROLL 0 /* If off, enables code for fast scroll.*/ -#elif PCVT_NOFASTSCROLL != 0 /* This is done by changing the CRTC */ -# undef PCVT_NOFASTSCROLL /* screen start address for scrolling */ -# define PCVT_NOFASTSCROLL 1 /* and using 2 times the screen size as */ -#endif /* buffer. The fastscroll code works */ - /* ONLY for VGA/EGA/CGA because it uses */ - /* the crtc for hardware scrolling and */ - /* therefore needs more than the one */ - /* page video memory MDA and most */ - /* Hercules boards support. */ - /* If you run pcvt ONLY on MDA/Hercules */ - /* you should disable fastscroll to save*/ - /* the time to decide which board you */ - /* are running pcvt on at runtime. */ - /* [see roll_up() and roll_down().] */ - -#if !defined PCVT_MDAFASTSCROLL /* ---------- DEFAULT: OFF ------------ */ -# define PCVT_MDAFASTSCROLL 0 /* If on, enables code for fast scroll */ -#elif PCVT_MDAFASTSCROLL != 0 /* on MDA/Hercules (see notes for */ -# undef PCVT_MDAFASTSCROLL /* PCVT_NOFASTSCROLL). Works only on */ -# define PCVT_MDAFASTSCROLL 1 /* MDA/Hercules which do support more */ -#endif /* than one page of video memory. */ - -/*---------------------------------------------------------------------------* - * Kernel messages attribute definitions - * These define the foreground and background attributes used to - * emphasize messages from the kernel on color and mono displays. - *---------------------------------------------------------------------------*/ - -#if !defined COLOR_KERNEL_FG /* color displays */ -#define COLOR_KERNEL_FG FG_LIGHTGREY /* kernel messages, foreground */ -#endif -#if !defined COLOR_KERNEL_BG -#define COLOR_KERNEL_BG BG_RED /* kernel messages, background */ -#endif - -#if !defined MONO_KERNEL_FG /* monochrome displays */ -#define MONO_KERNEL_FG FG_UNDERLINE /* kernel messages, foreground */ -#endif -#if !defined MONO_KERNEL_BG -#define MONO_KERNEL_BG BG_BLACK /* kernel messages, background */ -#endif - -/*---------------------------------- E O F ----------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/pcvt_cons.h b/sys/arch/i386/isa/pcvt/pcvt_cons.h deleted file mode 100644 index d79ee2662ec9..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_cons.h +++ /dev/null @@ -1 +0,0 @@ -int pccnattach __P((void)); diff --git a/sys/arch/i386/isa/pcvt/pcvt_drv.c b/sys/arch/i386/isa/pcvt/pcvt_drv.c deleted file mode 100644 index 7eb7283a7473..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_drv.c +++ /dev/null @@ -1,936 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore and Scott Turner. - * - * Copyright (c) 1993 Charles M. Hannum. - * - * All rights reserved. - * - * Parts of this code regarding the NetBSD interface were written - * by Charles M. Hannum. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz and Don Ahn. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis, Brian Dunford-Shore, Joerg Wunsch, Scott Turner - * and Charles M. Hannum. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_drv.c, 3.32, Last Edit-Date: [Tue Oct 3 11:19:47 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_drv.c VT220 Driver Main Module / OS - Interface - * --------------------------------------------------------- - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -hm adding ttrstrt() proto for NetBSD 0.9 - * -hm kernel/console output cursor positioning fixed - * -hm kernel/console output switches optional to screen 0 - * -hm FreeBSD 1.1 porting - * -hm the NetBSD 0.9 compiler detected a nondeclared var which was - * NOT detected by neither the NetBSD-current nor FreeBSD 1.x! - * -hm including Michael's keyboard fifo code - * -hm Joergs patch for FreeBSD tty-malloc code - * -hm adjustments for NetBSD-current - * -hm FreeBSD bugfix from Joerg re timeout/untimeout casts - * -jw including Thomas Gellekum's FreeBSD 1.1.5 patch - * -hm adjusting #if's for NetBSD-current - * -hm applying Joerg's patch for FreeBSD 2.0 - * -hm patch from Onno & Martin for NetBSD-current (post 1.0) - * -hm some adjustments for NetBSD 1.0 - * -hm NetBSD PR #400: screen size report for new session - * -hm patch from Rafael Boni/Lon Willett for NetBSD-current - * -hm bell patch from Thomas Eberhardt for NetBSD - * -hm multiple X server bugfixes from Lon Willett - * -hm patch from joerg - pcdevtotty for FreeBSD pre-2.1 - * -hm delay patch from Martin Husemann after port-i386 ml-discussion - * -jw add some code to provide more FreeBSD pre-2.1 support - * -hm patches from Michael for NetBSD-current (Apr/21/95) support - * -hm merged in changes from FreeBSD 2.0.5-RELEASE - * -hm NetBSD-current patches from John Kohl - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Joerg in pcopen() to make mouse emulator work again - * -hm patch from Frank van der Linden for keyboard state per VT - * -hm no TS_ASLEEP anymore in FreeBSD 2.1.0 SNAP 950928 - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#define EXTERN /* allocate mem */ -#include "pcvt_hdr.h" /* global include */ -#include "pcvt_cons.h" /* NetBSD only */ - -/* consistency check: pcvt can't coexist with pckbc, vga or pcdisplay */ -#include "pckbc.h" -#include "vga.h" -#include "pcdisplay.h" -#if (NPCKBC > 0) || (NVGA > 0) || (NPCDISPLAY > 0) -#error "pcvt and (pckbc or vga or pcdisplay) can't coexist" -#endif - -#ifdef NOTDEF -unsigned __debug = 0; /*0xffe */; -static __color; -static nrow; -#endif - -static void vgapelinit(void); /* read initial VGA DAC palette */ -int getchar(void); - -void pccnpollc(Dev_t, int); -int pcprobe(struct device *, struct cfdata *, void *); -void pcattach(struct device *, struct device *, void *); - - -int -pcprobe(struct device *parent, struct cfdata *match, void *aux) -{ - kbd_code_init(); - - ((struct isa_attach_args *)aux)->ia_iosize = 16; - return 1; - -} - -void -pcattach(struct device *parent, struct device *self, void *aux) -{ - struct isa_attach_args *ia = aux; - - struct vt_softc *sc = (void *) self; - - - int i; - - if(do_initialization) - vt_coldinit(); - - vt_coldmalloc(); /* allocate memory for screens */ - - printf("\n%s: ", self->dv_xname); - - switch(adaptor_type) - { - case MDA_ADAPTOR: - printf("mda"); - break; - - case CGA_ADAPTOR: - printf("cga"); - break; - - case EGA_ADAPTOR: - printf("ega"); - break; - - case VGA_ADAPTOR: - printf("%s, ", (char *)vga_string(vga_type)); - if(can_do_132col) - printf("80/132 col"); - else - printf("80 col"); - vgapelinit(); - break; - - default: - printf("unknown"); - break; - } - - if(color == 0) - printf(", mono"); - else - printf(", color"); - - printf(", %d scr, ", totalscreens); - - switch(keyboard_type) - { - case KB_AT: - printf("at-"); - break; - - case KB_MFII: - printf("mf2-"); - break; - - default: - printf("unknown "); - break; - } - - printf("kbd, [R%s]\n", PCVT_REL); - - - for(i = 0; i < totalscreens; i++) - { - - vs[i].vs_tty = ttymalloc(); - tty_attach(vs[i].vs_tty); - - } - -#if PCVT_EMU_MOUSE - pc_tty[totalscreens] = ttymalloc(); /* the mouse emulator tty */ -#endif /* PCVT_EMU_MOUSE */ - - pcconsp = vs[0].vs_tty; - - - - - async_update(); - - - sc->sc_ih = isa_intr_establish(ia->ia_ic, ia->ia_irq, IST_EDGE, - IPL_TTY, pcintr, (void *)0); - - /* - * Look for children of the keyboard controller. - * XXX Really should decouple keyboard controller - * from the console code. - */ - while (config_found(self, ia->ia_ic, NULL) != NULL) - /* will break when no more children */ ; - - if(pcvt_is_console) { - int maj; - - /* locate the major number */ - for (maj = 0; maj < nchrdev; maj++) - if (cdevsw[maj].d_open == pcopen) - break; - - cn_tab->cn_dev = makedev(maj, 0); - /* minor number selects virtual screen, - console always uses "0" (hardwired at - various places) */ - - printf("%s: console\n", sc->sc_dev.dv_xname); - } -} - -/* had a look at the friedl driver */ - -struct tty * -get_pccons(Dev_t dev) -{ - register int i = minor(dev); - -#if PCVT_EMU_MOUSE - if(i == totalscreens) - return(pc_tty[i]); -#endif /* PCVT_EMU_MOUSE */ - - if(i >= PCVT_NSCREENS) - return(NULL); - - return(vs[i].vs_tty); -} - - -/*---------------------------------------------------------------------------* - * /dev/ttyc0, /dev/ttyc1, etc. - *---------------------------------------------------------------------------*/ -int -pcopen(Dev_t dev, int flag, int mode, struct proc *p) -{ - register struct tty *tp; - register struct video_state *vsx; - int s, retval; - int winsz = 0; - int i = minor(dev); - -#if PCVT_EMU_MOUSE - if(i == totalscreens) - vsx = 0; - else -#endif /* PCVT_EMU_MOUSE */ - - vsx = &vs[i]; - - if((tp = get_pccons(dev)) == NULL) - return ENXIO; - -#if PCVT_EMU_MOUSE - if(i == totalscreens) - { - if(mouse.opened == 0) - mouse.buttons = mouse.extendedseen = - mouse.breakseen = mouse.lastmove.tv_sec = 0; - mouse.minor = i; - mouse.opened++; - } - else -#endif /* PCVT_EMU_MOUSE */ - - vsx->openf++; - - tp->t_oproc = pcstart; - tp->t_param = pcparam; - tp->t_dev = dev; - - if ((tp->t_state & TS_ISOPEN) == 0) - { - ttychars(tp); - tp->t_iflag = TTYDEF_IFLAG; - tp->t_oflag = TTYDEF_OFLAG; - tp->t_cflag = TTYDEF_CFLAG; - tp->t_lflag = TTYDEF_LFLAG; - tp->t_ispeed = tp->t_ospeed = TTYDEF_SPEED; - pcparam(tp, &tp->t_termios); - ttsetwater(tp); - } - else if (tp->t_state & TS_XCLUDE && p->p_ucred->cr_uid != 0) - return (EBUSY); - - tp->t_state |= TS_CARR_ON; - tp->t_cflag |= CLOCAL; /* cannot be a modem (:-) */ - - if ((tp->t_state & TS_ISOPEN) == 0) /* is this a "cold" open ? */ - winsz = 1; /* yes, set winsize later */ - - retval = ((*linesw[tp->t_line].l_open)(dev, tp)); - - if(winsz == 1 -#if PCVT_EMU_MOUSE - && vsx /* the mouse device has no vsx */ -#endif /* PCVT_EMU_MOUSE */ - ) - { - - /* - * The line discipline has clobbered t_winsize if TS_ISOPEN - * was clear. (NetBSD PR #400 from Bill Sommerfeld) - * We have to do this after calling the open routine, because - * it does some other things in other/older *BSD releases -hm - */ - - s = spltty(); - - tp->t_winsize.ws_col = vsx->maxcol; - tp->t_winsize.ws_row = vsx->screen_rows; - tp->t_winsize.ws_xpixel = (vsx->maxcol == 80)? 720: 1056; - tp->t_winsize.ws_ypixel = 400; - - splx(s); - } - - return(retval); -} - -int -pcclose(Dev_t dev, int flag, int mode, struct proc *p) -{ - register struct tty *tp; - register struct video_state *vsx; - int i = minor(dev); - -#if PCVT_EMU_MOUSE - if(i == totalscreens) - vsx = 0; - else -#endif /* PCVT_EMU_MOUSE */ - - vsx = &vs[i]; - - if((tp = get_pccons(dev)) == NULL) - return ENXIO; - - (*linesw[tp->t_line].l_close)(tp, flag); - ttyclose(tp); - -#if PCVT_EMU_MOUSE - if(i == totalscreens) - mouse.opened = 0; - else -#endif /* PCVT_EMU_MOUSE */ - - vsx->openf = 0; - -#if PCVT_EMU_MOUSE - - if(i == totalscreens) - return (0); - -#endif /* PCVT_EMU_MOUSE */ - - reset_usl_modes(vsx); - - return(0); -} - -int -pcread(Dev_t dev, struct uio *uio, int flag) -{ - register struct tty *tp; - - if((tp = get_pccons(dev)) == NULL) - return ENXIO; - - return ((*linesw[tp->t_line].l_read)(tp, uio, flag)); -} - -int -pcwrite(Dev_t dev, struct uio *uio, int flag) -{ - register struct tty *tp; - - if((tp = get_pccons(dev)) == NULL) - return ENXIO; - - return ((*linesw[tp->t_line].l_write)(tp, uio, flag)); -} - -struct tty * -pctty(Dev_t dev) -{ - register struct tty *tp; - - if((tp = get_pccons(dev)) == NULL) - return 0; - - return tp; -} - -int -pcioctl(Dev_t dev, int cmd, caddr_t data, int flag, struct proc *p) -{ - register int error; - register struct tty *tp; - - if((tp = get_pccons(dev)) == NULL) - return(ENXIO); - - /* note that some ioctl's are global, e.g. KBSTPMAT: There is - * only one keyboard and different repeat rates for instance between - * sessions are a suspicious wish. If you really need this make the - * appropriate variables arrays - */ - -#if PCVT_EMU_MOUSE - if(minor(dev) == totalscreens) - { - if((error = mouse_ioctl(dev, cmd, data)) >= 0) - return error; - goto do_standard; - } -#endif /* PCVT_EMU_MOUSE */ - - - if((error = usl_vt_ioctl(dev, cmd, data, flag, p)) >= 0) - return (error == PCVT_ERESTART) ? ERESTART : error; - -#ifdef XSERVER - /* - * just for compatibility: - * XFree86 < 2.0 and SuperProbe still might use it - * - * NB: THIS IS A HACK! Do not use it unless you explicitly need. - * Especially, since the vty is not put into process-controlled - * mode (this would require the application to co-operate), any - * attempts to switch vtys while this kind of X mode is active - * may cause serious trouble. - */ - switch(cmd) - { - case CONSOLE_X_MODE_ON: - { - int i; - - if((error = usl_vt_ioctl(dev, KDENABIO, 0, flag, p)) > 0) - return error; - - i = KD_GRAPHICS; - if((error = usl_vt_ioctl(dev, KDSETMODE, (caddr_t)&i, flag, p)) - > 0) - return error; - - i = K_RAW; - error = usl_vt_ioctl(dev, KDSKBMODE, (caddr_t)&i, flag, p); - return error; - } - - case CONSOLE_X_MODE_OFF: - { - int i; - - (void)usl_vt_ioctl(dev, KDDISABIO, 0, flag, p); - - i = KD_TEXT; - (void)usl_vt_ioctl(dev, KDSETMODE, (caddr_t)&i, flag, p); - - i = K_XLATE; - (void)usl_vt_ioctl(dev, KDSKBMODE, (caddr_t)&i, flag, p); - return 0; - } - - - case CONSOLE_X_BELL: - - /* - * If `data' is non-null, the first int value denotes - * the pitch, the second a duration. Otherwise, behaves - * like BEL. - */ - - if (data) - { - - sysbeep(((int *)data)[0], - ((int *)data)[1] * hz / 1000); - - } - else - { - sysbeep(PCVT_SYSBEEPF / 1493, hz / 4); - } - return (0); - - default: /* fall through */ ; - } - -#endif /* XSERVER */ - - if((error = kbdioctl(dev,cmd,data,flag)) >= 0) - return error; - - if((error = vgaioctl(dev,cmd,data,flag)) >= 0) - return error; - -#if PCVT_EMU_MOUSE -do_standard: -#endif /* PCVT_EMU_MOUSE */ - - if((error = (*linesw[tp->t_line].l_ioctl)(tp, cmd, data, flag, p)) >= 0) - return (error); - - if((error = ttioctl(tp, cmd, data, flag, p)) >= 0) - return (error); - - return (ENOTTY); -} - -int -pcmmap(Dev_t dev, int offset, int nprot) -{ - if ((u_int)offset >= 0x20000) - return -1; - return i386_btop((0xa0000 + offset)); -} - - -/*---------------------------------------------------------------------------* - * - * handle a keyboard receive interrupt - * - * NOTE: the keyboard is multiplexed by means of "pcconsp" - * between virtual screens. pcconsp - switching is done in - * the vgapage() routine - * - *---------------------------------------------------------------------------*/ - -#if PCVT_KBD_FIFO - -u_char pcvt_kbd_fifo[PCVT_KBD_FIFO_SZ]; -int pcvt_kbd_wptr = 0; -int pcvt_kbd_rptr = 0; -short pcvt_kbd_count= 0; -static u_char pcvt_timeout_scheduled = 0; -static struct callout pcvt_timeout_ch = CALLOUT_INITIALIZER; - -static void pcvt_timeout (void *arg) -{ - u_char *cp; - int s; - - pcvt_timeout_scheduled = 0; - -#if PCVT_SCREENSAVER - pcvt_scrnsv_reset(); -#endif /* PCVT_SCREENSAVER */ - - while (pcvt_kbd_count) - { - if (((cp = sgetc(1)) != 0) && - (vs[current_video_screen].openf)) - { - -#if PCVT_NULLCHARS - if(*cp == '\0') - { - /* pass a NULL character */ - (*linesw[pcconsp->t_line].l_rint)('\0', pcconsp); - } -/* XXX */ else -#endif /* PCVT_NULLCHARS */ - - while (*cp) - (*linesw[pcconsp->t_line].l_rint)(*cp++ & 0xff, pcconsp); - } - - s = spltty(); - - if (!pcvt_kbd_count) - pcvt_timeout_scheduled = 0; - - splx(s); - } - - return; -} -#endif - -int -pcintr(void *arg) -{ - -#if PCVT_KBD_FIFO - u_char dt; - u_char ret = -1; - int s; - -#else /* !PCVT_KBD_FIFO */ - u_char *cp; -#endif /* PCVT_KBD_FIFO */ - -#if PCVT_SCREENSAVER - pcvt_scrnsv_reset(); -#endif /* PCVT_SCREENSAVER */ - -#if PCVT_KBD_FIFO - if (kbd_polling) - { - if(sgetc(1) == 0) - return -1; - else - return 1; - } - - while (inb(CONTROLLER_CTRL) & STATUS_OUTPBF) /* check 8042 buffer */ - { - ret = 1; /* got something */ - - PCVT_KBD_DELAY(); /* 7 us delay */ - - dt = inb(CONTROLLER_DATA); /* get it 8042 data */ - - if (pcvt_kbd_count >= PCVT_KBD_FIFO_SZ) /* fifo overflow ? */ - { - log (LOG_WARNING, "pcvt: keyboard buffer overflow\n"); - } - else - { - pcvt_kbd_fifo[pcvt_kbd_wptr++] = dt; /* data -> fifo */ - - s = spltty(); /* XXX necessary ? */ - pcvt_kbd_count++; /* update fifo count */ - splx(s); - - if (pcvt_kbd_wptr >= PCVT_KBD_FIFO_SZ) - pcvt_kbd_wptr = 0; /* wraparound pointer */ - } - } - - if (ret == 1) /* got data from keyboard ? */ - { - if (!pcvt_timeout_scheduled) /* if not already active .. */ - { - s = spltty(); - pcvt_timeout_scheduled = 1; /* flag active */ - callout_reset(&pcvt_timeout_ch, 1, - (TIMEOUT_FUNC_T)pcvt_timeout, NULL); /* fire off */ - splx(s); - } - } - return (ret); - -#else /* !PCVT_KBD_FIFO */ - - if((cp = sgetc(1)) == 0) - return -1; - - if (kbd_polling) - return 1; - - if(!(vs[current_video_screen].openf)) /* XXX was vs[minor(dev)] */ - return 1; - -#if PCVT_NULLCHARS - if(*cp == '\0') - { - /* pass a NULL character */ - (*linesw[pcconsp->t_line].l_rint)('\0', pcconsp); - return 1; - } -#endif /* PCVT_NULLCHARS */ - - while (*cp) - (*linesw[pcconsp->t_line].l_rint)(*cp++ & 0xff, pcconsp); - return 1; - -#endif /* PCVT_KBD_FIFO */ -} - - -void -pcstart(register struct tty *tp) -{ - int s, len; - u_char buf[PCVT_PCBURST]; - - s = spltty(); - - if (tp->t_state & (TS_TIMEOUT|TS_BUSY|TS_TTSTOP)) - goto out; - if (tp->t_outq.c_cc == 0) { - async_update(); - goto low; - } - - tp->t_state |= TS_BUSY; - - splx(s); - - /* - * We need to do this outside spl since it could be fairly - * expensive and we don't want our serial ports to overflow. - */ - - while ((len = q_to_b(&tp->t_outq, buf, PCVT_PCBURST)) != 0) - sput(&buf[0], 0, len, minor(tp->t_dev)); - - s = spltty(); - - tp->t_state &= ~TS_BUSY; - - tp->t_state |= TS_TIMEOUT; - callout_reset(&tp->t_rstrt_ch, 1, ttrstrt, tp); - - if (tp->t_outq.c_cc <= tp->t_lowat) - { -low: - if (tp->t_state&TS_ASLEEP) - { - tp->t_state &= ~TS_ASLEEP; - wakeup((caddr_t)&tp->t_outq); - } - selwakeup(&tp->t_wsel); - } - -out: - splx(s); -} - -void -pcstop(struct tty *tp, int flag) -{ -} - - -/*---------------------------------------------------------------------------* - * /dev/console - *---------------------------------------------------------------------------*/ - - -int -pccnattach() -{ - static struct consdev pccons = { NULL, NULL, - pccngetc, pccnputc, pccnpollc, NULL, NODEV, CN_NORMAL}; - - cn_tab = &pccons; - - pcvt_is_console = 1; - - return(0); -} - -void -pccnputc(Dev_t dev, U_char c) -{ - -#if PCVT_SW0CNOUTP - - if(current_video_screen != 0) - { - switch_screen(0, 0); - } - -#endif /* PCVT_SW0CNOUTP */ - - if (c == '\n') - sput("\r", 1, 1, 0); - - sput((char *) &c, 1, 1, 0); - - async_update(); - -} - -int -pccngetc(Dev_t dev) -{ - register int s; - register u_char *cp; - -#ifdef XSERVER - if (dev != NODEV && vs[minor(dev)].kbd_state == K_RAW) - return 0; -#endif /* XSERVER */ - - s = spltty(); /* block pcrint while we poll */ - cp = sgetc(0); - splx(s); - async_update(); - - /* this belongs to cons.c */ - if (*cp == '\r') - return('\n'); - - return (*cp); -} - -void -pccnpollc(Dev_t dev, int on) -{ - struct vt_softc *sc = NULL; /* XXX not used */ - - kbd_polling = on; - if (!on) { - register int s; - - /* - * If disabling polling, make sure there are no bytes left in - * the FIFO, holding up the interrupt line. Otherwise we - * won't get any further interrupts. - */ - s = spltty(); - - pcintr(sc); - - splx(s); - } -} - -/*---------------------------------------------------------------------------* - * Set line parameters - *---------------------------------------------------------------------------*/ -int -pcparam(struct tty *tp, struct termios *t) -{ - register int cflag = t->c_cflag; - - /* and copy to tty */ - - tp->t_ispeed = t->c_ispeed; - tp->t_ospeed = t->c_ospeed; - tp->t_cflag = cflag; - - return(0); -} - -/* special characters */ -#define bs 8 -#define lf 10 -#define cr 13 -#define cntlc 3 -#define del 0177 -#define cntld 4 - -int -getchar(void) -{ - u_char thechar; - int x; - - kbd_polling = 1; - - x = splhigh(); - - sput(">", 1, 1, 0); - - async_update(); - - thechar = *(sgetc(0)); - - kbd_polling = 0; - - splx(x); - - switch (thechar) - { - default: - if (thechar >= ' ') - sput(&thechar, 1, 1, 0); - return(thechar); - - case cr: - case lf: - sput("\r\n", 1, 2, 0); - return(lf); - - case bs: - case del: - sput("\b \b", 1, 3, 0); - return(thechar); - - case cntlc: - sput("^C\r\n", 1, 4, 0) ; - cpu_reset(); - - case cntld: - sput("^D\r\n", 1, 4, 0) ; - return(0); - } -} - -/*----------------------------------------------------------------------* - * read initial VGA palette (as stored by VGA ROM BIOS) into - * palette save area - *----------------------------------------------------------------------*/ -void -vgapelinit(void) -{ - register unsigned idx; - register struct rgb *val; - - /* first, read all and store to first screen's save buffer */ - for(idx = 0, val = vs[0].palette; idx < NVGAPEL; idx++, val++) - vgapaletteio(idx, val, 0 /* read it */); - - /* now, duplicate for remaining screens */ - for(idx = 1; idx < PCVT_NSCREENS; idx++) - bcopy(vs[0].palette, vs[idx].palette, - NVGAPEL * sizeof(struct rgb)); -} - -/*-------------------------- E O F -------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/pcvt_ext.c b/sys/arch/i386/isa/pcvt/pcvt_ext.c deleted file mode 100644 index 45e93328bd15..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_ext.c +++ /dev/null @@ -1,2847 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (C) 1992, 1993 Soeren Schmidt. - * - * All rights reserved. - * - * For the sake of compatibility, portions of this code regarding the - * X server interface are taken from Soeren Schmidt's syscons driver. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis, Joerg Wunsch and Soeren Schmidt. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_ext.c, 3.32, Last Edit-Date: [Tue Oct 3 11:19:48 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_ext.c VT220 Driver Extended Support Routines - * ------------------------------------------------------ - * - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -hm applied Onno van der Linden's patch for Cirrus BIOS upgrade - * -hm pcvt_x_hook has to care about fkey labels now - * -hm changed some bcopyb's to bcopy's - * -hm TS_INDEX -> TS_DATA for cirrus (mail from Onno/Charles) - * -jw removed kbc_8042(), and replaced by kbd_emulate_pc() - * -hm X server patch from John Kohl - * -hm applying Joerg's patch for FreeBSD 2.0 - * -hm enable 132 col support for Trident TVGA8900CL - * -hm applying patch from Joerg fixing Crtat bug - * -hm removed PCVT_FAKE_SYSCONS10 - * -hm fastscroll/Crtat bugfix from Lon Willett - * -hm bell patch from Thomas Eberhardt for NetBSD - * -hm multiple X server bugfixes from Lon Willett - * -hm patch from John Kohl fixing tsleep bug in usl_vt_ioctl() - * -hm bugfix: clear 25th line when switching to a force 24 lines vt - * -jw add some forward declarations - * -hm fixing MDA re-init when leaving X - * -hm patch from John Kohl fixing potential divide by 0 problem - * -hm patch from Joerg: console unavailable flag handling - * -hm bugfix: unknown cirrus board enables 132 cols - * -hm fixing NetBSD PR1123, minor typo (reported by J.T. Conklin) - * -hm adding support for Cirrus 5430 chipset - * -hm adding NetBSD-current patches from John Kohl - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch to support Cirrus CL-GD62x5 from Martin - * -hm patch to support 132 cols for Cirrus CL-GD62x5 from Martin - * -hm patch from Frank van der Linden for keyboard state per VT - * -hm patch from Charles Hannum, bugfix of keyboard state switch - * -hm implemented KDGKBMODE keyboard ioctl - * -hm patch from John Kohl, missing kbd_setmode() in switch_screen() - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#include "pcvt_hdr.h" /* global include */ -#include "opt_compat_netbsd.h" - -static int s3testwritable( void ); -static int et4000_col( int ); -static int wd90c11_col( int ); -static int tri9000_col( int ); -static int v7_1024i_col( int ); -static int s3_928_col( int ); -static int cl_gd542x_col( int ); - -/* storage to save video timing values of 80 columns text mode */ -static union { - u_char generic[11]; - u_char et4000[11]; - u_char wd90c11[12]; - u_char tri9000[13]; - u_char v7_1024i[17]; - u_char s3_928[32]; - u_char cirrus[13]; -} -savearea; - -static int regsaved = 0; /* registers are saved to savearea */ - -/*---------------------------------------------------------------------------* - * - * Find out which video board we are running on, taken from: - * Richard Ferraro: Programmers Guide to the EGA and VGA Cards - * and from David E. Wexelblat's SuperProbe Version 1.0. - * When a board is found, for which 132 column switching is - * provided, the global variable "can_do_132col" is set to 1, - * also the global variable vga_family is set to what we found. - * - * ############################################################### - * ## THIS IS GETTING MORE AND MORE A LARGE SPAGHETTI HACK !!!! ## - * ############################################################### - * - *---------------------------------------------------------------------------*/ -u_char -vga_chipset(void) -{ - u_char *ptr; - u_char byte, oldbyte, old1byte, newbyte; - -#if PCVT_132GENERIC - can_do_132col = 1; /* assumes everyone can do 132 col */ -#else - can_do_132col = 0; /* assumes noone can do 132 col */ -#endif /* PCVT_132GENERIC */ - - vga_family = VGA_F_NONE; - -/*---------------------------------------------------------------------------* - * check for Western Digital / Paradise chipsets - *---------------------------------------------------------------------------*/ - - ptr = (u_char *)Crtat; - - if(color) - ptr += (0xc007d - 0xb8000); - else - ptr += (0xc007d - 0xb0000); - - if((*ptr++ == 'V') && (*ptr++ == 'G') && - (*ptr++ == 'A') && (*ptr++ == '=')) - { - int wd90c10; - - vga_family = VGA_F_WD; - - outb(addr_6845, 0x2b); - oldbyte = inb(addr_6845+1); - outb(addr_6845+1, 0xaa); - newbyte = inb(addr_6845+1); - outb(addr_6845+1, oldbyte); - if(newbyte != 0xaa) - return(VGA_PVGA); /* PVGA1A chip */ - - outb(TS_INDEX, 0x12); - oldbyte = inb(TS_DATA); - outb(TS_DATA, oldbyte & 0xbf); - newbyte = inb(TS_DATA) & 0x40; - if(newbyte != 0) - return(VGA_WD90C00); /* WD90C00 chip */ - - outb(TS_DATA, oldbyte | 0x40); - newbyte = inb(TS_DATA) & 0x40; - if(newbyte == 0) - return(VGA_WD90C00); /* WD90C00 chip */ - - outb(TS_DATA, oldbyte); - - wd90c10 = 0; - outb(TS_INDEX, 0x10); - oldbyte = inb(TS_DATA); - - outb(TS_DATA, oldbyte & 0xfb); - newbyte = inb(TS_DATA) & 0x04; - if(newbyte != 0) - wd90c10 = 1; - - outb(TS_DATA, oldbyte | 0x04); - newbyte = inb(TS_DATA) & 0x04; - if(newbyte == 0) - wd90c10 = 1; - - outb(TS_DATA, oldbyte); - - if(wd90c10) - return(VGA_WD90C10); - else - { - can_do_132col = 1; - return(VGA_WD90C11); - } - } - -/*---------------------------------------------------------------------------* - * check for Trident chipsets - *---------------------------------------------------------------------------*/ - - outb(TS_INDEX, 0x0b); - oldbyte = inb(TS_DATA); - - - outb(TS_INDEX, 0x0b); - outb(TS_DATA, 0x00); - - byte = inb(TS_DATA); /* chipset type */ - - - outb(TS_INDEX, 0x0e); - old1byte = inb(TS_DATA); - - outb(TS_DATA, 0); - newbyte = inb(TS_DATA); - - outb(TS_DATA, (old1byte ^ 0x02)); - - outb(TS_INDEX, 0x0b); - outb(TS_DATA, oldbyte); - - if((newbyte & 0x0f) == 0x02) - { - /* is a trident chip */ - - vga_family = VGA_F_TRI; - - switch(byte) - { - case 0x01: - return(VGA_TR8800BR); - - case 0x02: - return(VGA_TR8800CS); - - case 0x03: - can_do_132col = 1; - return(VGA_TR8900B); - - case 0x04: - case 0x13: - /* Haven't tried, but should work */ - can_do_132col = 1; - return(VGA_TR8900C); - - case 0x23: - can_do_132col = 1; - return(VGA_TR9000); - - case 0x33: - can_do_132col = 1; - return(VGA_TR8900CL); - - case 0x83: - return(VGA_TR9200); - - case 0x93: - return(VGA_TR9100); - - default: - return(VGA_TRUNKNOWN); - } - } - -/*---------------------------------------------------------------------------* - * check for Tseng Labs ET3000/4000 chipsets - *---------------------------------------------------------------------------*/ - - outb(GN_HERCOMPAT, 0x06); - if(color) - outb(GN_DMCNTLC, 0xa0); - else - outb(GN_DMCNTLM, 0xa0); - - /* read old value */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MISC); - oldbyte = inb(ATC_DATAR); - - /* write new value */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MISC); - newbyte = oldbyte ^ 0x10; - outb(ATC_DATAW, newbyte); - - /* read back new value */ - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MISC); - byte = inb(ATC_DATAR); - - /* write back old value */ - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MISC); - outb(ATC_DATAW, oldbyte); - - if(byte == newbyte) /* ET3000 or ET4000 */ - { - vga_family = VGA_F_TSENG; - - outb(addr_6845, CRTC_EXTSTART); - oldbyte = inb(addr_6845+1); - newbyte = oldbyte ^ 0x0f; - outb(addr_6845+1, newbyte); - byte = inb(addr_6845+1); - outb(addr_6845+1, oldbyte); - - if(byte == newbyte) - { - can_do_132col = 1; - return(VGA_ET4000); - } - else - { - return(VGA_ET3000); - } - } - -/*---------------------------------------------------------------------------* - * check for Video7 VGA chipsets - *---------------------------------------------------------------------------*/ - - outb(TS_INDEX, TS_EXTCNTL); /* enable extensions */ - outb(TS_DATA, 0xea); - - outb(addr_6845, CRTC_STARTADRH); - oldbyte = inb(addr_6845+1); - - outb(addr_6845+1, 0x55); - newbyte = inb(addr_6845+1); - - outb(addr_6845, CRTC_V7ID); /* id register */ - byte = inb(addr_6845+1); /* read id */ - - outb(addr_6845, CRTC_STARTADRH); - outb(addr_6845+1, oldbyte); - - outb(TS_INDEX, TS_EXTCNTL); /* disable extensions */ - outb(TS_DATA, 0xae); - - if(byte == (0x55 ^ 0xea)) - { /* is Video 7 */ - - vga_family = VGA_F_V7; - - outb(TS_INDEX, TS_EXTCNTL); /* enable extensions */ - outb(TS_DATA, 0xea); - - outb(TS_INDEX, TS_V7CHIPREV); - byte = inb(TS_DATA); - - outb(TS_INDEX, TS_EXTCNTL); /* disable extensions */ - outb(TS_DATA, 0xae); - - if(byte < 0xff && byte >= 0x80) - return(VGA_V7VEGA); - if(byte < 0x7f && byte >= 0x70) - return(VGA_V7FWVR); - if(byte < 0x5a && byte >= 0x50) - return(VGA_V7V5); - if(byte < 0x4a && byte > 0x40) - { - can_do_132col = 1; - return(VGA_V71024I); - } - return(VGA_V7UNKNOWN); - } - -/*---------------------------------------------------------------------------* - * check for S3 chipsets - *---------------------------------------------------------------------------*/ - - outb(addr_6845, 0x38); /* reg 1 lock register */ - old1byte = inb(addr_6845+1); /* get old value */ - - outb(addr_6845, 0x38); - outb(addr_6845+1, 0x00); /* lock registers */ - - if(s3testwritable() == 0) /* check if locked */ - { - outb(addr_6845, 0x38); - outb(addr_6845+1, 0x48); /* unlock registers */ - - if(s3testwritable() == 1 ) /* check if unlocked */ - { - vga_family = VGA_F_S3; /* FAMILY S3 */ - - outb(addr_6845, 0x30); /* chip id/rev reg */ - byte = inb(addr_6845+1); - - switch(byte & 0xf0) - { - case 0x80: - switch(byte & 0x0f) - { - case 0x01: - outb(addr_6845, 0x38); - outb(addr_6845+1, old1byte); - return VGA_S3_911; - - case 0x02: - outb(addr_6845, 0x38); - outb(addr_6845+1, old1byte); - return VGA_S3_924; - - default: - outb(addr_6845, 0x38); - outb(addr_6845+1, old1byte); - return VGA_S3_UNKNOWN; - } - break; - - case 0xA0: - outb(addr_6845, 0x38); - outb(addr_6845+1, old1byte); - return VGA_S3_80x; - - case 0x90: - case 0xb0: - outb(addr_6845, 0x38); - outb(addr_6845+1, old1byte); - can_do_132col = 1; - return VGA_S3_928; - - default: - outb(addr_6845, 0x38); - outb(addr_6845+1, old1byte); - return VGA_S3_UNKNOWN; - } - } - } - -/*---------------------------------------------------------------------------* - * check for Cirrus chipsets - *---------------------------------------------------------------------------*/ - - outb(TS_INDEX, 6); - oldbyte = inb(TS_DATA); - - outb(TS_INDEX, 6); - outb(TS_DATA, 0x12); - - outb(TS_INDEX, 6); - newbyte = inb(TS_DATA); - - outb(addr_6845, 0x27); - byte = inb(addr_6845 + 1); - - outb(TS_INDEX, 6); - outb(TS_DATA, oldbyte); - - if (newbyte == 0x12) - { - vga_family = VGA_F_CIR; - - switch ((byte & 0xfc) >> 2) - { - case 0x06: - can_do_132col = 1; - return VGA_CL_GD6225; - - case 0x22: - switch (byte & 3) - { - case 0: - can_do_132col = 1; - return VGA_CL_GD5402; - - case 1: - can_do_132col = 1; - return VGA_CL_GD5402r1; - - case 2: - can_do_132col = 1; - return VGA_CL_GD5420; - - case 3: - can_do_132col = 1; - return VGA_CL_GD5420r1; - } - break; - case 0x23: - can_do_132col = 1; - return VGA_CL_GD5422; - - case 0x24: - can_do_132col = 1; - return VGA_CL_GD5426; - - case 0x25: - can_do_132col = 1; - return VGA_CL_GD5424; - - case 0x26: - can_do_132col = 1; - return VGA_CL_GD5428; - - case 0x28: - case 0x2a: /* GD5434 */ - can_do_132col = 1; - return VGA_CL_GD5430; - - } - return(VGA_CL_UNKNOWN); - } - return(VGA_UNKNOWN); -} - -/*--------------------------------------------------------------------------- - * test if index 35 lower nibble is writable (taken from SuperProbe 1.0) - *---------------------------------------------------------------------------*/ -static int -s3testwritable(void) -{ - u_char old, new1, new2; - - outb(addr_6845, 0x35); - old = inb(addr_6845+1); /* save */ - - outb(addr_6845, 0x35); - outb(addr_6845+1, (old & 0xf0)); /* write 0 */ - - outb(addr_6845, 0x35); - new1 = (inb(addr_6845+1)) & 0x0f; /* must read 0 */ - - outb(addr_6845, 0x35); - outb(addr_6845+1, (old | 0x0f)); /* write 1 */ - - outb(addr_6845, 0x35); - new2 = (inb(addr_6845+1)) & 0x0f; /* must read 1 */ - - outb(addr_6845, 0x35); - outb(addr_6845+1, old); /* restore */ - - return((new1==0) && (new2==0x0f)); -} - -/*---------------------------------------------------------------------------* - * return ptr to string describing vga type - *---------------------------------------------------------------------------*/ -char * -vga_string(int number) -{ - static char *vga_tab[] = { - "generic", - "et4000", - "et3000", - "pvga1a", - "wd90c00", - "wd90c10", - "wd90c11", - "v7 vega", - "v7 fast", - "v7 ver5", - "v7 1024i", - "unknown v7", - "tvga 8800br", - "tvga 8800cs", - "tvga 8900b", - "tvga 8900c", - "tvga 8900cl", - "tvga 9000", - "tvga 9100", - "tvga 9200", - "unknown trident", - "s3 911", - "s3 924", - "s3 801/805", - "s3 928", - "unknown s3", - "cl-gd5402", - "cl-gd5402r1", - "cl-gd5420", - "cl-gd5420r1", - "cl-gd5422", - "cl-gd5424", - "cl-gd5426", - "cl-gd5428", - "cl-gd5430", - "cl-gd62x5", - "unknown cirrus", - /* VGA_MAX_CHIPSET */ - "vga_string: chipset name table ptr overflow!" - }; - - if(number > VGA_MAX_CHIPSET) /* failsafe */ - number = VGA_MAX_CHIPSET; - - return(vga_tab[number]); -} - -/*---------------------------------------------------------------------------* - * toggle vga 80/132 column operation - *---------------------------------------------------------------------------*/ -int -vga_col(struct video_state *svsp, int cols) -{ - int ret = 0; - - if(adaptor_type != VGA_ADAPTOR) - return(0); - - switch(vga_type) - { - case VGA_ET4000: - ret = et4000_col(cols); - break; - - case VGA_WD90C11: - ret = wd90c11_col(cols); - break; - - case VGA_TR8900B: - case VGA_TR8900C: - case VGA_TR8900CL: - case VGA_TR9000: - ret = tri9000_col(cols); - break; - - case VGA_V71024I: - ret = v7_1024i_col(cols); - break; - - case VGA_S3_928: - ret = s3_928_col(cols); - break; - - case VGA_CL_GD5402: - case VGA_CL_GD5402r1: - case VGA_CL_GD5420: - case VGA_CL_GD5420r1: - case VGA_CL_GD5422: - case VGA_CL_GD5424: - case VGA_CL_GD5426: - case VGA_CL_GD5428: - case VGA_CL_GD5430: - case VGA_CL_GD6225: - ret = cl_gd542x_col(cols); - break; - - default: - -#if PCVT_132GENERIC - ret = generic_col(cols); -#endif /* PCVT_132GENERIC */ - - break; - } - - if(ret == 0) - return(0); /* failed */ - - svsp->maxcol = cols; - - return(1); -} - -#if PCVT_132GENERIC -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for "generic" SVGAs - * NB: this is supposed to work on any (S)VGA as long as the monitor - * is able to sync down to 21.5 kHz horizontally. The resulting - * vertical frequency is only 50 Hz, so if there is some better board - * specific algorithm, we avoid using this generic one. - * REPORT ANY FAILURES SO WE CAN IMPROVE THIS - *---------------------------------------------------------------------------*/ - -#if PCVT_EXP_132COL -/* - * Some improved (i.e. higher scan rates) figures for the horizontal - * timing. USE AT YOUR OWN RISK, THIS MIGHT DAMAGE YOUR MONITOR DUE - * TO A LOSS OF HORIZONTAL SYNC! - * The figures have been tested with an ET3000 board along with a - * NEC MultiSync 3D monitor. If you are playing here, consider - * testing with several screen pictures (dark background vs. light - * background, even enlightening the border color may impact the - * result - you can do this e.g. by "scon -p black,42,42,42") - * Remember that all horizontal timing values must be dividable - * by 8! (The scheme below is taken so that nifty kernel hackers - * are able to patch the figures at run-time.) - * - * The actual numbers result in 23 kHz line scan and 54 Hz vertical - * scan. - */ -#endif /* PCVT_EXP_132COL */ - -int -generic_col(int cols) -{ - u_char *sp; - u_char byte; - -#if !PCVT_EXP_132COL - - /* stable figures for any multisync monitor that syncs down to 22 kHz*/ - static volatile u_short htotal = 1312; - static volatile u_short displayend = 1056; - static volatile u_short blankstart = 1072; - static volatile u_short syncstart = 1112; - static volatile u_short syncend = 1280; - -#else /* PCVT_EXP_132COL */ - - /* reduced sync-pulse width and sync delays */ - static volatile u_short htotal = 1232; - static volatile u_short displayend = 1056; - static volatile u_short blankstart = 1056; - static volatile u_short syncstart = 1104; - static volatile u_short syncend = 1168; - -#endif /* PCVT_EXP_132COL */ - - vga_screen_off(); - - /* enable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte & 0x7f); - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - sp = savearea.generic; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); /* Row Offset Register */ - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - *sp++ = inb(GN_MISCOUTR); /* Misc output register */ - } - - /* setup chipset for 132 column operation */ - - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, (htotal / 8) - 5); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, (displayend / 8) - 1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, blankstart / 8); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, ((syncend / 8) & 0x1f) | 0x80); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, syncstart / 8); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, - (((syncend / 8) & 0x20) * 4) - | ((syncend / 8) & 0x1f)); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, 0x01); /* 8 dot char clock */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); /* ATC Mode control */ - outb(ATC_DATAW, 0x08); /* Line graphics disable */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); /* ATC Horizontal Pixel Panning */ - outb(ATC_DATAW, 0x00); - - /* Misc output register */ - /* use the 28.322 MHz clock */ - outb(GN_MISCOUTW, (inb(GN_MISCOUTR) & ~0x0c) | 4); - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - /* disable access to first 7 CRTC registers */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - vga_screen_on(); - return(0); - } - - sp = savearea.generic; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - } - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - vga_screen_on(); - - return(1); -} -#endif /* PCVT_132GENERIC */ - -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for ET4000 based boards - *---------------------------------------------------------------------------*/ -int -et4000_col(int cols) -{ - u_char *sp; - u_char byte; - - vga_screen_off(); - - /* enable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte & 0x7f); - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - sp = savearea.et4000; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); /* Row Offset Register */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x34); /* 6845 Compatibility */ - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - *sp++ = inb(GN_MISCOUTR); /* Misc output register */ - } - - /* setup chipset for 132 column operation */ - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, 0x9f); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, 0x83); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, 0x84); - - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, 0x8b); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, 0x80); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - outb(addr_6845, 0x34); /* 6845 Compatibility */ - outb(addr_6845+1, 0x0a); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, 0x01); /* 8 dot char clock */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); /* ATC Mode control */ - outb(ATC_DATAW, 0x08); /* Line graphics disable */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); /* ATC Horizontal Pixel Panning */ - outb(ATC_DATAW, 0x00); - - /* Misc output register */ - - outb(GN_MISCOUTW, (inb(GN_MISCOUTR) & ~0x0c)); - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - /* disable access to first 7 CRTC registers */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - vga_screen_on(); - return(0); - } - - sp = savearea.et4000; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - - - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x34); /* 6845 Compatibility */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - } - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - vga_screen_on(); - - return(1); -} - -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for WD/Paradise based boards - * - * when this card does 132 cols, the char map select register (TS_INDEX, - * TS_FONTSEL) function bits get REDEFINED. whoever did design this, - * please don't cross my way ever ....... - * - *---------------------------------------------------------------------------*/ -int -wd90c11_col(int cols) -{ - -#if !PCVT_BACKUP_FONTS - static unsigned char *sv_fontwd[NVGAFONTS]; -#endif /* !PCVT_BACKUP_FONTS */ - - u_char *sp; - u_char byte; - int i; - - vga_screen_off(); - - /* enable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte & 0x7f); - - /* enable access to WD/Paradise "control extensions" */ - - outb(GDC_INDEX, GDC_PR5GPLOCK); - outb(GDC_INDEX, 0x05); - outb(addr_6845, CRTC_PR10); - outb(addr_6845, 0x85); - outb(TS_INDEX, TS_UNLOCKSEQ); - outb(TS_DATA, 0x48); - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - /* save current fonts */ - -#if !PCVT_BACKUP_FONTS - for(i = 0; i < totalfonts; i++) - { - if(vgacs[i].loaded) - { - if((sv_fontwd[i] = - (u_char *)malloc(32 * 256, - M_DEVBUF, - M_WAITOK)) - == NULL) - printf("pcvt: no font buffer\n"); - else - vga_move_charset(i, - sv_fontwd[i], - 1); - } - else - { - sv_fontwd[i] = 0; - } - } - -#endif /* !PCVT_BACKUP_FONTS */ - - sp = savearea.wd90c11; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); /* Row Offset Register */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x2e); /* misc 1 */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x2f); /* misc 2 */ - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, 0x10);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - outb(TS_INDEX, 0x12);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - *sp++ = inb(GN_MISCOUTR); /* Misc output register */ - } - - /* setup chipset for 132 column operation */ - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, 0x9c); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, 0x83); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, 0x84); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, 0x9f); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, 0x8a); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, 0x1c); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - outb(addr_6845, 0x2e); /* misc 1 */ - outb(addr_6845+1, 0x04); - outb(addr_6845, 0x2f); /* misc 2 */ - outb(addr_6845+1, 0x00); - - outb(TS_INDEX, 0x10);/* Timing Sequencer */ - outb(TS_DATA, 0x21); - outb(TS_INDEX, 0x12);/* Timing Sequencer */ - outb(TS_DATA, 0x14); - - outb(GN_MISCOUTW, (inb(GN_MISCOUTR) | 0x08)); /* Misc output register */ - - vsp->wd132col = 1; - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - /* disable access to WD/Paradise "control extensions" */ - - outb(GDC_INDEX, GDC_PR5GPLOCK); - outb(GDC_INDEX, 0x00); - outb(addr_6845, CRTC_PR10); - outb(addr_6845, 0x00); - outb(TS_INDEX, TS_UNLOCKSEQ); - outb(TS_DATA, 0x00); - - vga_screen_on(); - - return(0); - } - - sp = savearea.wd90c11; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x2e); /* misc 1 */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x2f); /* misc 2 */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, 0x10);/* Timing Sequencer */ - outb(addr_6845+1, *sp++); - outb(TS_INDEX, 0x12);/* Timing Sequencer */ - outb(addr_6845+1, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - - vsp->wd132col = 0; - } - - /* restore fonts */ - -#if !PCVT_BACKUP_FONTS - for(i = 0; i < totalfonts; i++) - { - if(sv_fontwd[i]) - vga_move_charset(i, sv_fontwd[i], 0); - } -#else - for(i = 0; i < totalfonts; i++) - if(saved_charsets[i]) - vga_move_charset(i, 0, 0); -#endif /* !PCVT_BACKUP_FONTS */ - - select_vga_charset(vsp->vga_charset); - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - /* disable access to WD/Paradise "control extensions" */ - - outb(GDC_INDEX, GDC_PR5GPLOCK); - outb(GDC_INDEX, 0x00); - outb(addr_6845, CRTC_PR10); - outb(addr_6845, 0x00); - outb(TS_INDEX, TS_UNLOCKSEQ); - outb(TS_DATA, 0x00); - - vga_screen_on(); - - return(1); -} - -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for TRIDENT 9000 based boards - *---------------------------------------------------------------------------*/ -int -tri9000_col(int cols) -{ - u_char *sp; - u_char byte; - - vga_screen_off(); - - /* sync reset is necessary to preserve memory contents ... */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - /* disable protection of misc out and other regs */ - - outb(addr_6845, CRTC_MTEST); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_MTEST); - outb(addr_6845+1, byte & ~0x50); - - /* enable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte & 0x7f); - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - sp = savearea.tri9000; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, TS_HWVERS);/* Hardware Version register */ - outb(TS_DATA, 0x00); /* write ANYTHING switches to OLD */ - outb(TS_INDEX, TS_MODEC2); - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, TS_HWVERS);/* Hardware Version register */ - inb(TS_DATA); /* read switches to NEW */ - outb(TS_INDEX, TS_MODEC2); - *sp++ = inb(TS_DATA); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - *sp++ = inb(GN_MISCOUTR); /* Misc output register */ - } - - /* setup chipset for 132 column operation */ - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, 0x9b); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, 0x83); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, 0x84); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, 0x1e); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, 0x87); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, 0x1a); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, 0x01); /* 8 dot char clock */ - - outb(TS_INDEX, TS_HWVERS);/* Hardware Version register */ - outb(TS_DATA, 0x00); /* write ANYTHING switches to OLD */ - outb(TS_INDEX, TS_MODEC2); - outb(TS_DATA, 0x00); - - outb(TS_INDEX, TS_HWVERS);/* Hardware Version register */ - inb(TS_DATA); /* read switches to NEW */ - outb(TS_INDEX, TS_MODEC2); - outb(TS_DATA, 0x01); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); /* ATC Mode control */ - outb(ATC_DATAW, 0x08); /* Line graphics disable */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); /* ATC Horizontal Pixel Panning */ - outb(ATC_DATAW, 0x00); - - outb(GN_MISCOUTW, (inb(GN_MISCOUTR) | 0x0c)); /* Misc output register */ - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - /* disable access to first 7 CRTC registers */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - - vga_screen_on(); - - return(0); - } - - sp = savearea.tri9000; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - outb(TS_INDEX, TS_HWVERS);/* Hardware Version register */ - outb(TS_DATA, 0x00); /* write ANYTHING switches to OLD */ - outb(TS_INDEX, TS_MODEC2);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - outb(TS_INDEX, TS_HWVERS);/* Hardware Version register */ - inb(TS_DATA); /* read switches to NEW */ - outb(TS_INDEX, TS_MODEC2);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - } - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - - vga_screen_on(); - - return(1); -} - -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for Video7 VGA 1024i - *---------------------------------------------------------------------------*/ -int -v7_1024i_col(int cols) -{ - u_char *sp; - u_char byte; - u_char save__byte; - - vga_screen_off(); - - /* enable access to first 7 CRTC registers */ - - /* first, enable read access to vertical retrace start/end */ - outb(addr_6845, CRTC_HBLANKE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_HBLANKE); - outb(addr_6845+1, (byte | 0x80)); - - /* second, enable access to protected registers */ - outb(addr_6845, CRTC_VSYNCE); - save__byte = byte = inb(addr_6845+1); - byte |= 0x20; /* no irq 2 */ - byte &= 0x6f; /* wr enable, clr irq flag */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - outb(TS_INDEX, TS_EXTCNTL); /* enable extensions */ - outb(TS_DATA, 0xea); - - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - sp = savearea.v7_1024i; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); /* Row Offset Register */ - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - outb(TS_INDEX, 0x83); - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, 0xa4); - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, 0xe0); - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, 0xe4); - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, 0xf8); - *sp++ = inb(TS_DATA); - - outb(TS_INDEX, 0xfd); - *sp++ = inb(TS_DATA); - - *sp++ = inb(GN_MISCOUTR); /* Misc output register */ - } - - /* setup chipset for 132 column operation */ - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, 0x9c); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, 0x83); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, 0x86); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, 0x9e); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, 0x89); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, 0x1c); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, 0x01); /* 8 dot char clock */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); /* ATC Mode control */ - outb(ATC_DATAW, 0x08); /* Line graphics disable */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); /* ATC Horizontal Pixel Panning */ - outb(ATC_DATAW, 0x00); - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, 0x83); - outb(TS_DATA, 0xa0); - - outb(TS_INDEX, 0xa4); - outb(TS_DATA, 0x1c); - - outb(TS_INDEX, 0xe0); - outb(TS_DATA, 0x00); - - outb(TS_INDEX, 0xe4); - outb(TS_DATA, 0xfe); - - outb(TS_INDEX, 0xf8); - outb(TS_DATA, 0x1b); - - outb(TS_INDEX, 0xfd); - outb(TS_DATA, 0x33); - - byte = inb(GN_MISCOUTR); - byte |= 0x0c; - outb(GN_MISCOUTW, byte); /* Misc output register */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - outb(TS_INDEX, TS_EXTCNTL); /* disable extensions */ - outb(TS_DATA, 0xae); - - /* disable access to first 7 CRTC registers */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - vga_screen_on(); - return(0); - } - - sp = savearea.v7_1024i; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, 0x83); - outb(TS_DATA, *sp++); - - outb(TS_INDEX, 0xa4); - outb(TS_DATA, *sp++); - - outb(TS_INDEX, 0xe0); - outb(TS_DATA, *sp++); - - outb(TS_INDEX, 0xe4); - outb(TS_DATA, *sp++); - - outb(TS_INDEX, 0xf8); - outb(TS_DATA, *sp++); - - outb(TS_INDEX, 0xfd); - outb(TS_DATA, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - } - - outb(TS_INDEX, TS_EXTCNTL); /* disable extensions */ - outb(TS_DATA, 0xae); - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, save__byte); - - vga_screen_on(); - - return(1); -} - -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for S3 86C928 based boards - *---------------------------------------------------------------------------*/ -int -s3_928_col(int cols) -{ - u_char *sp; - u_char byte; - - vga_screen_off(); - - outb(addr_6845, 0x38); - outb(addr_6845+1, 0x48); /* unlock registers */ - outb(addr_6845, 0x39); - outb(addr_6845+1, 0xa0); /* unlock registers */ - - /* enable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte & 0x7f); - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - sp = savearea.s3_928; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); /* Row Offset Register */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x34); /* Backward Compat 3 Reg */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x3b); /* Data Xfer Exec Position */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x42); /* (Clock) Mode Control */ - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - *sp++ = inb(GN_MISCOUTR); /* Misc output register */ - } - - /* setup chipset for 132 column operation */ - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, 0x9a); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, 0x83); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, 0x86); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, 0x9d); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, 0x87); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, 0x1b); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - outb(addr_6845, 0x34); - outb(addr_6845+1, 0x10);/* enable data xfer pos control */ - outb(addr_6845, 0x3b); - outb(addr_6845+1, 0x90);/* set data xfer pos value */ - - outb(addr_6845, 0x42); /* (Clock) Mode Control */ - outb(addr_6845+1, 0x02);/* Select 40MHz Clock */ - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, 0x01); /* 8 dot char clock */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); /* ATC Mode control */ - outb(ATC_DATAW, 0x08); /* Line graphics disable */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); /* ATC Horizontal Pixel Panning */ - outb(ATC_DATAW, 0x00); - - /* Misc output register */ - - outb(GN_MISCOUTW, (inb(GN_MISCOUTR) | 0x0c)); - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - /* disable access to first 7 CRTC registers */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - outb(addr_6845, 0x38); - outb(addr_6845+1, 0x00); /* lock registers */ - outb(addr_6845, 0x39); - outb(addr_6845+1, 0x00); /* lock registers */ - - vga_screen_on(); - return(0); - } - - sp = savearea.s3_928; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x34); - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x3b); - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x42); /* Mode control */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - } - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - outb(addr_6845, 0x38); - outb(addr_6845+1, 0x00); /* lock registers */ - outb(addr_6845, 0x39); - outb(addr_6845+1, 0x00); /* lock registers */ - - vga_screen_on(); - - return(1); -} - -/*---------------------------------------------------------------------------* - * toggle 80/132 column operation for Cirrus Logic 542x based boards - *---------------------------------------------------------------------------*/ -int -cl_gd542x_col(int cols) -{ - u_char *sp; - u_char byte; - - vga_screen_off(); - - /* enable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - byte = inb(addr_6845+1); - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte & 0x7f); - - /* enable access to cirrus extension registers */ - outb(TS_INDEX, 6); - outb(TS_DATA, 0x12); - - if(cols == SCR_COL132) /* switch 80 -> 132 */ - { - /* save state of board for 80 columns */ - - if(!regsaved) - { - regsaved = 1; - - sp = savearea.cirrus; - - outb(addr_6845, 0x00); /* Horizontal Total */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x01); /* Horizontal Display End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - *sp++ = inb(addr_6845+1); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - *sp++ = inb(addr_6845+1); - - outb(addr_6845, 0x13); /* Row Offset Register */ - *sp++ = inb(addr_6845+1); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - *sp++ = inb(TS_DATA); - - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - *sp++ = inb(ATC_DATAR); - - /* VCLK2 Numerator Register */ - outb(TS_INDEX, 0xd); - *sp++ = inb(TS_DATA); - - /* VCLK2 Denominator and Post-Scalar Value Register */ - outb(TS_INDEX, 0x1d); - *sp++ = inb(TS_DATA); - - /* Misc output register */ - *sp++ = inb(GN_MISCOUTR); - } - - /* setup chipset for 132 column operation */ - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, 0x9f); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, 0x83); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, 0x84); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, 0x82); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, 0x8a); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, 0x9e); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, 0x42); - - /* set VCLK2 to 41.164 MHz ..... */ - outb(TS_INDEX, 0xd); /* VCLK2 Numerator Register */ - outb(TS_DATA, 0x45); - - outb(TS_INDEX, 0x1d); /* VCLK2 Denominator and */ - outb(TS_DATA, 0x30); /* Post-Scalar Value Register */ - - /* and use it. */ - outb(GN_MISCOUTW, (inb(GN_MISCOUTR) & ~0x0c) | (2 << 2)); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, 0x01); /* 8 dot char clock */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); /* ATC Mode control */ - outb(ATC_DATAW, 0x08); /* Line graphics disable */ - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); /* ATC Horizontal Pixel Panning */ - outb(ATC_DATAW, 0x00); - } - else /* switch 132 -> 80 */ - { - if(!regsaved) /* failsafe */ - { - /* disable access to first 7 CRTC registers */ - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - /* disable access to cirrus extension registers */ - outb(TS_INDEX, 6); - outb(TS_DATA, 0); - - vga_screen_on(); - return(0); - } - - sp = savearea.cirrus; - - outb(addr_6845, 0x00); /* Horizontal Total */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x01); /* Horizontal Display End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x02); /* Horizontal Blank Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x03); /* Horizontal Blank End */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x04); /* Horizontal Retrace Start */ - outb(addr_6845+1, *sp++); - outb(addr_6845, 0x05); /* Horizontal Retrace End */ - outb(addr_6845+1, *sp++); - - outb(addr_6845, 0x13); /* Row Offset Register */ - outb(addr_6845+1, *sp++); - - outb(TS_INDEX, TS_MODE);/* Timing Sequencer */ - outb(TS_DATA, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Mode control */ - outb(ATC_INDEX, ATC_MODE | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - if(color) - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - /* ATC Horizontal Pixel Panning */ - outb(ATC_INDEX, ATC_HORPIXPAN | ATC_ACCESS); - outb(ATC_DATAW, *sp++); - - /* VCLK2 Numerator Register */ - outb(TS_INDEX, 0xd); - outb(TS_DATA, *sp++); - - /* VCLK2 Denominator and Post-Scalar Value Register */ - outb(TS_INDEX, 0x1d); - outb(TS_DATA, *sp++); - - outb(GN_MISCOUTW, *sp++); /* Misc output register */ - } - - /* disable access to cirrus extension registers */ - outb(TS_INDEX, 6); - outb(TS_DATA, 0); - - /* disable access to first 7 CRTC registers */ - - outb(addr_6845, CRTC_VSYNCE); - outb(addr_6845+1, byte); - - vga_screen_on(); - - return(1); -} - -/*---------------------------------------------------------------------------* - * switch screen from text mode to X-mode and vice versa - *---------------------------------------------------------------------------*/ -void -switch_screen(int n, int oldgrafx, int newgrafx) -{ - -#if PCVT_SCREENSAVER - static unsigned saved_scrnsv_tmo = 0; -#endif /* PCVT_SCREENSAVER */ - -#if !PCVT_KBD_FIFO - int x; -#endif /* !PCVT_KBD_FIFO */ - - int cols = vsp->maxcol; /* get current col val */ - - if(n < 0 || n >= totalscreens) - return; - -#if !PCVT_KBD_FIFO - x = spltty(); /* protect us */ -#endif /* !PCVT_KBD_FIFO */ - - if(!oldgrafx && newgrafx) - { - /* switch from text to graphics */ - -#if PCVT_SCREENSAVER - if((saved_scrnsv_tmo = scrnsv_timeout)) - pcvt_set_scrnsv_tmo(0); /* screensaver off */ -#endif /* PCVT_SCREENSAVER */ - } - - if(!oldgrafx) - { - /* switch from text mode */ - - /* video board memory -> kernel memory */ - bcopy(vsp->Crtat, vsp->Memory, - vsp->screen_rows * vsp->maxcol * CHR); - - vsp->Crtat = vsp->Memory; /* operate in memory now */ - } - - /* update global screen pointers/variables */ - current_video_screen = n; /* current screen no */ - - pcconsp = vs[n].vs_tty; /* current tty */ - - vsp = &vs[n]; /* current video state ptr */ - - if(oldgrafx && !newgrafx) - { - /* switch from graphics to text mode */ - unsigned i; - - /* restore fonts */ - for(i = 0; i < totalfonts; i++) - if(saved_charsets[i]) - vga_move_charset(i, 0, 0); - -#if PCVT_SCREENSAVER - /* activate screen saver */ - if(saved_scrnsv_tmo) - pcvt_set_scrnsv_tmo(saved_scrnsv_tmo); -#endif /* PCVT_SCREENSAVER */ - - /* re-initialize lost MDA information */ - if(adaptor_type == MDA_ADAPTOR) - { - /* - * Due to the fact that HGC registers are write-only, - * the Xserver can only make guesses about the state - * the HGC adaptor has been before turning on X mode. - * Thus, the display must be re-enabled now, and the - * cursor shape and location restored. - */ - outb(GN_DMCNTLM, 0x28); /* enable display, text mode */ - outb(addr_6845, CRTC_CURSORH); /* select high register */ - outb(addr_6845+1, - ((vsp->Crtat + vsp->cur_offset) - Crtat) >> 8); - outb(addr_6845, CRTC_CURSORL); /* select low register */ - outb(addr_6845+1, - ((vsp->Crtat + vsp->cur_offset) - Crtat)); - - outb(addr_6845, CRTC_CURSTART); /* select high register */ - outb(addr_6845+1, vsp->cursor_start); - outb(addr_6845, CRTC_CUREND); /* select low register */ - outb(addr_6845+1, vsp->cursor_end); - } - } - - if(!newgrafx) - { - /* to text mode */ - - /* kernel memory -> video board memory */ - bcopy(vsp->Crtat, Crtat, - vsp->screen_rows * vsp->maxcol * CHR); - - vsp->Crtat = Crtat; /* operate on screen now */ - - outb(addr_6845, CRTC_STARTADRH); - outb(addr_6845+1, 0); - outb(addr_6845, CRTC_STARTADRL); - outb(addr_6845+1, 0); - } - -#if !PCVT_KBD_FIFO - splx(x); -#endif /* !PCVT_KBD_FIFO */ - - select_vga_charset(vsp->vga_charset); - - if(vsp->maxcol != cols) - vga_col(vsp, vsp->maxcol); /* select 80/132 columns */ - - outb(addr_6845, CRTC_CURSORH); /* select high register */ - outb(addr_6845+1, vsp->cur_offset >> 8); - outb(addr_6845, CRTC_CURSORL); /* select low register */ - outb(addr_6845+1, vsp->cur_offset); - - if(vsp->cursor_on) - { - outb(addr_6845, CRTC_CURSTART); /* select high register */ - outb(addr_6845+1, vsp->cursor_start); - outb(addr_6845, CRTC_CUREND); /* select low register */ - outb(addr_6845+1, vsp->cursor_end); - } - else - { - sw_cursor(0); - } - - if(adaptor_type == VGA_ADAPTOR) - { - unsigned i; - - /* switch VGA DAC palette entries */ - for(i = 0; i < NVGAPEL; i++) - vgapaletteio(i, &vsp->palette[i], 1); - } - - if(!newgrafx) - { - update_led(); /* update led's */ - update_hp(vsp); /* update fkey labels, if present */ - - /* if we switch to a vt with force 24 lines mode and */ - /* pure VT emulation and 25 rows charset, then we have */ - /* to clear the last line on display ... */ - - if(vsp->force24 && (vsp->vt_pure_mode == M_PUREVT) && - (vgacs[vsp->vga_charset].screen_size == SIZ_25ROWS)) - { - fillw(' ', vsp->Crtat + vsp->screen_rows * vsp->maxcol, - vsp->maxcol); - } - } - kbd_setmode(vsp->kbd_state); -} - -/*---------------------------------------------------------------------------* - * Change specified vt to VT_AUTO mode - * xxx Maybe this should also reset VT_GRAFX mode; since switching and - * graphics modes are not going to work without VT_PROCESS mode. - *---------------------------------------------------------------------------*/ -static void -set_auto_mode (struct video_state *vsx) -{ - unsigned ostatus = vsx->vt_status; - vsx->smode.mode = VT_AUTO; - vsx->proc = NULL; - vsx->pid = 0; - vsx->vt_status &= ~(VT_WAIT_REL|VT_WAIT_ACK); - if (ostatus & VT_WAIT_ACK) { -#if 0 - assert (!(ostatus&VT_WAIT_REL)); - assert (vsp == vsx && - vt_switch_pending == current_video_screen + 1); - vt_switch_pending = 0; -#else - if (vsp == vsx && - vt_switch_pending == current_video_screen + 1) - vt_switch_pending = 0; -#endif - } - if (ostatus&VT_WAIT_REL) { - int new_screen = vt_switch_pending - 1; -#if 0 - assert(vsp == vsx && vt_switch_pending); - vt_switch_pending = 0; - vgapage (new_screen); -#else - if (vsp == vsx && vt_switch_pending) { - vt_switch_pending = 0; - vgapage (new_screen); - } -#endif - } -} - -/*---------------------------------------------------------------------------* - * Exported function; to be called when a vt is closed down. - * - * Ideally, we would like to be able to recover from an X server crash; - * but in reality, if the server crashes hard while in control of the - * vga board, then you're not likely to be able to use pcvt ttys - * without rebooting. - *---------------------------------------------------------------------------*/ -void -reset_usl_modes (struct video_state *vsx) -{ - /* Clear graphics mode */ - if (vsx->vt_status & VT_GRAFX) - { - vsx->vt_status &= ~VT_GRAFX; - if (vsp == vsx) - switch_screen(current_video_screen, 1, 0); - } - - /* Take kbd out of raw mode */ - if(vsx->kbd_state == K_RAW) - { - if(vsx == vsp) - kbd_setmode(K_XLATE); - vsx->kbd_state = K_XLATE; - } - - /* Clear process controlled mode */ - set_auto_mode (vsx); -} - -/*---------------------------------------------------------------------------* - * switch to virtual screen n (0 ... PCVT_NSCREENS-1) - * (the name vgapage() stands for historical reasons) - *---------------------------------------------------------------------------*/ -int -vgapage(int new_screen) -{ - int x; - - if(new_screen < 0 || new_screen >= totalscreens) - return EINVAL; - - /* fallback to VT_AUTO if controlling processes died */ - if(vsp->proc && vsp->proc != pfind(vsp->pid)) - set_auto_mode(vsp); - if(vs[new_screen].proc - && vs[new_screen].proc != pfind(vs[new_screen].pid)) - set_auto_mode(&vs[new_screen]); - - if (!vt_switch_pending && new_screen == current_video_screen) - return 0; - - if(vt_switch_pending && vt_switch_pending != new_screen + 1) { - /* Try resignaling uncooperative X-window servers */ - if (vsp->smode.mode == VT_PROCESS) { - if (vsp->vt_status & VT_WAIT_REL) { - if(vsp->smode.relsig) - psignal(vsp->proc, vsp->smode.relsig); - } else if (vsp->vt_status & VT_WAIT_ACK) { - if(vsp->smode.acqsig) - psignal(vsp->proc, vsp->smode.acqsig); - } - } - return EAGAIN; - } - - vt_switch_pending = new_screen + 1; - - if(vsp->smode.mode == VT_PROCESS) - { - /* we cannot switch immediately here */ - vsp->vt_status |= VT_WAIT_REL; - if(vsp->smode.relsig) - psignal(vsp->proc, vsp->smode.relsig); - } - else - { - struct video_state *old_vsp = vsp; - - switch_screen(new_screen, - vsp->vt_status & VT_GRAFX, - vs[new_screen].vt_status & VT_GRAFX); - - x = spltty(); - if(old_vsp->vt_status & VT_WAIT_ACT) - { - old_vsp->vt_status &= ~VT_WAIT_ACT; - wakeup((caddr_t)&old_vsp->smode); - } - if(vsp->vt_status & VT_WAIT_ACT) - { - vsp->vt_status &= ~VT_WAIT_ACT; - wakeup((caddr_t)&vsp->smode); - } - splx(x); - - if(vsp->smode.mode == VT_PROCESS) - { - /* if _new_ vt is under process control... */ - vsp->vt_status |= VT_WAIT_ACK; - if(vsp->smode.acqsig) - psignal(vsp->proc, vsp->smode.acqsig); - } - else - { - /* we are committed */ - vt_switch_pending = 0; - - } - } - return 0; -} - -/*---------------------------------------------------------------------------* - * VT_USL ioctl handling - *---------------------------------------------------------------------------*/ -int -usl_vt_ioctl(Dev_t dev, int cmd, caddr_t data, int flag, struct proc *p) -{ - int i, j, error, opri, mode; - struct vt_mode newmode; - struct video_state *vsx = &vs[minor(dev)]; - - switch(cmd) - { - - case VT_SETMODE: - newmode = *(struct vt_mode *)data; - - opri = spltty(); - - if (newmode.mode != VT_PROCESS) - { - if (vsx->smode.mode == VT_PROCESS) - { - if (vsx->proc != p) - { - splx(opri); - return EPERM; - } - set_auto_mode(vsx); - } - splx(opri); - return 0; - } - - /* - * NB: XFree86-3.1.1 does the following: - * VT_ACTIVATE (vtnum) - * VT_WAITACTIVE (vtnum) - * VT_SETMODE (VT_PROCESS) - * So it is possible that the screen was switched - * between the WAITACTIVE and the SETMODE (here). This - * can actually happen quite frequently, and it was - * leading to dire consequences. Now it is detected by - * requiring that minor(dev) match current_video_screen. - * An alternative would be to operate on vs[minor(dev)] - * instead of *vsp, but that would leave the server - * confused, because it would believe that its vt was - * currently activated. - */ - if (minor(dev) != current_video_screen) - { - splx(opri); - return EPERM; - } - - /* Check for server died */ - - if(vsp->proc && vsp->proc != pfind(vsp->pid)) - set_auto_mode(vsp); - - /* Check for server already running */ - - if (vsp->smode.mode == VT_PROCESS && vsp->proc != p) - { - splx(opri); - return EBUSY; /* already in use on this VT */ - } - - vsp->smode = newmode; - vsp->proc = p; - vsp->pid = p->p_pid; - - splx(opri); - return 0; - - case VT_GETMODE: - *(struct vt_mode *)data = vsp->smode; - return 0; - - case VT_RELDISP: - if (minor(dev) != current_video_screen) - return EPERM; - if (vsp->smode.mode != VT_PROCESS) - return EINVAL; - if (vsp->proc != p) - return EPERM; - switch(*(int *)data) - { - case VT_FALSE: - /* process refuses to release screen; abort */ - if(vt_switch_pending - && (vsp->vt_status & VT_WAIT_REL)) - { - vsp->vt_status &= ~VT_WAIT_REL; - vt_switch_pending = 0; - return 0; - } - break; - - case VT_TRUE: - /* process releases its VT */ - if(vt_switch_pending - && (vsp->vt_status & VT_WAIT_REL)) - { - int new_screen = vt_switch_pending - 1; - struct video_state *old_vsp = vsp; - - vsp->vt_status &= ~VT_WAIT_REL; - - switch_screen(new_screen, - vsp->vt_status & VT_GRAFX, - vs[new_screen].vt_status - & VT_GRAFX); - - opri = spltty(); - if(old_vsp->vt_status & VT_WAIT_ACT) - { - old_vsp->vt_status &= ~VT_WAIT_ACT; - wakeup((caddr_t)&old_vsp->smode); - } - if(vsp->vt_status & VT_WAIT_ACT) - { - vsp->vt_status &= ~VT_WAIT_ACT; - wakeup((caddr_t)&vsp->smode); - } - splx(opri); - - if(vsp->smode.mode == VT_PROCESS) - { - /* - * if the new vt is also in process - * mode, we have to wait until its - * controlling process acknowledged - * the switch - */ - vsp->vt_status - |= VT_WAIT_ACK; - if(vsp->smode.acqsig) - psignal(vsp->proc, - vsp->smode.acqsig); - } - else - { - /* we are committed */ - vt_switch_pending = 0; - - } - return 0; - } - break; - - case VT_ACKACQ: - /* new vts controlling process acknowledged */ - if(vsp->vt_status & VT_WAIT_ACK) - { - vt_switch_pending = 0; - vsp->vt_status &= ~VT_WAIT_ACK; - - return 0; - } - break; - } - return EINVAL; /* end case VT_RELDISP */ - - - case VT_OPENQRY: - /* return free vt */ - for(i = 0; i < PCVT_NSCREENS; i++) - { - if(!vs[i].openf) - { - *(int *)data = i + 1; - return 0; - } - } - return EAGAIN; - - case VT_GETACTIVE: - *(int *)data = current_video_screen + 1; - return 0; - - case VT_ACTIVATE: - return vgapage(*(int *)data - 1); - - case VT_WAITACTIVE: - /* sleep until vt switch happened */ - i = *(int *)data - 1; - - if(i != -1 && (i < 0 || i >= PCVT_NSCREENS)) - return EINVAL; - - if(i != -1 && current_video_screen == i) - return 0; - - if(i == -1) - { - /* xxx Is this what it is supposed to do? */ - int x = spltty(); - i = current_video_screen; - error = 0; - while (current_video_screen == i && error == 0) - { - vs[i].vt_status |= VT_WAIT_ACT; - error = tsleep((caddr_t)&vs[i].smode, - PZERO | PCATCH, "waitvt", 0); - } - splx(x); - } - else - { - int x = spltty(); - error = 0; - while (current_video_screen != i && error == 0) - { - vs[i].vt_status |= VT_WAIT_ACT; - error = tsleep((caddr_t)&vs[i].smode, - PZERO | PCATCH, "waitvt", 0); - } - splx(x); - } - return (error == ERESTART) ? PCVT_ERESTART : error; - - case KDENABIO: - /* - * grant the process IO access; only allowed if euid == 0 - * and securelevel <= 1. XXX -- this is a fairly serious - * hole, but if closed at securelevel 1, would require - * options INSECURE in order to use X at all. - */ - - { - -#if defined(COMPAT_10) || defined(COMPAT_11) - struct trapframe *fp = (struct trapframe *)p->p_md.md_regs; -#endif - - if(suser(p->p_ucred, &p->p_acflag) || securelevel > 1) - return (EPERM); - -#if defined(COMPAT_10) || defined(COMPAT_11) - /* This is done by i386_iopl(3) now. */ - fp->tf_eflags |= PSL_IOPL; -#endif - - return 0; - } - - case KDDISABIO: - /* abandon IO access permission */ - { - -#if defined(COMPAT_10) || defined(COMPAT_11) - /* This is done by i386_iopl(3) now. */ - struct trapframe *fp = (struct trapframe *)p->p_md.md_regs; - fp->tf_eflags &= ~PSL_IOPL; -#endif - return 0; - } - - case KDSETMODE: - { - int haschanged = 0; - - if(adaptor_type != VGA_ADAPTOR - && adaptor_type != MDA_ADAPTOR) - /* X will only run on those adaptors */ - return (EINVAL); - - /* set text/graphics mode of current vt */ - switch(*(int *)data) - { - case KD_TEXT: - haschanged = (vsx->vt_status & VT_GRAFX) != 0; - vsx->vt_status &= ~VT_GRAFX; - if(haschanged && vsx == vsp) - switch_screen(current_video_screen, 1, 0); - return 0; - - case KD_GRAPHICS: - /* xxx It might be a good idea to require that - the vt be in process controlled mode here, - and that the calling process is the owner */ - haschanged = (vsx->vt_status & VT_GRAFX) == 0; - vsx->vt_status |= VT_GRAFX; - if(haschanged && vsx == vsp) - switch_screen(current_video_screen, 0, 1); - return 0; - - } - return EINVAL; /* end case KDSETMODE */ - } - - case KDSETRAD: - /* set keyboard repeat and delay */ - return kbdioctl(dev, KBDSTPMAT, data, flag); - - case KDGKBMODE: - *(int *)data = vsx->kbd_state; - return 0; - - case KDSKBMODE: - mode = *(int *)data; - switch(mode) - { - case K_RAW: - case K_XLATE: - if(vsx->kbd_state != mode) - { - if(vsx == vsp) - kbd_setmode(mode); - vsx->kbd_state = mode; - } - return 0; - } - return EINVAL; /* end KDSKBMODE */ - - case KDMKTONE: - /* ring the speaker */ - if(data) - { - int duration = *(int *)data >> 16; - int pitch = *(int *)data & 0xffff; - - if(pitch != 0) - { - sysbeep(PCVT_SYSBEEPF / pitch, - duration * hz / 1000); - } - - } - else - { - sysbeep(PCVT_SYSBEEPF / 1493, hz / 4); - } - return 0; - - case KDSETLED: - /* set kbd LED status */ - /* unfortunately, the LED definitions between pcvt and */ - /* USL differ some way :-( */ - i = *(int *)data; - j = (i & LED_CAP? KBD_CAPSLOCK: 0) - + (i & LED_NUM? KBD_NUMLOCK: 0) - + (i & LED_SCR? KBD_SCROLLLOCK: 0); - return kbdioctl(dev, KBDSLOCK, (caddr_t)&j, flag); - - case KDGETLED: - /* get kbd LED status */ - if((error = kbdioctl(dev, KBDGLOCK, (caddr_t)&j, flag))) - return error; - i = (j & KBD_CAPSLOCK? LED_CAP: 0) - + (j & KBD_NUMLOCK? LED_NUM: 0) - + (j & KBD_SCROLLLOCK? LED_SCR: 0); - *(int *)data = i; - return 0; - - case GIO_KEYMAP: - get_usl_keymap((keymap_t *)data); - return 0; - } /* end case cmd */ - - return -1; /* inappropriate usl_vt_compat ioctl */ -} - -/* ------------------------- E O F ------------------------------------------*/ - diff --git a/sys/arch/i386/isa/pcvt/pcvt_hdr.h b/sys/arch/i386/isa/pcvt/pcvt_hdr.h deleted file mode 100644 index 132a6648d459..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_hdr.h +++ /dev/null @@ -1,1212 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore. - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis, Brian Dunford-Shore and Joerg Wunsch. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_hdr.h, 3.32, Last Edit-Date: [Tue Oct 3 11:19:48 1995] - * - */ - -/*--------------------------------------------------------------------------- - * - * pcvt_hdr.h VT220 Driver Global Include File - * ------------------------------------------------ - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -hm integrating patches from Thomas Gellekum - * -hm moving vt_selattr() inline into this file - * -hm Michael's keyboard fifo diffs - * -hm documenting some #ifdef's ... - * -hm Joerg's patches for FreeBSD's ttymalloc - * -jw introduced kbd_emulate_pc() if scanset > 1 - * -hm moved user configurable items to pcvt_conf.h - * -hm applying Joerg's patches for FreeBSD 2.0 - * -hm patch from Onno & Martin for NetBSD-current (post 1.0) - * -hm some adjustments for NetBSD 1.0 - * -hm patch from Joerg fixing FreeBSD 2.0 support - * -hm patch from Onno/John for NetBSD-current - * -hm applying patch from Joerg fixing Crtat bug - * -hm removed PCVT_FAKE_SYSCONS10 - * -hm added pcstop (patch from Onno) - * -hm multiple X server bugfixes from Lon Willett - * -hm patch from Joerg for FreeBSD pre-2.1 - * -jw adding more support for FreeBSD pre-2.1 - * -hm patches from Michael for NetBSD-current (Apr/21/95) support - * -hm several NetBSD-current patches from John Kohl - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Thomas Gellekum to support C1 controls - * -hm patch from Frank van der Linden for keyboard state per VT - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#define PCVT_REL "3.32" /* driver attach announcement */ - /* see also: pcvt_ioctl.h */ - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "pcvt_conf.h" - -#include - -#include "opt_xserver.h" - -#include -#include -#include - -#include - -#include - -#include -#include -#include - -#include - -#include "pcvt_ioctl.h" - -#include - -#include - - - -#ifdef XSERVER - -/* PCVT_NULLCHARS is mandatory for X server */ -#undef PCVT_NULLCHARS -#define PCVT_NULLCHARS 1 - -/* PCVT_BACKUP_FONTS is mandatory for XSERVER */ -#undef PCVT_BACKUP_FONTS -#define PCVT_BACKUP_FONTS 1 - -#endif /* XSERVER */ - -/* PCVT_SCREENSAVER is mandatory for PCVT_PRETTYSCRNS */ -#if PCVT_PRETTYSCRNS && !PCVT_SCREENSAVER -#undef PCVT_SCREENSAVER -#define PCVT_SCREENSAVER 1 -#endif - -/* get the inline inb/outb back again ... */ - -#include /* recent NetBSD -currents */ -#define NEW_AVERUNNABLE /* averunnable changes for younger currents */ - -#if PCVT_SCANSET !=1 && PCVT_SCANSET !=2 -#error "Supported keyboard scancode sets are 1 and 2 only (for now)!!!" -#endif - -/*---------------------------------------------------------------------------* - * Keyboard and Keyboard Controller - *---------------------------------------------------------------------------*/ - -#define CONTROLLER_CTRL 0x64 /* W - command, R - status */ -#define CONTROLLER_DATA 0x60 /* R/W - data */ - -/* commands to control the CONTROLLER (8042) on the mainboard */ - -#define CONTR_READ 0x20 /* read command byte from controller */ -#define CONTR_WRITE 0x60 /* write command to controller, see below */ -#define CONTR_SELFTEST 0xaa /* controller selftest, returns 0x55 when ok */ -#define CONTR_IFTEST 0xab /* interface selftest */ -#define CONTR_KBDISABL 0xad /* disable keyboard */ -#define CONTR_KBENABL 0xae /* enable keyboard */ - -/* command byte for writing to CONTROLLER (8042) via CONTR_WRITE */ - -#define COMMAND_RES7 0x80 /* bit 7, reserved, always write a ZERO ! */ -#define COMMAND_PCSCAN 0x40 /* bit 6, 1 = convert to pc scan codes */ -#define COMMAND_RES5 0x20 /* bit 5, perhaps (!) use 9bit frame - * instead of 11 */ -#define COMMAND_DISABL 0x10 /* bit 4, 1 = disable keyboard */ -#define COMMAND_INHOVR 0x08 /* bit 3, 1 = override security lock inhibit */ -#define COMMAND_SYSFLG 0x04 /* bit 2, value stored as "system flag" */ -#define COMMAND_RES2 0x02 /* bit 1, reserved, always write a ZERO ! */ -#define COMMAND_IRQEN 0x01 /* bit 0, 1 = enable output buffer full - * interrupt */ - -/* status from CONTROLLER (8042) on the mainboard */ - -#define STATUS_PARITY 0x80 /* bit 7, 1 = parity error on last byte */ -#define STATUS_RXTIMO 0x40 /* bit 6, 1 = receive timeout error occured */ -#define STATUS_TXTIMO 0x20 /* bit 5, 1 = transmit timeout error occured */ -#define STATUS_ENABLE 0x10 /* bit 4, 1 = keyboard unlocked */ -#define STATUS_WHAT 0x08 /* bit 3, 1 = wrote cmd to 0x64, 0 = wrote - * data to 0x60 */ -#define STATUS_SYSFLG 0x04 /* bit 2, value stored as "system flag" */ -#define STATUS_INPBF 0x02 /* bit 1, 1 = input buffer full (to 8042) */ -#define STATUS_OUTPBF 0x01 /* bit 0, 1 = output buffer full (from 8042) */ - -/* commands to the KEYBOARD (via the 8042 controller on mainboard..) */ - -#define KEYB_C_RESET 0xff /* reset keyboard to power-on status */ -#define KEYB_C_RESEND 0xfe /* resend last byte in case of error */ -#define KEYB_C_TYPEM 0xf3 /* set keyboard typematic rate/delay */ -#define KEYB_C_ID 0xf2 /* return keyboard id */ -#define KEYB_C_ECHO 0xee /* diagnostic, echo 0xee */ -#define KEYB_C_LEDS 0xed /* set/reset numlock,capslock & scroll lock */ - -/* responses from the KEYBOARD (via the 8042 controller on mainboard..) */ - -#define KEYB_R_OVERRUN0 0x00 /* keyboard buffer overflow */ -#define KEYB_R_SELFOK 0xaa /* keyboard selftest ok after KEYB_C_RESET */ -#define KEYB_R_EXT0 0xe0 /* keyboard extended scancode prefix 1 */ -#define KEYB_R_EXT1 0xe1 /* keyboard extended scancode prefix 2 */ -#define KEYB_R_ECHO 0xee /* keyboard response to KEYB_C_ECHO */ -#define KEYB_R_BREAKPFX 0xf0 /* break code prefix for set 2 and 3 */ -#define KEYB_R_ACK 0xfa /* acknowledge after a command has rx'd */ -#define KEYB_R_SELFBAD 0xfc /*keyboard selftest FAILED after KEYB_C_RESET*/ -#define KEYB_R_DIAGBAD 0xfd /* keyboard self diagnostic failure */ -#define KEYB_R_RESEND 0xfe /* keyboard wants command resent or illegal - * command rx'd */ -#define KEYB_R_OVERRUN1 0xff /* keyboard buffer overflow */ - -/* MF II Keyboard id-byte #1 */ /* Default keybd's id-byte #1 */ -#define KEYB_R_MF2ID1 0xab -/* MF II Keyboard id-byte #2 */ -#define KEYB_R_MF2ID2 0x41 /* Default keybd's id-byte #2 */ -#define KEYB_R_MF2ID2TP 0x54 /* IBM ThinkPad 76X keybd's id-byte #2 */ -#define KEYB_R_MF2ID2HP 0x83 /* HP kybd's id-byte #2 */ - -/* internal Keyboard Type */ - -#define KB_UNKNOWN 0 /* unknown keyboard type */ -#define KB_AT 1 /* AT (84 keys) Keyboard */ -#define KB_MFII 2 /* MF II (101/102 keys) Keyboard */ - -/*---------------------------------------------------------------------------* - * CMOS ram access to get the "Equipment Byte" - *---------------------------------------------------------------------------*/ - -#define EQ_EGAVGA NVRAM_EQUIPMENT_EGAVGA -#define EQ_40COLOR NVRAM_EQUIPMENT_COLOR40 -#define EQ_80COLOR NVRAM_EQUIPMENT_COLOR80 -#define EQ_80MONO NVRAM_EQUIPMENT_MONO80 - -/*---------------------------------------------------------------------------* - * VT220 -> internal color conversion table fields - *---------------------------------------------------------------------------*/ - -#define VT_NORMAL 0x00 /* no attributes at all */ -#define VT_BOLD 0x01 /* bold attribute */ -#define VT_UNDER 0x02 /* underline attribute */ -#define VT_BLINK 0x04 /* blink attribute */ -#define VT_INVERSE 0x08 /* inverse attribute */ - -/*---------------------------------------------------------------------------* - * VGA GENERAL/EXTERNAL Registers (3BA or 3DA and 3CA, 3C2, 3CC) - *---------------------------------------------------------------------------*/ - -#define GN_MISCOUTR 0x3CC /* misc output register read */ -#define GN_MISCOUTW 0x3C2 /* misc output register write */ -#define GN_INPSTAT0 0x3C2 /* input status 0, r/o */ -#define GN_INPSTAT1M 0x3BA /* input status 1, r/o, mono */ -#define GN_INPSTAT1C 0x3DA /* input status 1, r/o, color */ -#define GN_FEATR 0x3CA /* feature control, read */ -#define GN_FEATWM 0x3BA /* feature control, write, mono */ -#define GN_FEATWC 0x3DA /* feature control, write, color */ -#define GN_VSUBSYS 0x3C3 /* video subsystem register r/w */ -#define GN_DMCNTLM 0x3B8 /* display mode control, r/w, mono */ -#define GN_DMCNTLC 0x3D8 /* display mode control, r/w, color */ -#define GN_COLORSEL 0x3D9 /* color select register, w/o */ -#define GN_HERCOMPAT 0x3BF /* Hercules compatibility reg, w/o */ - -/*---------------------------------------------------------------------------* - * VGA CRTC Registers (3B4 and 3B5 or 3D4 and 3D5) - *---------------------------------------------------------------------------*/ - -#define MONO_BASE 0x3B4 /* crtc index register address mono */ -#define CGA_BASE 0x3D4 /* crtc index register address color */ - -#define CRTC_ADDR 0x00 /* index register */ - -#define CRTC_HTOTAL 0x00 /* horizontal total */ -#define CRTC_HDISPLE 0x01 /* horizontal display end */ -#define CRTC_HBLANKS 0x02 /* horizontal blank start */ -#define CRTC_HBLANKE 0x03 /* horizontal blank end */ -#define CRTC_HSYNCS 0x04 /* horizontal sync start */ -#define CRTC_HSYNCE 0x05 /* horizontal sync end */ -#define CRTC_VTOTAL 0x06 /* vertical total */ -#define CRTC_OVERFLL 0x07 /* overflow low */ -#define CRTC_IROWADDR 0x08 /* inital row address */ -#define CRTC_MAXROW 0x09 /* maximum row address */ -#define CRTC_CURSTART 0x0A /* cursor start row address */ -#define CURSOR_ON_BIT 0x20 /* cursor on/off on mda/cga/vga */ -#define CRTC_CUREND 0x0B /* cursor end row address */ -#define CRTC_STARTADRH 0x0C /* linear start address mid */ -#define CRTC_STARTADRL 0x0D /* linear start address low */ -#define CRTC_CURSORH 0x0E /* cursor address mid */ -#define CRTC_CURSORL 0x0F /* cursor address low */ -#define CRTC_VSYNCS 0x10 /* vertical sync start */ -#define CRTC_VSYNCE 0x11 /* vertical sync end */ -#define CRTC_VDE 0x12 /* vertical display end */ -#define CRTC_OFFSET 0x13 /* row offset */ -#define CRTC_ULOC 0x14 /* underline row address */ -#define CRTC_VBSTART 0x15 /* vertical blank start */ -#define CRTC_VBEND 0x16 /* vertical blank end */ -#define CRTC_MODE 0x17 /* CRTC mode register */ -#define CRTC_SPLITL 0x18 /* split screen start low */ - -/* start of ET4000 extensions */ - -#define CRTC_RASCAS 0x32 /* ras/cas configuration */ -#define CRTC_EXTSTART 0x33 /* extended start address */ -#define CRTC_COMPAT6845 0x34 /* 6845 comatibility control */ -#define CRTC_OVFLHIGH 0x35 /* overflow high */ -#define CRTC_SYSCONF1 0x36 /* video system configuration 1 */ -#define CRTC_SYSCONF2 0x36 /* video system configuration 2 */ - -/* start of WD/Paradise extensions */ - -#define CRTC_PR10 0x29 /* r/w unlocking */ -#define CRTC_PR11 0x2A /* ega switches */ -#define CRTC_PR12 0x2B /* scratch pad */ -#define CRTC_PR13 0x2C /* interlace h/2 start */ -#define CRTC_PR14 0x2D /* interlace h/2 end */ -#define CRTC_PR15 0x2E /* misc control #1 */ -#define CRTC_PR16 0x2F /* misc control #2 */ -#define CRTC_PR17 0x30 /* misc control #3 */ - /* 0x31 .. 0x3f reserved */ -/* Video 7 */ - -#define CRTC_V7ID 0x1f /* identification register */ - -/* Trident */ - -#define CRTC_MTEST 0x1e /* module test register */ -#define CRTC_SOFTPROG 0x1f /* software programming */ -#define CRTC_LATCHRDB 0x22 /* latch read back register */ -#define CRTC_ATTRSRDB 0x24 /* attribute state read back register*/ -#define CRTC_ATTRIRDB 0x26 /* attribute index read back register*/ -#define CRTC_HOSTAR 0x27 /* high order start address register */ - -/*---------------------------------------------------------------------------* - * VGA TIMING & SEQUENCER Registers (3C4 and 3C5) - *---------------------------------------------------------------------------*/ - -#define TS_INDEX 0x3C4 /* index register */ -#define TS_DATA 0x3C5 /* data register */ - -#define TS_SYNCRESET 0x00 /* synchronous reset */ -#define TS_MODE 0x01 /* ts mode register */ -#define TS_WRPLMASK 0x02 /* write plane mask */ -#define TS_FONTSEL 0x03 /* font select register */ -#define TS_MEMMODE 0x04 /* memory mode register */ - -/* ET4000 only */ - -#define TS_RESERVED 0x05 /* undef, reserved */ -#define TS_STATECNTL 0x06 /* state control register */ -#define TS_AUXMODE 0x07 /* auxiliary mode control */ - -/* WD/Paradise only */ - -#define TS_UNLOCKSEQ 0x06 /* PR20 - unlock sequencer register */ -#define TS_DISCFSTAT 0x07 /* PR21 - display config status */ -#define TS_MEMFIFOCTL 0x10 /* PR30 - memory i/f & fifo control */ -#define TS_SYSIFCNTL 0x11 /* PR31 - system interface control */ -#define TS_MISC4 0x12 /* PR32 - misc control #4 */ - -/* Video 7 */ - -#define TS_EXTCNTL 0x06 /* extensions control */ -#define TS_CLRVDISP 0x30 /* clear vertical display 0x30-0x3f */ -#define TS_V7CHIPREV 0x8e /* chipset revision 0x8e-0x8f */ -#define TS_SWBANK 0xe8 /* single/write bank register, rev 5+*/ -#define TS_RDBANK 0xe8 /* read bank register, rev 4+ */ -#define TS_MISCCNTL 0xe8 /* misc control register, rev 4+ */ -#define TS_SWSTROBE 0xea /* switch strobe */ -#define TS_MWRCNTL 0xf3 /* masked write control */ -#define TS_MWRMVRAM 0xf4 /* masked write mask VRAM only */ -#define TS_BANKSEL 0xf6 /* bank select */ -#define TS_SWREADB 0xf7 /* switch readback */ -#define TS_PAGESEL 0xf9 /* page select */ -#define TS_COMPAT 0xfc /* compatibility control */ -#define TS_16BITCTL 0xff /* 16 bit interface control */ - -/* Trident */ - -#define TS_HWVERS 0x0b /* hardware version, switch old/new! */ -#define TS_CONFPORT1 0x0c /* config port 1 and 2 - caution! */ -#define TS_MODEC2 0x0d /* old/new mode control 2 - caution! */ -#define TS_MODEC1 0x0e /* old/new mode control 1 - caution! */ -#define TS_PUPM2 0x0f /* power up mode 2 */ - -/*---------------------------------------------------------------------------* - * VGA GRAPHICS DATA CONTROLLER Registers (3CE, 3CF and 3CD) - *---------------------------------------------------------------------------*/ - -#define GDC_SEGSEL 0x3CD /* segment select register */ -#define GDC_INDEX 0x3CE /* index register */ -#define GDC_DATA 0x3CF /* data register */ - -#define GDC_SETRES 0x00 /* set / reset bits */ -#define GDC_ENSETRES 0x01 /* enable set / reset */ -#define GDC_COLORCOMP 0x02 /* color compare register */ -#define GDC_ROTFUNC 0x03 /* data rotate / function select */ -#define GDC_RDPLANESEL 0x04 /* read plane select */ -#define GDC_MODE 0x05 /* gdc mode register */ -#define GDC_MISC 0x06 /* gdc misc register */ -#define GDC_COLORCARE 0x07 /* color care register */ -#define GDC_BITMASK 0x08 /* bit mask register */ - -/* WD/Paradise only */ - -#define GDC_BANKSWA 0x09 /* PR0A - bank switch a */ -#define GDC_BANKSWB 0x0a /* PR0B - bank switch b */ -#define GDC_MEMSIZE 0x0b /* PR1 memory size */ -#define GDC_VIDEOSEL 0x0c /* PR2 video configuration */ -#define GDC_CRTCNTL 0x0d /* PR3 crt address control */ -#define GDC_VIDEOCNTL 0x0e /* PR4 video control */ -#define GDC_PR5GPLOCK 0x0f /* PR5 gp status and lock */ - -/* Video 7 */ - -#define GDC_DATALATCH 0x22 /* gdc data latch */ - -/*---------------------------------------------------------------------------* - * VGA ATTRIBUTE CONTROLLER Registers (3C0 and 3C1) - *---------------------------------------------------------------------------*/ - -#define ATC_INDEX 0x3C0 /* index register AND */ -#define ATC_DATAW 0x3C0 /* data write !!! */ -#define ATC_DATAR 0x3C1 /* data read */ - -#define ATC_ACCESS 0x20 /* access bit in ATC index register */ - -#define ATC_PALETTE0 0x00 /* color palette register 0 */ -#define ATC_PALETTE1 0x01 /* color palette register 1 */ -#define ATC_PALETTE2 0x02 /* color palette register 2 */ -#define ATC_PALETTE3 0x03 /* color palette register 3 */ -#define ATC_PALETTE4 0x04 /* color palette register 4 */ -#define ATC_PALETTE5 0x05 /* color palette register 5 */ -#define ATC_PALETTE6 0x06 /* color palette register 6 */ -#define ATC_PALETTE7 0x07 /* color palette register 7 */ -#define ATC_PALETTE8 0x08 /* color palette register 8 */ -#define ATC_PALETTE9 0x09 /* color palette register 9 */ -#define ATC_PALETTEA 0x0A /* color palette register 10 */ -#define ATC_PALETTEB 0x0B /* color palette register 11 */ -#define ATC_PALETTEC 0x0C /* color palette register 12 */ -#define ATC_PALETTED 0x0D /* color palette register 13 */ -#define ATC_PALETTEE 0x0E /* color palette register 14 */ -#define ATC_PALETTEF 0x0F /* color palette register 15 */ -#define ATC_MODE 0x10 /* atc mode register */ -#define ATC_OVERSCAN 0x11 /* overscan register */ -#define ATC_COLPLEN 0x12 /* color plane enable register */ -#define ATC_HORPIXPAN 0x13 /* horizontal pixel panning */ -#define ATC_COLRESET 0x14 /* color reset */ -#define ATC_MISC 0x16 /* misc register (ET3000/ET4000) */ - -/*---------------------------------------------------------------------------* - * VGA palette handling (output DAC palette) - *---------------------------------------------------------------------------*/ - -#define VGA_DAC 0x3C6 /* vga dac address */ -#define VGA_PMSK 0x3F /* palette mask, 64 distinct values */ -#define NVGAPEL 256 /* number of palette entries */ - -/*---------------------------------------------------------------------------* - * function key labels - *---------------------------------------------------------------------------*/ - -#define LABEL_LEN 9 /* length of one label */ -#define LABEL_MID 8 /* mid-part (row/col) */ - -#define LABEL_ROWH ((4*LABEL_LEN)+1) -#define LABEL_ROWL ((4*LABEL_LEN)+2) -#define LABEL_COLU ((4*LABEL_LEN)+4) -#define LABEL_COLH ((4*LABEL_LEN)+5) -#define LABEL_COLL ((4*LABEL_LEN)+6) - -/* tab setting */ - -#define MAXTAB 132 /* no of possible tab stops */ - -/* escape detection state machine */ - -#define STATE_INIT 0 /* normal */ -#define STATE_ESC 1 /* got ESC */ -#define STATE_BLANK 2 /* got ESC space*/ -#define STATE_HASH 3 /* got ESC # */ -#define STATE_BROPN 4 /* got ESC ( */ -#define STATE_BRCLO 5 /* got ESC ) */ -#define STATE_CSI 6 /* got ESC [ */ -#define STATE_CSIQM 7 /* got ESC [ ? */ -#define STATE_AMPSND 8 /* got ESC & */ -#define STATE_STAR 9 /* got ESC * */ -#define STATE_PLUS 10 /* got ESC + */ -#define STATE_DCS 11 /* got ESC P */ -#define STATE_DQUOTE 12 /* got ESC " */ -#define STATE_STR 13 /* got ESC ! */ -#define STATE_MINUS 14 /* got ESC - */ -#define STATE_DOT 15 /* got ESC . */ -#define STATE_SLASH 16 /* got ESC / */ - -/* for storing escape sequence parameters */ - -#define MAXPARMS 10 /* maximum no of parms */ - -/* terminal responses */ - -#define DA_VT220 "\033[?62;1;2;6;7;8;9c" - -/* sub-states for Device Control String processing */ - -#define DCS_INIT 0 /* got ESC P ... */ -#define DCS_AND_UDK 1 /* got ESC P ... | */ -#define DCS_UDK_DEF 2 /* got ESC P ... | fnckey / */ -#define DCS_UDK_ESC 3 /* got ESC P ... | fnckey / ... ESC */ -#define DCS_DLD_DSCS 4 /* got ESC P ... { */ -#define DCS_DLD_DEF 5 /* got ESC P ... { dscs */ -#define DCS_DLD_ESC 6 /* got ESC P ... { dscs ... / ... ESC */ - -/* vt220 user defined keys and vt220 downloadable charset */ - -#define MAXUDKDEF 300 /* max 256 char + 1 '\0' + space.. */ -#define MAXUDKEYS 18 /* plus holes .. */ -#define DSCS_LENGTH 3 /* descriptor length */ -#define MAXSIXEL 8 /* sixels forever ! */ - -/* sub-states for HP-terminal emulator */ - -#define SHP_INIT 0 - -/* esc & f family */ - -#define SHP_AND_F 1 -#define SHP_AND_Fa 2 -#define SHP_AND_Fak 3 -#define SHP_AND_Fak1 4 -#define SHP_AND_Fakd 5 -#define SHP_AND_FakdL 6 -#define SHP_AND_FakdLl 7 -#define SHP_AND_FakdLls 8 - -/* esc & j family */ - -#define SHP_AND_J 9 -#define SHP_AND_JL 10 - -/* esc & every-thing-else */ - -#define SHP_AND_ETE 11 - -/* additionals for function key labels */ - -#define MAX_LABEL 16 -#define MAX_STRING 80 -#define MAX_STATUS 160 - -/* MAX values for screen sizes for possible video adaptors */ - -#define MAXROW_MDACGA 25 /* MDA/CGA can do 25 x 80 max */ -#define MAXCOL_MDACGA 80 - -#define MAXROW_EGA 43 /* EGA can do 43 x 80 max */ -#define MAXCOL_EGA 80 - -#define MAXROW_VGA 50 /* VGA can do 50 x 80 max */ -#define MAXCOL_VGA 80 -#define MAXCOL_SVGA 132 /* Super VGA can do 50 x 132 max */ - -/* switch 80/132 columns */ - -#define SCR_COL80 80 /* in 80 col mode */ -#define SCR_COL132 132 /* in 132 col mode */ - -#define MAXDECSCA (((MAXCOL_SVGA * MAXROW_VGA) \ - / (8 * sizeof(unsigned int)) ) + 1 ) - -/* screen memory start, monochrome */ - -#ifndef MONO_BUF -# define MONO_BUF 0xfe0B0000 /* NetBSD-current: isa.h */ -#endif - -/* screen memory start, color */ - -#ifndef CGA_BUF -# define CGA_BUF 0xfe0B8000 /* NetBSD-current: isa.h */ -#endif - -#define CHR 2 /* bytes per word in screen mem */ - -#define NVGAFONTS 8 /* number of vga fonts loadable */ - -#define MAXKEYNUM 127 /* max no of keys in table */ - -/* charset tables */ - -#define CSL 0x0000 /* ega/vga charset, lower half of 512 */ -#define CSH 0x0800 /* ega/vga charset, upper half of 512 */ -#define CSSIZE 96 /* (physical) size of a character set */ - -/* charset designations */ - -#define D_G0 0 /* designated as G0 */ -#define D_G1 1 /* designated as G1 */ -#define D_G2 2 /* designated as G2 */ -#define D_G3 3 /* designated as G3 */ -#define D_G1_96 4 /* designated as G1 for 96-char charsets */ -#define D_G2_96 5 /* designated as G2 for 96-char charsets */ -#define D_G3_96 6 /* designated as G3 for 96-char charsets */ - -/* which fkey-labels */ - -#define SYS_FKL 0 /* in hp mode, sys-fkls are active */ -#define USR_FKL 1 /* in hp mode, user-fkls are active */ - -/* variables */ - -#ifdef EXTERN -#define WAS_EXTERN -#else -#define EXTERN extern -#endif - -EXTERN u_char *more_chars; /* response buffer via kbd */ -EXTERN int char_count; /* response char count */ -EXTERN u_char color; /* color or mono display */ - -EXTERN u_short kern_attr; /* kernel messages char attributes */ -EXTERN u_short user_attr; /* character attributes */ - -struct sixels { - u_char lower[MAXSIXEL]; /* lower half of char */ - u_char upper[MAXSIXEL]; /* upper half of char */ -}; - -struct udkentry { - u_char first[MAXUDKEYS]; /* index to first char */ - u_char length[MAXUDKEYS]; /* length of this entry */ -}; - -/* VGA palette handling */ -struct rgb { - u_char r, g, b; /* red/green/blue, valid 0..VGA_PMSK */ -}; - -typedef struct video_state { - u_short *Crtat; /* video page start addr */ - u_short *Memory; /* malloc'ed memory start address */ - struct tty *vs_tty; /* pointer to this screen's tty */ - u_char maxcol; /* 80 or 132 cols on screen */ - u_char row, col; /* current cursor position */ - u_short c_attr; /* current character attributes */ - u_char vtsgr; /* current sgr configuration */ - u_short cur_offset; /* current cursor position offset */ - u_char bell_on; /* flag, bell enabled */ - u_char sevenbit; /* flag, data path 7 bits wide */ - u_char dis_fnc; /* flag, display functions enable */ - u_char transparent; /* flag, mk path tmp trnsprnt for ctls*/ - u_char C1_ctls; /* flag, process C1 ctls */ - u_char scrr_beg; /* scrolling region, begin */ - u_char scrr_len; /* scrolling region, length */ - u_char scrr_end; /* scrolling region, end */ - u_char screen_rows; /* screen size, length - status lines */ - u_char screen_rowsize; /* screen size, length */ - u_char vga_charset; /* VGA character set value */ - u_char lastchar; /* flag, vt100 behaviour of last char */ - u_char lastrow; /* save row, --------- " ----------- */ - u_char *report_chars; /* ptr, status reports from terminal */ - u_char report_count; /* count, ----------- " ------------ */ - u_char state; /* escape sequence state machine */ - u_char m_awm; /* flag, vt100 mode, auto wrap */ - u_char m_om; /* flag, vt100 mode, origin mode */ - u_char sc_flag; /* flag, vt100 mode,saved parms valid */ - u_char sc_row; /* saved row */ - u_char sc_col; /* saved col */ - u_short sc_cur_offset; /* saved cursor addr offset */ - u_short sc_attr; /* saved attributes */ - u_char sc_vtsgr; /* saved sgr configuration */ - u_char sc_awm; /* saved auto wrap mode */ - u_char sc_om; /* saved origin mode */ - u_short *sc_G0; /* save G0 ptr */ - u_short *sc_G1; /* save G1 ptr */ - u_short *sc_G2; /* save G2 ptr */ - u_short *sc_G3; /* save G3 ptr */ - u_short *sc_GL; /* save GL ptr */ - u_short *sc_GR; /* save GR ptr */ - u_char sc_sel; /* selective erase state */ - u_char ufkl[8][17]; /* user fkey-labels */ - u_char sfkl[8][17]; /* system fkey-labels */ - u_char labels_on; /* display fkey labels etc. on/off */ - u_char which_fkl; /* which fkey labels are active */ - char tab_stops[MAXTAB]; /* table of active tab stops */ - u_char parmi; /* parameter index */ - u_char parms[MAXPARMS]; /* parameter array */ - u_char hp_state; /* hp escape sequence state machine */ - u_char attribute; /* attribute normal, tx only, local */ - u_char key; /* fkey label no */ - u_char l_len; /* buffer length's */ - u_char s_len; - u_char m_len; - u_char i; /* help (got short of names ...) */ - u_char l_buf[MAX_LABEL+1]; /* buffers */ - u_char s_buf[MAX_STRING+1]; - u_char m_buf[MAX_STATUS+1]; - u_char openf; /* we are opened ! */ - u_char vt_pure_mode; /* no fkey labels, row/col, status */ - u_char cursor_start; /* Start of cursor */ - u_char cursor_end; /* End of cursor */ - u_char cursor_on; /* cursor switched on */ - u_char ckm; /* true = cursor key normal mode */ - u_char irm; /* true = insert mode */ - u_char lnm; /* Line Feed/New Line Mode */ - u_char dcs_state; /* dcs escape sequence state machine */ - u_char udk_def[MAXUDKDEF]; /* new definitions for vt220 FKeys */ - u_char udk_defi; /* index for FKey definitions */ - u_char udk_deflow; /* low or high nibble in sequence */ - u_char udk_fnckey; /* function key to assign to */ - u_char dld_dscs[DSCS_LENGTH]; /* designate soft character set id */ - u_char dld_dscsi; /* index for dscs */ - u_char dld_sixel_lower; /* upper/lower sixels of character */ - u_char dld_sixelli; /* index for lower sixels */ - u_char dld_sixelui; /* index for upper sixels */ - struct sixels sixel; /* structure for storing char sixels */ - u_char selchar; /* true = selective attribute on */ - u_int decsca[MAXDECSCA]; /* Select Character Attrib bit array */ - u_short *GL; /* ptr to current GL conversion table*/ - u_short *GR; /* ptr to current GR conversion table*/ - u_short *G0; /* ptr to current G0 conversion table*/ - u_short *G1; /* ptr to current G1 conversion table*/ - u_char force24; /* force 24 lines in DEC 25 and HP 28*/ - u_short *G2; /* ptr to current G2 conversion table*/ - u_short *G3; /* ptr to current G3 conversion table*/ - u_char dld_id[DSCS_LENGTH+1]; /* soft character set id */ - u_char which[DSCS_LENGTH+1]; /* which set to designate */ - u_char whichi; /* index into which .. */ - u_char ss; /* flag, single shift G2 / G3 -> GL */ - u_short *Gs; /* ptr to cur. G2/G3 conversion table*/ - u_char udkbuf[MAXUDKDEF]; /* buffer for user defined keys */ - struct udkentry ukt; /* index & length for each udk */ - u_char udkff; /* index into buffer first free entry*/ - struct rgb palette[NVGAPEL]; /* saved VGA DAC palette */ - u_char wd132col; /* we are on a wd vga and in 132 col */ - u_char scroll_lock; /* scroll lock active */ - u_char caps_lock; /* caps lock active */ - u_char shift_lock; /* shiftlock flag (virtual ..) */ - u_char num_lock; /* num lock, true = keypad num mode */ - u_char abs_write; /* write outside of scroll region */ - struct vt_mode smode; /* screen mode */ - struct proc *proc; /* current process */ - pid_t pid; /* current process id */ - unsigned vt_status; /* state of the vt */ - /* becoming active */ - int kbd_state; /* keyboard raw or translated */ -} video_state; - -EXTERN video_state vs[PCVT_NSCREENS]; /* parameters for screens */ - -/* used to be able to pass ERESTART on properly */ -#define PCVT_ERESTART (ELAST + 1) - -/* possible states for video_state.vt_status: */ - -#define VT_WAIT_REL 1 /* wait till process released vt */ -#define VT_WAIT_ACK 2 /* wait till process ack vt acquire */ -#define VT_GRAFX 4 /* vt runs graphics mode */ -#define VT_WAIT_ACT 8 /* a process is sleeping on this vt */ - -/* struct describing one slot in the font ram */ - -struct vga_char_state { - int loaded; /* Whether a font is loaded here */ - int secondloaded; /* an extension characterset was loaded, */ - /* the number is found here */ - u_char char_scanlines; /* Scanlines per character */ - u_char scr_scanlines; /* Low byte of scanlines per screen */ - int screen_size; /* Screen size in SIZ_YYROWS */ -}; - -EXTERN struct vga_char_state vgacs[NVGAFONTS]; /* Character set states */ - -#if PCVT_EMU_MOUSE -struct mousestat { - struct timeval lastmove; /* last time the pointer moved */ - u_char opened; /* someone would like to use a mouse */ - u_char minor; /* minor device number */ - u_char buttons; /* current "buttons" pressed */ - u_char extendedseen; /* 0xe0 has been seen, do not use next key */ - u_char breakseen; /* key break has been seen for a sticky btn */ -}; -#endif /* PCVT_EMU_MOUSE */ - -#ifdef WAS_EXTERN - -struct vt_softc { - struct device sc_dev; - void *sc_ih; -}; - -int pcprobe(struct device *, struct cfdata *, void *); -void pcattach(struct device *, struct device *, void *); - -struct cfattach vt_ca = { - sizeof(struct vt_softc), pcprobe, pcattach -}; - -extern struct cfdriver vt_cd; - - -u_char fgansitopc[] = { /* foreground ANSI color -> pc */ - FG_BLACK, FG_RED, FG_GREEN, FG_BROWN, FG_BLUE, - FG_MAGENTA, FG_CYAN, FG_LIGHTGREY -}; - -u_char bgansitopc[] = { /* background ANSI color -> pc */ - BG_BLACK, BG_RED, BG_GREEN, BG_BROWN, BG_BLUE, - BG_MAGENTA, BG_CYAN, BG_LIGHTGREY -}; - -struct tty *pcconsp; /* ptr to current device, see pcattach() */ - -u_short *Crtat; /* screen start address */ - -#if PCVT_EMU_MOUSE -struct mousestat mouse = {0}; -struct mousedefs mousedef = {0x3b, 0x3c, 0x3d, 0, 250000}; -#endif /* PCVT_EMU_MOUSE */ /* F1, F2, F3, false, 0.25 sec */ - -video_state *vsp = &vs[0]; /* ptr to current screen parms */ - -int vt_switch_pending = 0; /* if > 0, a vt switch is */ - /* of the old vt + 1 */ -u_int addr_6845 = MONO_BASE; /* crtc base addr */ -u_char do_initialization = 1; /* we have to init ourselves */ -u_char pcvt_is_console = 0; /* until we know it */ -u_char shift_down = 0; /* shift key down flag */ -u_char ctrl_down = 0; /* ctrl key down flag */ -u_char meta_down = 0; /* alt key down flag */ -u_char altgr_down = 0; /* altgr key down flag */ -u_char kbrepflag = 1; /* key repeat flag */ -u_char totalscreens = 1; /* screens available */ -u_char current_video_screen = 0; /* displayed screen no */ -u_char adaptor_type = UNKNOWN_ADAPTOR;/* adaptor type */ -u_char vga_type = VGA_UNKNOWN; /* vga chipset */ -u_char can_do_132col = 0; /* vga chipset can 132 cols */ -u_char vga_family = 0; /* vga manufacturer */ -u_char totalfonts = 0; /* fonts available */ -u_char chargen_access = 0; /* synchronize access */ -u_char keyboard_type = KB_UNKNOWN; /* type of keyboard */ -u_char keyboard_is_initialized = 0; /* for ddb sanity */ -u_char kbd_polling = 0; /* keyboard is being polled */ - -#if PCVT_SHOWKEYS -u_char keyboard_show = 0; /* normal display */ -#endif /* PCVT_SHOWKEYS */ - -u_char cursor_pos_valid = 0; /* sput left a valid position*/ - -u_char critical_scroll = 0; /* inside scrolling up */ -int switch_page = -1; /* which page to switch to */ - -#if PCVT_SCREENSAVER -u_char reset_screen_saver = 1; /* reset the saver next time */ -u_char scrnsv_active = 0; /* active flag */ -unsigned scrnsv_timeout = 0; /* initially off */ -#endif /* XSERVER || PCVT_SCREENSAVER */ - -#if PCVT_BACKUP_FONTS -u_char *saved_charsets[NVGAFONTS] = {0}; /* backup copy of fonts */ -#endif /* PCVT_BACKUP_FONTS */ - -/*--------------------------------------------------------------------------- - - VT220 attributes -> internal emulator attributes conversion tables - - be careful when designing color combinations, because on - EGA and VGA displays, bit 3 of the attribute byte is used - for characterset switching, and is no longer available for - foreground intensity (bold)! - ----------------------------------------------------------------------------*/ - -/* color displays */ - -u_char sgr_tab_color[16] = { -/*00*/ (BG_BLACK | FG_LIGHTGREY), /* normal */ -/*01*/ (BG_BLUE | FG_LIGHTGREY), /* bold */ -/*02*/ (BG_BROWN | FG_LIGHTGREY), /* underline */ -/*03*/ (BG_MAGENTA | FG_LIGHTGREY), /* bold+underline */ -/*04*/ (BG_BLACK | FG_LIGHTGREY | FG_BLINK), /* blink */ -/*05*/ (BG_BLUE | FG_LIGHTGREY | FG_BLINK), /* bold+blink */ -/*06*/ (BG_BROWN | FG_LIGHTGREY | FG_BLINK), /* underline+blink */ -/*07*/ (BG_MAGENTA | FG_LIGHTGREY | FG_BLINK), /* bold+underline+blink */ -/*08*/ (BG_LIGHTGREY | FG_BLACK), /* invers */ -/*09*/ (BG_LIGHTGREY | FG_BLUE), /* bold+invers */ -/*10*/ (BG_LIGHTGREY | FG_BROWN), /* underline+invers */ -/*11*/ (BG_LIGHTGREY | FG_MAGENTA), /* bold+underline+invers*/ -/*12*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK), /* blink+invers */ -/*13*/ (BG_LIGHTGREY | FG_BLUE | FG_BLINK), /* bold+blink+invers */ -/*14*/ (BG_LIGHTGREY | FG_BROWN | FG_BLINK), /* underline+blink+invers*/ -/*15*/ (BG_LIGHTGREY | FG_MAGENTA | FG_BLINK) /*bold+underl+blink+invers*/ -}; - -/* monochrome displays (VGA version, no intensity) */ - -u_char sgr_tab_mono[16] = { -/*00*/ (BG_BLACK | FG_LIGHTGREY), /* normal */ -/*01*/ (BG_BLACK | FG_UNDERLINE), /* bold */ -/*02*/ (BG_BLACK | FG_UNDERLINE), /* underline */ -/*03*/ (BG_BLACK | FG_UNDERLINE), /* bold+underline */ -/*04*/ (BG_BLACK | FG_LIGHTGREY | FG_BLINK), /* blink */ -/*05*/ (BG_BLACK | FG_UNDERLINE | FG_BLINK), /* bold+blink */ -/*06*/ (BG_BLACK | FG_UNDERLINE | FG_BLINK), /* underline+blink */ -/*07*/ (BG_BLACK | FG_UNDERLINE | FG_BLINK), /* bold+underline+blink */ -/*08*/ (BG_LIGHTGREY | FG_BLACK), /* invers */ -/*09*/ (BG_LIGHTGREY | FG_BLACK), /* bold+invers */ -/*10*/ (BG_LIGHTGREY | FG_BLACK), /* underline+invers */ -/*11*/ (BG_LIGHTGREY | FG_BLACK), /* bold+underline+invers*/ -/*12*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK), /* blink+invers */ -/*13*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK), /* bold+blink+invers */ -/*14*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK), /* underline+blink+invers*/ -/*15*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK) /*bold+underl+blink+invers*/ -}; - -/* monochrome displays (MDA version, with intensity) */ - -u_char sgr_tab_imono[16] = { -/*00*/ (BG_BLACK | FG_LIGHTGREY), /* normal */ -/*01*/ (BG_BLACK | FG_LIGHTGREY | FG_INTENSE), /* bold */ -/*02*/ (BG_BLACK | FG_UNDERLINE), /* underline */ -/*03*/ (BG_BLACK | FG_UNDERLINE | FG_INTENSE), /* bold+underline */ -/*04*/ (BG_BLACK | FG_LIGHTGREY | FG_BLINK), /* blink */ -/*05*/ (BG_BLACK | FG_LIGHTGREY | FG_INTENSE | FG_BLINK), /* bold+blink */ -/*06*/ (BG_BLACK | FG_UNDERLINE | FG_BLINK), /* underline+blink */ -/*07*/ (BG_BLACK | FG_UNDERLINE | FG_BLINK | FG_INTENSE), /* bold+underline+blink */ -/*08*/ (BG_LIGHTGREY | FG_BLACK), /* invers */ -/*09*/ (BG_LIGHTGREY | FG_BLACK | FG_INTENSE), /* bold+invers */ -/*10*/ (BG_LIGHTGREY | FG_BLACK), /* underline+invers */ -/*11*/ (BG_LIGHTGREY | FG_BLACK | FG_INTENSE), /* bold+underline+invers*/ -/*12*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK), /* blink+invers */ -/*13*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK | FG_INTENSE),/* bold+blink+invers*/ -/*14*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK), /* underline+blink+invers*/ -/*15*/ (BG_LIGHTGREY | FG_BLACK | FG_BLINK | FG_INTENSE) /* bold+underl+blink+invers */ -}; - -#else /* WAS_EXTERN */ - -extern u_char vga_type; -extern struct tty *pcconsp; -extern video_state *vsp; - -#if PCVT_EMU_MOUSE -extern struct mousestat mouse; -extern struct mousedefs mousedef; -#endif /* PCVT_EMU_MOUSE */ - -extern int vt_switch_pending; -extern u_int addr_6845; -extern u_short *Crtat; -extern struct isa_driver vtdriver; -extern u_char do_initialization; -extern u_char pcvt_is_console; -extern u_char bgansitopc[]; -extern u_char fgansitopc[]; -extern u_char shift_down; -extern u_char ctrl_down; -extern u_char meta_down; -extern u_char altgr_down; -extern u_char kbrepflag; -extern u_char adaptor_type; -extern u_char current_video_screen; -extern u_char totalfonts; -extern u_char totalscreens; -extern u_char chargen_access; -extern u_char keyboard_type; -extern u_char can_do_132col; -extern u_char vga_family; -extern u_char keyboard_is_initialized; -extern u_char kbd_polling; - -#if PCVT_SHOWKEYS -extern u_char keyboard_show; -#endif /* PCVT_SHOWKEYS */ - -u_char cursor_pos_valid; - -u_char critical_scroll; -int switch_page; - -#if PCVT_SCREENSAVER -u_char reset_screen_saver; -u_char scrnsv_active; -#endif /* PCVT_SCREENSAVER */ - -extern u_char sgr_tab_color[]; -extern u_char sgr_tab_mono[]; -extern u_char sgr_tab_imono[]; - -#if defined(XSERVER) || PCVT_SCREENSAVER -extern unsigned scrnsv_timeout; -#endif /* XSERVER || PCVT_SCREENSAVER */ - -#if PCVT_BACKUP_FONTS -extern u_char *saved_charsets[NVGAFONTS]; -#endif /* PCVT_BACKUP_FONTS */ - -#endif /* WAS_EXTERN */ - -/* - * FreeBSD > 1.0.2 cleaned up the kernel definitions (with the aim of - * getting ANSI-clean). Since there has been a mixed usage of types like - * "dev_t" (actually some short) in prototyped and non-prototyped fasion, - * each of those types is declared as "int" within function prototypes - * (which is what the compiler would actually promote it to). - * - * The macros below are used to clarify which type a parameter ought to - * be, regardless of its actual promotion to "int". - */ - - -#define Dev_t int -#define U_short int -#define U_char int - -/* - * In FreeBSD >= 2.0 and NetBSD >= 1.1, dev_t has type - * `unsigned long' (FreeBSD) or `int32_t' or `u_int32_t' (NetBSD) - * so promoting it doesn't cause any problems in prototypes. - */ - -#undef Dev_t -#define Dev_t dev_t - -#define TIMEOUT_FUNC_T void * - -extern void bcopyb(void *from, void *to, u_int length); - -int pcopen ( Dev_t dev, int flag, int mode, struct proc *p ); -int pcclose ( Dev_t dev, int flag, int mode, struct proc *p ); -int pcread ( Dev_t dev, struct uio *uio, int flag ); -int pcwrite ( Dev_t dev, struct uio *uio, int flag ); -int pcioctl ( Dev_t dev, int cmd, caddr_t data, int flag, struct proc *p ); -int pcmmap ( Dev_t dev, int offset, int nprot ); - -struct tty * - pctty ( Dev_t dev ); -int pcintr ( void *arg); -void pccnprobe ( struct consdev *cp ); -void pccninit ( struct consdev *cp ); -void pccnputc ( Dev_t dev, U_char c ); -int pccngetc ( Dev_t dev ); - -int pcparam ( struct tty *tp, struct termios *t ); -void pcstart ( struct tty *tp ); -void pcstop ( struct tty *tp, int flag ); - -void switch_screen ( int n, int oldgrafx, int newgrafx ); -int usl_vt_ioctl (Dev_t dev,int cmd,caddr_t data,int flag,struct proc *); -int vt_activate ( int newscreen ); -int vgapage ( int n ); -void get_usl_keymap( keymap_t *map ); -void reset_usl_modes (struct video_state *vsx); - -#if PCVT_EMU_MOUSE -int mouse_ioctl ( Dev_t dev, int cmd, caddr_t data ); -#endif /* PCVT_EMU_MOUSE */ - -#if PCVT_SCREENSAVER -void pcvt_scrnsv_reset ( void ); -#endif /* PCVT_SCREENSAVER */ - -#if PCVT_SCREENSAVER -void pcvt_set_scrnsv_tmo ( int ); -#endif /* PCVT_SCREENSAVER */ - -void async_update ( void ); -void clr_parms ( struct video_state *svsp ); -void cons_highlight ( void ); -void cons_normal ( void ); -int egavga_test ( void ); -void fkl_off ( struct video_state *svsp ); -void fkl_on ( struct video_state *svsp ); -struct tty *get_pccons ( Dev_t dev ); -void init_sfkl ( struct video_state *svsp ); -void init_ufkl ( struct video_state *svsp ); -int kbd_cmd ( int val ); -void kbd_code_init ( void ); -void kbd_code_init1 ( void ); -void kbd_setmode(int mode); -int kbdioctl ( Dev_t dev, int cmd, caddr_t data, int flag ); -void loadchar ( int fontset, int character, int char_scanlines, - u_char *char_table ); -void mda2egaorvga ( void ); -void roll_up ( struct video_state *svsp, int n ); -void select_vga_charset ( int vga_charset ); -void set_2ndcharset ( void ); -void set_charset ( struct video_state *svsp, int curvgacs ); -void set_emulation_mode ( struct video_state *svsp, int mode ); -void set_screen_size ( struct video_state *svsp, int size ); -u_char *sgetc ( int noblock ); -void sixel_vga ( struct sixels *charsixel, u_char *charvga ); -void sput ( u_char *s, U_char attrib, int len, int page ); -void sw_cursor ( int onoff ); -void sw_sfkl ( struct video_state *svsp ); -void sw_ufkl ( struct video_state *svsp ); -void swritefkl ( int num, u_char *string, struct video_state *svsp ); -void toggl_awm ( struct video_state *svsp ); -void toggl_bell ( struct video_state *svsp ); -void toggl_columns ( struct video_state *svsp ); -void toggl_dspf ( struct video_state *svsp ); -void toggl_sevenbit ( struct video_state *svsp ); -void update_hp ( struct video_state *svsp ); -void update_led ( void ); -void vga10_vga10 ( u_char *invga, u_char *outvga ); -void vga10_vga14 ( u_char *invga, u_char *outvga ); -void vga10_vga16 ( u_char *invga, u_char *outvga ); -void vga10_vga8 ( u_char *invga, u_char *outvga ); -u_char vga_chipset ( void ); -int vga_col ( struct video_state *svsp, int cols ); -void vga_move_charset ( unsigned n, unsigned char *b, int save_it); -void vga_screen_off ( void ); -void vga_screen_on ( void ); -char *vga_string ( int number ); -int vga_test ( void ); -int vgaioctl ( Dev_t dev, int cmd, caddr_t data, int flag ); -void vgapaletteio ( unsigned idx, struct rgb *val, int writeit ); -void vt_aln ( struct video_state *svsp ); -void vt_clearudk ( struct video_state *svsp ); -void vt_clreol ( struct video_state *svsp ); -void vt_clreos ( struct video_state *svsp ); -void vt_clrtab ( struct video_state *svsp ); -int vt_col ( struct video_state *svsp, int cols ); -void vt_coldinit ( void ); -void vt_coldmalloc ( void ); -void vt_cub ( struct video_state *svsp ); -void vt_cud ( struct video_state *svsp ); -void vt_cuf ( struct video_state *svsp ); -void vt_curadr ( struct video_state *svsp ); -void vt_cuu ( struct video_state *svsp ); -void vt_da ( struct video_state *svsp ); -void vt_dch ( struct video_state *svsp ); -void vt_dcsentry ( U_char ch, struct video_state *svsp ); -void vt_designate ( struct video_state *svsp); -void vt_dl ( struct video_state *svsp ); -void vt_dld ( struct video_state *svsp ); -void vt_dsr ( struct video_state *svsp ); -void vt_ech ( struct video_state *svsp ); -void vt_ic ( struct video_state *svsp ); -void vt_il ( struct video_state *svsp ); -void vt_ind ( struct video_state *svsp ); -void vt_initsel ( struct video_state *svsp ); -void vt_keyappl ( struct video_state *svsp ); -void vt_keynum ( struct video_state *svsp ); -void vt_mc ( struct video_state *svsp ); -void vt_nel ( struct video_state *svsp ); -void vt_rc ( struct video_state *svsp ); -void vt_reqtparm ( struct video_state *svsp ); -void vt_reset_ansi ( struct video_state *svsp ); -void vt_reset_dec_priv_qm ( struct video_state *svsp ); -void vt_ri ( struct video_state *svsp ); -void vt_ris ( struct video_state *svsp ); -void vt_sc ( struct video_state *svsp ); -void vt_scl ( struct video_state *svsp ); -void vt_sca ( struct video_state *svsp ); -void vt_sd ( struct video_state *svsp ); -void vt_sed ( struct video_state *svsp ); -void vt_sel ( struct video_state *svsp ); -void vt_set_ansi ( struct video_state *svsp ); -void vt_set_dec_priv_qm ( struct video_state *svsp ); -void vt_sgr ( struct video_state *svsp ); -void vt_stbm ( struct video_state *svsp ); -void vt_str ( struct video_state *svsp ); -void vt_su ( struct video_state *svsp ); -void vt_tst ( struct video_state *svsp ); -void vt_udk ( struct video_state *svsp ); -void toggl_24l ( struct video_state *svsp ); - -#ifdef PCVT_INCLUDE_VT_SELATTR - -#define INT_BITS (sizeof(unsigned int) * 8) -#define INT_INDEX(n) ((n) / INT_BITS) -#define BIT_INDEX(n) ((n) % INT_BITS) - -/*---------------------------------------------------------------------------* - * set selective attribute if appropriate - *---------------------------------------------------------------------------*/ -static __inline void vt_selattr(struct video_state *svsp) -{ - int i; - - i = (svsp->Crtat + svsp->cur_offset) - svsp->Crtat; - - if(svsp->selchar) - svsp->decsca[INT_INDEX(i)] |= (1 << BIT_INDEX(i)); - else - svsp->decsca[INT_INDEX(i)] &= ~(1 << BIT_INDEX(i)); -} - -#endif /* PCVT_INCLUDE_VT_SELATTR */ - - -/*---------------------------------------------------------------------------* - * produce 7 us delay accessing the keyboard controller - *---------------------------------------------------------------------------*/ - -#if PCVT_PORTIO_DELAY - /* use multiple dummy accesses to port */ - /* 0x84 to produce keyboard controller */ - /* access delays */ -#define PCVT_KBD_DELAY() \ - { volatile u_char x = inb(0x84); (void) &x;} \ - { volatile u_char x = inb(0x84); (void) &x;} \ - { volatile u_char x = inb(0x84); (void) &x;} \ - { volatile u_char x = inb(0x84); (void) &x;} \ - { volatile u_char x = inb(0x84); (void) &x;} \ - { volatile u_char x = inb(0x84); (void) &x;} - -#else /* PCVT_PORTIO_DELAY */ - /* use system supplied delay function for */ - /* producing delays for accesssing the */ - /* keyboard controller */ -#define PCVT_KBD_DELAY() delay(7) -#endif /* PCVT_PORTIO_DELAY */ - -/*---------------------------------- E O F ----------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/pcvt_ioctl.h b/sys/arch/i386/isa/pcvt/pcvt_ioctl.h deleted file mode 100644 index 1eb1a0260011..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_ioctl.h +++ /dev/null @@ -1,584 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore and Holger Veit. - * - * Copyright (C) 1992, 1993 Soeren Schmidt. - * - * All rights reserved. - * - * For the sake of compatibility, portions of this code regarding the - * X server interface are taken from Soeren Schmidt's syscons driver. - * - * This code is derived from software contributed to 386BSD by - * Holger Veit. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz and Don Ahn. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by - * Hellmuth Michaelis, Brian Dunford-Shore, Joerg Wunsch, Holger Veit - * and Soeren Schmidt. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)ioctl_pcvt.h, 3.32, Last Edit-Date: [Tue Oct 3 11:19:48 1995] - * - */ - -/*--------------------------------------------------------------------------- - * - * pcvt_ioctl.h ioctl's for the VT220 video driver 'pcvt' - * --------------------------------------------------------- - * -hm ------------ Release 3.00 -------------- - * -hm some new PCVT_xxx (and CONF_xxx) values - * -hm version definitions moved to begin of file - * -hm removed PCVT_FAKE_SYSCONS10 - * -hm accept KERNEL or _KERNEL - * -hm changed _IOCTL_PCVT_H_ to _MACHINE_PCVT_IOCTL_H_ (bde) - * -hm added PCVT_MDAFASTSCROLL - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch to support Cirrus CL-GD62x5 from Martin - * -hm removed KBDGLEDS and KBDSLEDS ioctls - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#ifndef _MACHINE_PCVT_IOCTL_H_ -#define _MACHINE_PCVT_IOCTL_H_ - -/* pcvt version information for VGAPCVTID ioctl */ - -#define PCVTIDNAME "pcvt" /* driver id - string */ -#define PCVTIDMAJOR 3 /* driver id - major release */ -#define PCVTIDMINOR 32 /* driver id - minor release */ - -#include -#if !defined(KERNEL) && !defined(_KERNEL) -#include -#endif - -/*---------------------------------------------------------------------------* - * IOCTLs for MF II and AT Keyboards - *---------------------------------------------------------------------------*/ - -#define KBDRESET _IO('K', 1) /* reset keyboard / set defaults */ -#define KBDGTPMAT _IOR('K', 2, int) /* get current typematic value */ -#define KBDSTPMAT _IOW('K', 3, int) /* set current typematic value */ - -/* Typematic Delay Values */ - -#define KBD_TPD250 0x00 /* 250 ms */ -#define KBD_TPD500 0x20 /* 500 ms */ -#define KBD_TPD750 0x40 /* 750 ms */ -#define KBD_TPD1000 0x60 /* 1000 ms */ - -/* Typematic Repeat Rate */ - -#define KBD_TPM300 0x00 /* 30.0 char/second */ -#define KBD_TPM267 0x01 /* 26.7 char/second */ -#define KBD_TPM240 0x02 /* 24.0 char/second */ -#define KBD_TPM218 0x03 /* 21.8 char/second */ -#define KBD_TPM200 0x04 /* 20.0 char/second */ -#define KBD_TPM185 0x05 /* 18.5 char/second */ -#define KBD_TPM171 0x06 /* 17.1 char/second */ -#define KBD_TPM160 0x07 /* 16.0 char/second */ -#define KBD_TPM150 0x08 /* 15.0 char/second */ -#define KBD_TPM133 0x09 /* 13.3 char/second */ -#define KBD_TPM120 0x0A /* 12.0 char/second */ -#define KBD_TPM109 0x0B /* 10.9 char/second */ -#define KBD_TPM100 0x0C /* 10.0 char/second */ -#define KBD_TPM92 0x0D /* 9.2 char/second */ -#define KBD_TPM86 0x0E /* 8.6 char/second */ -#define KBD_TPM80 0x0F /* 8.0 char/second */ -#define KBD_TPM75 0x10 /* 7.5 char/second */ -#define KBD_TPM67 0x11 /* 6.7 char/second */ -#define KBD_TPM60 0x12 /* 6.0 char/second */ -#define KBD_TPM55 0x13 /* 5.5 char/second */ -#define KBD_TPM50 0x14 /* 5.0 char/second */ -#define KBD_TPM46 0x15 /* 4.6 char/second */ -#define KBD_TPM43 0x16 /* 4.3 char/second */ -#define KBD_TPM40 0x17 /* 4.0 char/second */ -#define KBD_TPM37 0x18 /* 3.7 char/second */ -#define KBD_TPM33 0x19 /* 3.3 char/second */ -#define KBD_TPM30 0x1A /* 3.0 char/second */ -#define KBD_TPM27 0x1B /* 2.7 char/second */ -#define KBD_TPM25 0x1C /* 2.5 char/second */ -#define KBD_TPM23 0x1D /* 2.3 char/second */ -#define KBD_TPM21 0x1E /* 2.1 char/second */ -#define KBD_TPM20 0x1F /* 2.0 char/second */ - -#define KBDGREPSW _IOR('K', 4, int) /* get key repetition switch */ -#define KBDSREPSW _IOW('K', 5, int) /* set key repetition switch */ -#define KBD_REPEATOFF 0 -#define KBD_REPEATON 1 - -#define KBDGLOCK _IOR('K', 8, int) /* gets SCROLL,NUM,CAPS state */ -#define KBDSLOCK _IOW('K', 9, int) /* sets SCROLL,NUM,CAPS state */ - /* _and_ sets keyboard LEDs! */ -#define KBD_SCROLLLOCK 0x0001 /* the driver's idea of */ -#define KBD_NUMLOCK 0x0002 /* lock key state */ -#define KBD_CAPSLOCK 0x0004 /* for kbdioctl() */ - -#define KBDMAXOVLKEYSIZE 15 /* + zero byte */ - -struct kbd_ovlkey /* complete definition of a key */ -{ - u_short keynum; /* the key itself */ - u_short type; /* type of key, see below */ - u_char subu; /* subtype, ignored on write */ - char unshift[KBDMAXOVLKEYSIZE+1]; /* emitted string, unshifted */ - u_char subs; /* subtype, ignored on write */ - char shift[KBDMAXOVLKEYSIZE+1]; /* emitted string, shifted */ - u_char subc; /* subtype, ignored on write */ - char ctrl[KBDMAXOVLKEYSIZE+1]; /* emitted string, control */ - u_char suba; /* subtype, ignored on write */ - char altgr[KBDMAXOVLKEYSIZE+1]; /* emitted string, altgr */ -}; - -/* Max value for keynum field */ - -#define KBDMAXKEYS 128 /* Max No. of Keys */ - -/* Values for type field */ - -#define KBD_NONE 0 /* no function, key is disabled */ -#define KBD_SHIFT 1 /* keyboard shift */ -#define KBD_META 2 /* alternate shift, sets bit8 to ASCII code */ -#define KBD_NUM 3 /* numeric shift, keypad num / appl */ -#define KBD_CTL 4 /* control code generation */ -#define KBD_CAPS 5 /* caps shift - swaps case of letter */ -#define KBD_ASCII 6 /* ascii code generating key */ -#define KBD_SCROLL 7 /* stop output */ -#define KBD_FUNC 8 /* function key */ -#define KBD_KP 9 /* keypad keys */ -#define KBD_BREAK 10 /* ignored */ -#define KBD_ALTGR 11 /* AltGr Translation feature */ -#define KBD_SHFTLOCK 12 /* shiftlock */ -#define KBD_CURSOR 13 /* cursor keys */ -#define KBD_RETURN 14 /* RETURN/ENTER keys */ - -/* Values for subtype field */ - -#define KBD_SUBT_STR 0 /* key is bound to a string */ -#define KBD_SUBT_FNC 1 /* key is bound to a function */ - - -#define KBD_OVERLOAD 0x8000 /* Key is overloaded, ignored in ioctl */ -#define KBD_MASK (~KBD_OVERLOAD) /* mask for type */ - -#define KBDGCKEY _IOWR('K',16, struct kbd_ovlkey) /* get current key values */ -#define KBDSCKEY _IOW('K',17, struct kbd_ovlkey) /* set new key assignment values*/ -#define KBDGOKEY _IOWR('K',18, struct kbd_ovlkey) /* get original key assignment values*/ - -#define KBDRMKEY _IOW('K',19, int) /* remove a key assignment */ -#define KBDDEFAULT _IO('K',20) /* remove all key assignments */ - -/* mouse emulator definitions */ - -struct mousedefs { - int leftbutton; /* (PC) scan code for "left button" key */ - int middlebutton; /* (PC) scan code for "mid button" key */ - int rightbutton; /* (PC) scan code for "right button" key */ - int stickybuttons; /* if true, the buttons are "sticky" */ - int acceltime; /* timeout in microseconds to start pointer */ - /* movement acceleration */ - /* defaults to: scan(F1), scan(F2), scan(F3), false, 500000 */ -}; - -#define KBDMOUSEGET _IOR('K', 25, struct mousedefs) /* read defs */ -#define KBDMOUSESET _IOW('K', 26, struct mousedefs) /* set defs */ - -/*---------------------------------------------------------------------------* - * IOCTLs for Video Adapter - *---------------------------------------------------------------------------*/ - -/* Definition of PC Video Adaptor Types */ - -#define UNKNOWN_ADAPTOR 0 /* Unidentified adaptor ... */ -#define MDA_ADAPTOR 1 /* Monochrome Display Adaptor/Hercules Graphics Card */ -#define CGA_ADAPTOR 2 /* Color Graphics Adaptor */ -#define EGA_ADAPTOR 3 /* Enhanced Graphics Adaptor */ -#define VGA_ADAPTOR 4 /* Video Graphics Adaptor/Array */ - -/* Deifinitions of Monitor types */ - -#define MONITOR_MONO 0 /* Monochrome Monitor */ -#define MONITOR_COLOR 1 /* Color Monitor */ - -/* Types of VGA chips detectable by current driver version */ - -#define VGA_F_NONE 0 /* FAMILY NOT KNOWN */ -#define VGA_UNKNOWN 0 /* default, no 132 columns */ - -#define VGA_F_TSENG 1 /* FAMILY TSENG */ -#define VGA_ET4000 1 /* Tseng Labs ET4000 */ -#define VGA_ET3000 2 /* Tseng Labs ET3000 */ - -#define VGA_F_WD 2 /* FAMILY WD */ -#define VGA_PVGA 3 /* Western Digital Paradise VGA */ -#define VGA_WD90C00 4 /* Western Digital WD90C00 */ -#define VGA_WD90C10 5 /* Western Digital WD90C10 */ -#define VGA_WD90C11 6 /* Western Digital WD90C11 */ - -#define VGA_F_V7 3 /* FAMILY VIDEO 7 */ -#define VGA_V7VEGA 7 /* Video 7 VEGA VGA */ -#define VGA_V7FWVR 8 /* Video 7 FASTWRITE/VRAM */ -#define VGA_V7V5 9 /* Video 7 Version 5 */ -#define VGA_V71024I 10 /* Video 7 1024i */ -#define VGA_V7UNKNOWN 11 /* Video 7 unknown board .. */ - -#define VGA_F_TRI 4 /* FAMILY TRIDENT */ -#define VGA_TR8800BR 12 /* Trident TVGA 8800BR */ -#define VGA_TR8800CS 13 /* Trident TVGA 8800CS */ -#define VGA_TR8900B 14 /* Trident TVGA 8900B */ -#define VGA_TR8900C 15 /* Trident TVGA 8900C */ -#define VGA_TR8900CL 16 /* Trident TVGA 8900CL */ -#define VGA_TR9000 17 /* Trident TVGA 9000 */ -#define VGA_TR9100 18 /* Trident TVGA 9100 */ -#define VGA_TR9200 19 /* Trident TVGA 9200 */ -#define VGA_TRUNKNOWN 20 /* Trident unknown */ - -#define VGA_F_S3 5 /* FAMILY S3 */ -#define VGA_S3_911 21 /* S3 911 */ -#define VGA_S3_924 22 /* S3 924 */ -#define VGA_S3_80x 23 /* S3 801/805 */ -#define VGA_S3_928 24 /* S3 928 */ -#define VGA_S3_UNKNOWN 25 /* unknown S3 chipset */ - -#define VGA_F_CIR 6 /* FAMILY CIRRUS */ -#define VGA_CL_GD5402 26 /* Cirrus CL-GD5402 */ -#define VGA_CL_GD5402r1 27 /* Cirrus CL-GD5402r1 */ -#define VGA_CL_GD5420 28 /* Cirrus CL-GD5420 */ -#define VGA_CL_GD5420r1 29 /* Cirrus CL-GD5420r1 */ -#define VGA_CL_GD5422 30 /* Cirrus CL-GD5422 */ -#define VGA_CL_GD5424 31 /* Cirrus CL-GD5424 */ -#define VGA_CL_GD5426 32 /* Cirrus CL-GD5426 */ -#define VGA_CL_GD5428 33 /* Cirrus CL-GD5428 */ -#define VGA_CL_GD5430 34 /* Cirrus CL-GD543x */ -#define VGA_CL_GD6225 35 /* Cirrus CL-GD62x5 */ -#define VGA_CL_UNKNOWN 36 /* Unknown Cirrus CL */ - -#define VGA_MAX_CHIPSET 37 /* max no of chips */ - -/*****************************************************************************/ -/* NOTE: update the 'scon' utility when adding support for more chipsets !!! */ -/*****************************************************************************/ - -/* Definitions of Vertical Screen Sizes for EGA/VGA Adaptors */ - -#define SIZ_25ROWS 0 /* VGA: 25 lines, 8x16 font */ - /* EGA: 25 lines, 8x14 font */ -#define SIZ_28ROWS 1 /* VGA: 28 lines, 8x14 font */ -#define SIZ_35ROWS 2 /* EGA: 35 lines, 8x10 font */ -#define SIZ_40ROWS 3 /* VGA: 40 lines, 8x10 font */ -#define SIZ_43ROWS 4 /* EGA: 43 lines, 8x8 font */ -#define SIZ_50ROWS 5 /* VGA: 50 lines, 8x8 font */ - -/* Definitions of Font Sizes for EGA/VGA Adaptors */ - -#define FNT_8x16 0 /* 8x16 Pixel Font, only VGA */ -#define FNT_8x14 1 /* 8x14 Pixel Font, EGA/VGA */ -#define FNT_8x10 2 /* 8x10 Pixel Font, EGA/VGA */ -#define FNT_8x8 3 /* 8x8 Pixel Font, EGA/VGA */ - -/* Definitions of Character Set (Font) Numbers */ - -#define CH_SET0 0 /* Character Set (Font) 0, EGA/VGA */ -#define CH_SET1 1 /* Character Set (Font) 1, EGA/VGA */ -#define CH_SET2 2 /* Character Set (Font) 2, EGA/VGA */ -#define CH_SET3 3 /* Character Set (Font) 3, EGA/VGA */ -#define CH_SETMAX_EGA 3 /* EGA has 4 Character Sets / Fonts */ -#define CH_SET4 4 /* Character Set (Font) 4, VGA */ -#define CH_SET5 5 /* Character Set (Font) 5, VGA */ -#define CH_SET6 6 /* Character Set (Font) 6, VGA */ -#define CH_SET7 7 /* Character Set (Font) 7, VGA */ -#define CH_SETMAX_VGA 7 /* VGA has 8 Character Sets / Fonts */ - -/* Definitions of Terminal Emulation Modes */ - -#define M_HPVT 0 /* VTxxx and HP Mode, Labels & Status Line on */ -#define M_PUREVT 1 /* only VTxxx Sequences recognized, no Labels */ - -/*---*/ - -#define VGACURSOR _IOW('V',100, struct cursorshape) /* set cursor shape */ - -struct cursorshape { - int screen_no; /* screen number for which to set, */ - /* or -1 to set on current active screen */ - int start; /* top scanline, range 0... Character Height - 1 */ - int end; /* end scanline, range 0... Character Height - 1 */ -}; - -#define VGALOADCHAR _IOW('V',101, struct vgaloadchar) /* load vga char */ - -struct vgaloadchar { - int character_set; /* VGA character set to load into */ - int character; /* Character to load */ - int character_scanlines; /* Scanlines per character */ - u_char char_table[32]; /* VGA character shape table */ -}; - -#define VGASETFONTATTR _IOW('V',102, struct vgafontattr) /* set font attr */ -#define VGAGETFONTATTR _IOWR('V',103, struct vgafontattr) /* get font attr */ - -struct vgafontattr { - int character_set; /* VGA character set */ - int font_loaded; /* Mark font loaded or unloaded */ - int screen_size; /* Character rows per screen */ - int character_scanlines; /* Scanlines per character - 1 */ - int screen_scanlines; /* Scanlines per screen - 1 byte */ -}; - -#define VGASETSCREEN _IOW('V',104, struct screeninfo) /* set screen info */ -#define VGAGETSCREEN _IOWR('V',105, struct screeninfo) /* get screen info */ - -struct screeninfo { - int adaptor_type; /* type of video adaptor installed */ - /* read only, ignored on write */ - int monitor_type; /* type of monitor (mono/color)installed*/ - /* read only, ignored on write */ - int totalfonts; /* no of downloadable fonts */ - /* read only, ignored on write */ - int totalscreens; /* no of virtual screens */ - /* read only, ignored on write */ - int screen_no; /* screen number, this was got from */ - /* on write, if -1, apply pure_vt_mode */ - /* and/or screen_size to current screen */ - /* else to screen_no supplied */ - int current_screen; /* screen number, which is displayed. */ - /* on write, if -1, make this screen */ - /* the current screen, else set current */ - /* displayed screen to parameter */ - int pure_vt_mode; /* flag, pure VT mode or HP/VT mode */ - /* on write, if -1, no change */ - int screen_size; /* screen size */ - /* on write, if -1, no change */ - int force_24lines; /* force 24 lines if 25 lines VT mode */ - /* or 28 lines HP mode to get pure */ - /* VT220 screen size */ - /* on write, if -1, no change */ - int vga_family; /* if adaptor_type = VGA, this reflects */ - /* the chipset family after a read */ - /* nothing happenes on write ... */ - int vga_type; /* if adaptor_type = VGA, this reflects */ - /* the chipset after a read */ - /* nothing happenes on write ... */ - int vga_132; /* set to 1 if driver has support for */ - /* 132 column operation for chipset */ - /* currently ignored on write */ -}; - -#define VGAREADPEL _IOWR('V', 110, struct vgapel) /*r VGA palette entry */ -#define VGAWRITEPEL _IOW('V', 111, struct vgapel) /*w VGA palette entry */ - -struct vgapel { - unsigned idx; /* index into palette, 0 .. 255 valid */ - unsigned r, g, b; /* RGB values, masked by VGA_PMASK (63) */ -}; - -/* NOTE: The next ioctl is only valid if option PCVT_SCREENSAVER is configured*/ -/* this is *not* restricted to VGA's, but won't introduce new garbage... */ - -#define VGASCREENSAVER _IOW('V', 112, int) /* set timeout for screen */ - /* saver in seconds; 0 turns */ - /* it off */ - -#define VGAPCVTID _IOWR('V',113, struct pcvtid) /* get driver id */ - -struct pcvtid { /* THIS STRUCTURE IS NOW FROZEN !!! */ -#define PCVTIDNAMELN 16 /* driver id - string length */ - char name[PCVTIDNAMELN]; /* driver name, == PCVTIDSTR */ - int rmajor; /* revision number, major */ - int rminor; /* revision number, minor */ -}; /* END OF COLD PART ... */ - -#define VGAPCVTINFO _IOWR('V',114, struct pcvtinfo) /* get driver info */ - -struct pcvtinfo { /* compile time option values */ - u_int opsys; /* PCVT_xxx(x)BSD */ -#define CONF_UNKNOWNOPSYS 0 -#define CONF_386BSD 1 /* unsupported */ -#define CONF_NETBSD 2 -#define CONF_FREEBSD 3 - u_int opsysrel; /* Release */ - u_int nscreens; /* PCVT_NSCREENS */ - u_int scanset; /* PCVT_SCANSET */ - u_int sysbeepf; /* PCVT_SYSBEEPF */ - u_int pcburst; /* PCVT_PCBURST */ - u_int kbd_fifo_sz; /* PCVT_KBD_FIFO_SZ */ - -/* config booleans */ - - u_long compile_opts; /* PCVT_xxxxxxxxxxxxxxx */ - -#define CONF_VT220KEYB 0x00000001 -#define CONF_SCREENSAVER 0x00000002 -#define CONF_PRETTYSCRNS 0x00000004 -#define CONF_CTRL_ALT_DEL 0x00000008 -#define CONF_USEKBDSEC 0x00000010 -#define CONF_24LINESDEF 0x00000020 -#define CONF_EMU_MOUSE 0x00000040 -#define CONF_SHOWKEYS 0x00000080 -#define CONF_KEYBDID 0x00000100 -#define CONF_SIGWINCH 0x00000200 -#define CONF_NULLCHARS 0x00000400 -#define CONF_BACKUP_FONTS 0x00000800 -#define CONF_SW0CNOUTP 0x00001000 -#define CONF_MDAFASTSCROLL 0x00002000 -#define CONF_SETCOLOR 0x00004000 -#define CONF_132GENERIC 0x00008000 -#define CONF_PALFLICKER 0x00010000 -#define CONF_WAITRETRACE 0x00020000 -#define CONF_XSERVER 0x00040000 -/* #define CONF_USL_VT_COMPAT 0x00080000 */ -#define CONF_PORTIO_DELAY 0x00100000 -#define CONF_INHIBIT_NUMLOCK 0x00200000 -#define CONF_META_ESC 0x00400000 -#define CONF_NOFASTSCROLL 0x00800000 -#define CONF_KBD_FIFO 0x02000000 -#define CONF_NO_LED_UPDATE 0x04000000 -}; - -#define VGASETCOLMS _IOW('V', 115, int) /* set number of columns (80/132)*/ - -/* - * only useful if compiled with ``XSERVER'' defined, but always here: - * WARNING: DO NOT CHANGE THESE DEFINITIONS, the X server relies on - * it since it's defining its own values and doesn't know nothing about - * this header file. - */ - -#define CONSOLE_X_MODE_ON _IO('t', 121) /* turn off pcvt, grant IOPL for X */ - -#define CONSOLE_X_MODE_OFF _IO('t', 122) /* back to pcvt */ - -#define CONSOLE_X_BELL _IOW('t', 123, int[2]) /* set bell behaviour */ - -/* - * start of USL VT compatibility stuff - * these definitions must match those ones used by syscons - * - * Note that some of the ioctl command definitions below break the Berkeley - * style. They accept a parameter of type "int" (instead of Berkeley style - * "int *") in order to pass a single integer to the ioctl. These macros - * below are marked with a dummy "int" comment. Dont blame anyone else - * than USL for that braindeadness. It is done here to be a bit source- - * level compatible to SysV. (N.B., within the ioctl, the argument is - * dereferenced by "int *" anyway. The translation is done by the upper- - * level ioctl stuff.) - */ - -/* - * NB: Some of the definitions below apparently override the definitions - * in the KBD section above. But, due to BSDs encoding of the IO direction - * and transfer size, the resulting ioctl cmds differ, so we can take them - * here. - */ - -#define KDGKBMODE _IOR('K', 6, int) /* get keyboard mode */ -#define KDSKBMODE _IO('K', 7 /*, int */) /* set keyboard mode */ -#define K_RAW 0 /* kbd switched to raw mode */ -#define K_XLATE 1 /* kbd switched to "normal" mode */ - -#define KDMKTONE _IO('K', 8 /*, int */) - -/* #define KDGETMODE _IOR('K', 9, int) */ /* not yet implemented */ - -#define KDSETMODE _IO('K', 10 /*, int */) -#define KD_TEXT 0 /* set text mode restore fonts */ -#define KD_GRAPHICS 1 /* set graphics mode */ - -/* we cannot see any sense to support KD_TEXT0 or KD_TEXT1 */ - -#define KDENABIO _IO('K', 60) /* only allowed if euid == 0 */ -#define KDDISABIO _IO('K', 61) - -#define KDGETLED _IOR('K', 65, int) -#define KDSETLED _IO('K', 66 /*, int */) -#define LED_CAP 1 -#define LED_NUM 2 -#define LED_SCR 4 - -#define KDSETRAD _IO('K', 67 /*, int */) - -/* - * Note that since our idea of key mapping is much different from the - * SysV style, we _only_ support mapping layers base (0), shifted (1), - * alt (4), and alt-shift (5), and only for the basic keys (without - * any function keys). This is what XFree86 2.0+ needs to establish - * the default X keysym mapping. - */ -#define GIO_KEYMAP _IOR('k', 6, keymap_t) - -#define VT_OPENQRY _IOR('v', 1, int) -#define VT_SETMODE _IOW('v', 2, vtmode_t) -#define VT_GETMODE _IOR('v', 3, vtmode_t) - -#define VT_RELDISP _IO('v', 4 /*, int */) - -/* acceptable values for the VT_RELDISP command */ - -#define VT_FALSE 0 /* release of VT refused */ -#define VT_TRUE 1 /* VT released */ -#define VT_ACKACQ 2 /* acknowledging VT acquiration */ - - -#define VT_ACTIVATE _IO('v', 5 /*, int */) -#define VT_WAITACTIVE _IO('v', 6 /*, int */) -#define VT_GETACTIVE _IOR('v', 7, int) - -struct vt_mode { - char mode; - -#define VT_AUTO 0 /* switching controlled by drvr */ -#define VT_PROCESS 1 /* switching controlled by prog */ - - char waitv; /* not implemented yet SOS */ - short relsig; - short acqsig; - short frsig; /* not implemented yet SOS */ -}; - -typedef struct vt_mode vtmode_t; - -#define NUM_KEYS 256 -#define NUM_STATES 8 - -struct keymap { - u_short n_keys; - struct key_t { - u_char map[NUM_STATES]; - u_char spcl; - u_char flgs; - } key[NUM_KEYS]; -}; - -typedef struct keymap keymap_t; - -/* end of USL VT compatibility stuff */ - -#endif /* ! _MACHINE_PCVT_IOCTL_H_ */ diff --git a/sys/arch/i386/isa/pcvt/pcvt_kbd.c b/sys/arch/i386/isa/pcvt/pcvt_kbd.c deleted file mode 100644 index d0535ec3e54c..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_kbd.c +++ /dev/null @@ -1,2942 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore and Holger Veit. - * - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz and Don Ahn. - * - * This code is derived from software contributed to 386BSD by - * Holger Veit. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis, - * Brian Dunford-Shore and Joerg Wunsch. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_kbd.c, 3.32, Last Edit-Date: [Tue Oct 3 11:19:48 1995] - * - */ - -#include "opt_ddb.h" - -/*---------------------------------------------------------------------------* - * - * pcvt_kbd.c VT220 Driver Keyboard Interface Code - * ---------------------------------------------------- - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -jw introduced kbd_emulate_pc() if scanset > 1 - * -hm patch from joerg for timeout in kbd_emulate_pc() - * -hm starting to implement alt-shift/ctrl key mappings - * -hm Gateway 2000 Keyboard fix from Brian Moore - * -hm some #if adjusting for NetBSD 0.9 - * -hm split off pcvt_kbd.h - * -hm applying Joerg's patches for FreeBSD 2.0 - * -hm patch from Martin, PCVT_NO_LED_UPDATE - * -hm PCVT_VT220KEYB patches from Lon Willet - * -hm PR #399, patch from Bill Sommerfeld: Return with PCVT_META_ESC - * -hm allow keyboard-less kernel boot for serial consoles and such .. - * -hm patch from Lon Willett for led-update and showkey() - * -hm patch from Lon Willett to fix mapping of Control-R scancode - * -hm delay patch from Martin Husemann after port-i386 ml-discussion - * -hm added PCVT_NONRESP_KEYB_TRY definition to doreset() - * -hm keyboard code bugfix from Jukka A. Ukkonen (ukkonen@csc.fi) - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Frank van der Linden for keyboard state per VT - * -hm removed KBDGLEDS and KBDSLEDS ioctls - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#include "pcvt_hdr.h" /* global include */ - -static void fkey1(void), fkey2(void), fkey3(void), fkey4(void); -static void fkey5(void), fkey6(void), fkey7(void), fkey8(void); -static void fkey9(void), fkey10(void), fkey11(void), fkey12(void); - -static void sfkey1(void), sfkey2(void), sfkey3(void), sfkey4(void); -static void sfkey5(void), sfkey6(void), sfkey7(void), sfkey8(void); -static void sfkey9(void), sfkey10(void), sfkey11(void), sfkey12(void); - -static void cfkey1(void), cfkey2(void), cfkey3(void), cfkey4(void); -static void cfkey5(void), cfkey6(void), cfkey7(void), cfkey8(void); -static void cfkey9(void), cfkey10(void), cfkey11(void), cfkey12(void); - -static inline int kbd_wait_output(void); -static inline int kbd_wait_input(void); -int kbd_response(void); - - -static void doreset ( void ); -static void ovlinit ( int force ); -static void settpmrate ( int rate ); -static void setlockkeys ( int snc ); -static int kbc_8042cmd ( int val ); -static int getokeydef ( unsigned key, struct kbd_ovlkey *thisdef ); -static int getckeydef ( unsigned key, struct kbd_ovlkey *thisdef ); -static int rmkeydef ( int key ); -static int setkeydef ( struct kbd_ovlkey *data ); -static u_char * xlatkey2ascii( U_short key ); - -#if !PCVT_NO_LED_UPDATE -static int ledstate = 0; /* keyboard led's */ -#endif -static int tpmrate = KBD_TPD500|KBD_TPM100; -static u_char altkpflag = 0; -static u_short altkpval = 0; - -#if PCVT_SHOWKEYS -u_char rawkeybuf[80]; -#endif - -#include "pcvt_kbd.h" /* tables etc */ - -#if PCVT_SHOWKEYS -/*---------------------------------------------------------------------------* - * keyboard debugging: put kbd communication char into some buffer - *---------------------------------------------------------------------------*/ -static void showkey (char delim, u_char val) -{ - int rki; - - for(rki = 3; rki < 80; rki++) /* shift left buffer */ - rawkeybuf[rki-3] = rawkeybuf[rki]; - - rawkeybuf[77] = delim; /* delimiter */ - - rki = (val & 0xf0) >> 4; /* ms nibble */ - - if(rki <= 9) - rki = rki + '0'; - else - rki = rki - 10 + 'A'; - - rawkeybuf[78] = rki; - - rki = val & 0x0f; /* ls nibble */ - - if(rki <= 9) - rki = rki + '0'; - else - rki = rki - 10 + 'A'; - - rawkeybuf[79] = rki; -} -#endif /* PCVT_SHOWKEYS */ - -/*---------------------------------------------------------------------------* - * function to switch to another virtual screen - *---------------------------------------------------------------------------*/ -static void -do_vgapage(int page) -{ - if(critical_scroll) /* executing critical region ? */ - switch_page = page; /* yes, auto switch later */ - else - vgapage(page); /* no, switch now */ -} - - -/* - * This code from Lon Willett enclosed in #if PCVT_UPDLED_LOSES_INTR is - * abled because it crashes FreeBSD 1.1.5.1 at boot time. - * The cause is obviously that the timeout queue is not yet initialized - * timeout is called from here the first time. - * Anyway it is a pointer in the right direction so it is included for - * reference here. - */ - -#define PCVT_UPDLED_LOSES_INTR 0 /* disabled for now */ - -#if PCVT_UPDLED_LOSES_INTR - -/*---------------------------------------------------------------------------* - * check for lost keyboard interrupts - *---------------------------------------------------------------------------*/ - -/* - * The two commands to change the LEDs generate two KEYB_R_ACK responses - * from the keyboard, which aren't explicitly checked for (maybe they - * should be?). However, when a lot of other I/O is happening, one of - * the interrupts sometimes gets lost (I'm not sure of the details of - * how and why and what hardware this happens with). - * - * This is a real problem, because normally the keyboard is only polled - * by pcrint(), and no more interrupts will be generated until the ACK - * has been read. So the keyboard is hung. This code polls a little - * while after changing the LEDs to make sure that this hasn't happened. - * - * XXX Quite possibly we should poll the kbd on a regular basis anyway, - * in the interest of robustness. It may be possible that interrupts - * get lost other times as well. - */ - -static int lost_intr_timeout_queued = 0; -static struct callout check_for_lost_intr_ch = CALLOUT_INITIALIZER; - -static void -check_for_lost_intr (void *arg) -{ - lost_intr_timeout_queued = 0; - if (inb(CONTROLLER_CTRL) & STATUS_OUTPBF) - { - int opri = spltty (); - (void) pcrint (); - splx (opri); - } -} - -#endif /* PCVT_UPDLED_LOSES_INTR */ - -/*---------------------------------------------------------------------------* - * update keyboard led's - *---------------------------------------------------------------------------*/ -void -update_led(void) -{ - -#if !PCVT_NO_LED_UPDATE - - /* Don't update LED's unless necessary. */ - - int new_ledstate = ((vsp->scroll_lock) | - (vsp->num_lock * 2) | - (vsp->caps_lock * 4)); - - if (new_ledstate != ledstate) - { - if(kbd_cmd(KEYB_C_LEDS) != 0) - { - printf("Keyboard LED command timeout\n"); - return; - } - - if(kbd_cmd(new_ledstate) != 0) { - printf("Keyboard LED data timeout\n"); - return; - } - - ledstate = new_ledstate; - -#if PCVT_UPDLED_LOSES_INTR - if (lost_intr_timeout_queued) - callout_stop(&check_for_lost_intr_ch); - - callout_reset(&check_for_lost_intr_ch, hz, - check_for_lost_intr, NULL); - lost_intr_timeout_queued = 1; -#endif /* PCVT_UPDLED_LOSES_INTR */ - - } -#endif /* !PCVT_NO_LED_UPDATE */ -} - -/*---------------------------------------------------------------------------* - * set typematic rate - *---------------------------------------------------------------------------*/ -static void -settpmrate(int rate) -{ - tpmrate = rate & 0x7f; - if(kbd_cmd(KEYB_C_TYPEM) != 0) - printf("Keyboard TYPEMATIC command timeout\n"); - else if(kbd_cmd(tpmrate) != 0) - printf("Keyboard TYPEMATIC data timeout\n"); -} - -/*---------------------------------------------------------------------------* - * Pass command to keyboard controller (8042) - *---------------------------------------------------------------------------*/ -static inline int -kbd_wait_output() -{ - u_int i; - - for (i = 100000; i; i--) - if ((inb(CONTROLLER_CTRL) & STATUS_INPBF) == 0) { - PCVT_KBD_DELAY(); - return 1; - } - return 0; -} - -static inline int -kbd_wait_input() -{ - u_int i; - - for (i = 100000; i; i--) - if ((inb(CONTROLLER_CTRL) & STATUS_OUTPBF) != 0) { - PCVT_KBD_DELAY(); - return 1; - } - return 0; -} - -static int -kbc_8042cmd(int val) -{ - - if (!kbd_wait_output()) - return (-1); - outb(CONTROLLER_CTRL, val); - - return (0); -} - -/*---------------------------------------------------------------------------* - * Pass command to keyboard itself - *---------------------------------------------------------------------------*/ -int -kbd_cmd(int val) -{ - - if (!kbd_wait_output()) - return (-1); - outb(CONTROLLER_DATA, val); - -#if PCVT_SHOWKEYS - showkey ('>', val); -#endif /* PCVT_SHOWKEYS */ - - return (0); -} - -/*---------------------------------------------------------------------------* - * Read response from keyboard - * NB: make sure to call spltty() before kbd_cmd(), kbd_response(). - *---------------------------------------------------------------------------*/ -int -kbd_response(void) -{ - u_char ch; - - if (!kbd_wait_input()) - return (-1); - ch = inb(CONTROLLER_DATA); - -#if PCVT_SHOWKEYS - showkey ('<', ch); -#endif /* PCVT_SHOWKEYS */ - - return ch; -} - -/*---------------------------------------------------------------------------* - * switch to/from PC scan code emulation mode - *---------------------------------------------------------------------------*/ -void -kbd_setmode(int mode) -{ -#if PCVT_SCANSET > 1 /* switch only if we are running */ - /* keyboard scancode 2 */ - - int cmd; - -#if PCVT_USEKBDSEC - cmd = COMMAND_SYSFLG | COMMAND_IRQEN; -#else - cmd = COMMAND_INHOVR | COMMAND_SYSFLG | COMMAND_IRQEN; -#endif - - if(mode == K_RAW) /* switch to scancode 1 ? */ - cmd |= COMMAND_PCSCAN; /* yes, setup command */ - - kbc_8042cmd(CONTR_WRITE); - kbd_cmd(cmd); - -#endif /* PCVT_SCANSET > 1 */ - - if(mode == K_RAW) - shift_down = meta_down = altgr_down = ctrl_down = 0; -} - - -#ifndef PCVT_NONRESP_KEYB_TRY -#define PCVT_NONRESP_KEYB_TRY 25 /* no of times to try to detect */ -#endif /* a nonresponding keyboard */ - -/*---------------------------------------------------------------------------* - * try to force keyboard into a known state .. - *---------------------------------------------------------------------------*/ -static -void doreset(void) -{ - int again = 0; - int once = 0; - int response, opri; - unsigned int wait_retries, seen_negative_response; - - /* Enable interrupts and keyboard, etc. */ - if(kbc_8042cmd(CONTR_WRITE) != 0) - printf("pcvt: doreset() - timeout controller write command\n"); - -#if PCVT_USEKBDSEC /* security enabled */ - -# if PCVT_SCANSET == 2 -# define KBDINITCMD COMMAND_SYSFLG|COMMAND_IRQEN -# else /* PCVT_SCANSET != 2 */ -# define KBDINITCMD COMMAND_PCSCAN|COMMAND_SYSFLG|COMMAND_IRQEN -# endif /* PCVT_SCANSET == 2 */ - -#else /* ! PCVT_USEKBDSEC */ /* security disabled */ - -# if PCVT_SCANSET == 2 -# define KBDINITCMD COMMAND_INHOVR|COMMAND_SYSFLG|COMMAND_IRQEN -# else /* PCVT_SCANSET != 2 */ -# define KBDINITCMD COMMAND_PCSCAN|COMMAND_INHOVR|COMMAND_SYSFLG\ - |COMMAND_IRQEN -# endif /* PCVT_SCANSET == 2 */ - -#endif /* PCVT_USEKBDSEC */ - - if(kbd_cmd(KBDINITCMD) != 0) - printf("pcvt: doreset() - timeout writing keyboard init command\n"); - - /* - * Discard any stale keyboard activity. The 0.1 boot code isn't - * very careful and sometimes leaves a KEYB_R_RESEND. - */ - while(inb(CONTROLLER_CTRL) & STATUS_OUTPBF) - kbd_response(); - - /* Start keyboard reset */ - - opri = spltty(); - - if(kbd_cmd(KEYB_C_RESET) != 0) - printf("pcvt: doreset() - timeout for keyboard reset command\n"); - - /* Wait for the first response to reset and handle retries */ - - while((response = kbd_response()) != KEYB_R_ACK) - { - if(response < 0) - { - if(!again) /* print message only once ! */ - printf("pcvt: doreset() - response != ack and response < 0 [one time only msg]\n"); - response = KEYB_R_RESEND; - } - if(response == KEYB_R_RESEND) - { - if(!again) /* print message only once ! */ - printf("pcvt: doreset() - got KEYB_R_RESEND response ... [one time only msg]\n"); - - if(++again > PCVT_NONRESP_KEYB_TRY) - { - printf("pcvt: doreset() - Caution - no PC keyboard detected!\n"); - keyboard_type = KB_UNKNOWN; - splx(opri); - return; - } - - if((kbd_cmd(KEYB_C_RESET) != 0) && (once == 0)) - { - once++; /* print message only once ! */ - printf("pcvt: doreset() - timeout for loop keyboard reset command [one time only msg]\n"); - } - } - } - - /* Wait for the second response to reset */ - - wait_retries = seen_negative_response = 0; - - while((response = kbd_response()) != KEYB_R_SELFOK) - { - /* - * Let's be a little more tolerant here... - * Receiving a -1 could indicate that the keyboard - * is not ready to answer just yet. - * Such cases have been noticed with e.g. Alps Membrane. - */ - - if(response < 0) - seen_negative_response = 1; - - if(seen_negative_response && (wait_retries >= 10)) - { - printf("pcvt: doreset() - response != OK and response < 0\n"); - - /* - * If KEYB_R_SELFOK never arrives, the loop will - * finish here unless the keyboard babbles or - * STATUS_OUTPBF gets stuck. - */ - break; - } - wait_retries++; - } - - splx(opri); - -#if PCVT_KEYBDID - -query_kbd_id: - - opri = spltty(); - - if(kbd_cmd(KEYB_C_ID) != 0) - { - printf("pcvt: doreset() - timeout for keyboard ID command\n"); - keyboard_type = KB_UNKNOWN; - } - else - { - -r_entry: - if((response = kbd_response()) == KEYB_R_MF2ID1) - { - if((response = kbd_response()) == KEYB_R_MF2ID2) - { - keyboard_type = KB_MFII; - } - else if(response == KEYB_R_RESEND) - { - /* - * Let's give other priority levels - * a chance instead of blocking at - * tty level. - */ - splx(opri); - goto query_kbd_id; - } - else if(response == KEYB_R_MF2ID2HP || - response == KEYB_R_MF2ID2TP) - { - /* - * Handle particular vendor responses - */ - keyboard_type = KB_MFII; - } - else - { - printf("\npcvt: doreset() - kbdid, response 2 = [%d]\n", - response); - keyboard_type = KB_UNKNOWN; - } - } - else if(response == KEYB_R_ACK) - { - goto r_entry; - } - else if(response == -1) - { - keyboard_type = KB_AT; - } - else - { - printf("\npcvt: doreset() - kbdid, response 1 = [%d]\n", response); - } - } - - splx(opri); - -#else /* PCVT_KEYBDID */ - - keyboard_type = KB_MFII; /* force it .. */ - -#endif /* PCVT_KEYBDID */ - -} - -/*---------------------------------------------------------------------------* - * init keyboard code - *---------------------------------------------------------------------------*/ -void -kbd_code_init(void) -{ - doreset(); - ovlinit(0); - keyboard_is_initialized = 1; -} - -/*---------------------------------------------------------------------------* - * init keyboard code, this initializes the keyboard subsystem - * just "a bit" so the very very first ddb session is able to - * get proper keystrokes - in other words, it's a hack .... - *---------------------------------------------------------------------------*/ -void -kbd_code_init1(void) -{ - doreset(); - keyboard_is_initialized = 1; -} - -/*---------------------------------------------------------------------------* - * init keyboard overlay table - *---------------------------------------------------------------------------*/ -static -void ovlinit(int force) -{ - register int i; - - if(force || ovlinitflag==0) - { - if(ovlinitflag == 0 && - (ovltbl = (Ovl_tbl *)malloc(sizeof(Ovl_tbl) * OVLTBL_SIZE, - M_DEVBUF, M_WAITOK)) == NULL) - panic("pcvt_kbd: malloc of Ovl_tbl failed"); - - for(i=0; i MAXKEYNUM) - return EINVAL; - - thisdef->keynum = key; - thisdef->type = key2ascii[key].type; - - if(key2ascii[key].unshift.subtype == STR) - { - bcopy((u_char *)(key2ascii[key].unshift.what.string), - thisdef->unshift, CODE_SIZE); - thisdef->subu = KBD_SUBT_STR; - } - else - { - bcopy("", thisdef->unshift, CODE_SIZE); - thisdef->subu = KBD_SUBT_FNC; - } - - if(key2ascii[key].shift.subtype == STR) - { - bcopy((u_char *)(key2ascii[key].shift.what.string), - thisdef->shift, CODE_SIZE); - thisdef->subs = KBD_SUBT_STR; - } - else - { - bcopy("",thisdef->shift,CODE_SIZE); - thisdef->subs = KBD_SUBT_FNC; - } - - if(key2ascii[key].ctrl.subtype == STR) - { - bcopy((u_char *)(key2ascii[key].ctrl.what.string), - thisdef->ctrl, CODE_SIZE); - thisdef->subc = KBD_SUBT_STR; - } - else - { - bcopy("",thisdef->ctrl,CODE_SIZE); - thisdef->subc = KBD_SUBT_FNC; - } - - /* deliver at least anything for ALTGR settings ... */ - - if(key2ascii[key].unshift.subtype == STR) - { - bcopy((u_char *)(key2ascii[key].unshift.what.string), - thisdef->altgr, CODE_SIZE); - thisdef->suba = KBD_SUBT_STR; - } - else - { - bcopy("",thisdef->altgr, CODE_SIZE); - thisdef->suba = KBD_SUBT_FNC; - } - return 0; -} - -/*---------------------------------------------------------------------------* - * get current key definition - *---------------------------------------------------------------------------*/ -static int -getckeydef(unsigned key, Ovl_tbl *thisdef) -{ - u_short type = key2ascii[key].type; - - if(key>MAXKEYNUM) - return EINVAL; - - if(type & KBD_OVERLOAD) - *thisdef = ovltbl[key2ascii[key].ovlindex]; - else - getokeydef(key,thisdef); - - return 0; -} - -/*---------------------------------------------------------------------------* - * translate keynumber and returns ptr to associated ascii string - * if key is bound to a function, executes it, and ret empty ptr - *---------------------------------------------------------------------------*/ -static u_char * -xlatkey2ascii(U_short key) -{ - static u_char capchar[2] = {0, 0}; -#if PCVT_META_ESC - static u_char metachar[3] = {0x1b, 0, 0}; -#else - static u_char metachar[2] = {0, 0}; -#endif - static Ovl_tbl thisdef; - int n; - void (*fnc)(void); - - if(key==0) /* ignore the NON-KEY */ - return 0; - - getckeydef(key&0x7F, &thisdef); /* get the current ASCII value */ - - thisdef.type &= KBD_MASK; - - if(key&0x80) /* special handling of ALT-KEYPAD */ - { - /* is the ALT Key released? */ - if(thisdef.type==KBD_META || thisdef.type==KBD_ALTGR) - { - if(altkpflag) /* have we been in altkp mode? */ - { - capchar[0] = altkpval; - altkpflag = 0; - altkpval = 0; - return capchar; - } - } - return 0; - } - - switch(thisdef.type) /* convert the keys */ - { - case KBD_BREAK: - case KBD_ASCII: - case KBD_FUNC: - fnc = NULL; - more_chars = NULL; - - if(altgr_down) - { - more_chars = (u_char *)thisdef.altgr; - } - else if(!ctrl_down && (shift_down || vsp->shift_lock)) - { - if(key2ascii[key].shift.subtype == STR) - more_chars = (u_char *)thisdef.shift; - else - fnc = key2ascii[key].shift.what.func; - } - - else if(ctrl_down) - { - if(key2ascii[key].ctrl.subtype == STR) - more_chars = (u_char *)thisdef.ctrl; - else - fnc = key2ascii[key].ctrl.what.func; - } - - else - { - if(key2ascii[key].unshift.subtype == STR) - more_chars = (u_char *)thisdef.unshift; - else - fnc = key2ascii[key].unshift.what.func; - } - - if(fnc) - (*fnc)(); /* execute function */ - - if((more_chars != NULL) && (more_chars[1] == 0)) - { - if(vsp->caps_lock && more_chars[0] >= 'a' - && more_chars[0] <= 'z') - { - capchar[0] = *more_chars - ('a'-'A'); - more_chars = capchar; - } - if(meta_down) - { -#if PCVT_META_ESC - metachar[1] = *more_chars; -#else - metachar[0] = *more_chars | 0x80; -#endif - more_chars = metachar; - } - } - return(more_chars); - - case KBD_KP: - fnc = NULL; - more_chars = NULL; - - if(meta_down) - { - switch(key) - { - case 95: /* / */ - altkpflag = 0; - more_chars = - (u_char *)"\033OQ"; - return(more_chars); - - case 100: /* * */ - altkpflag = 0; - more_chars = - (u_char *)"\033OR"; - return(more_chars); - - case 105: /* - */ - altkpflag = 0; - more_chars = - (u_char *)"\033OS"; - return(more_chars); - } - } - - if(meta_down || altgr_down) - { - if((n = keypad2num[key-91]) >= 0) - { - if(!altkpflag) - { - /* start ALT-KP mode */ - altkpflag = 1; - altkpval = 0; - } - altkpval *= 10; - altkpval += n; - } - else - altkpflag = 0; - return 0; - } - - if(!(vsp->num_lock)) - { - if(key2ascii[key].shift.subtype == STR) - more_chars = (u_char *)thisdef.shift; - else - fnc = key2ascii[key].shift.what.func; - } - else - { - if(key2ascii[key].unshift.subtype == STR) - more_chars = (u_char *)thisdef.unshift; - else - fnc = key2ascii[key].unshift.what.func; - } - - if(fnc) - (*fnc)(); /* execute function */ - return(more_chars); - - case KBD_CURSOR: - fnc = NULL; - more_chars = NULL; - - if(vsp->ckm) - { - if(key2ascii[key].shift.subtype == STR) - more_chars = (u_char *)thisdef.shift; - else - fnc = key2ascii[key].shift.what.func; - } - else - { - if(key2ascii[key].unshift.subtype == STR) - more_chars = (u_char *)thisdef.unshift; - else - fnc = key2ascii[key].unshift.what.func; - } - - if(fnc) - (*fnc)(); /* execute function */ - return(more_chars); - - case KBD_NUM: /* special kp-num handling */ - more_chars = NULL; - - if(meta_down) - { - more_chars = (u_char *)"\033OP"; /* PF1 */ - } - else - { - vsp->num_lock ^= 1; - update_led(); - } - return(more_chars); - - case KBD_RETURN: - more_chars = NULL; - - if(!(vsp->num_lock)) - { - more_chars = (u_char *)thisdef.shift; - } - else - { - more_chars = (u_char *)thisdef.unshift; - } - if(vsp->lnm && (*more_chars == '\r')) - { - more_chars = (u_char *)"\r\n"; /* CR LF */ - } - if(meta_down) - { -#if PCVT_META_ESC - metachar[1] = *more_chars; -#else - metachar[0] = *more_chars | 0x80; -#endif - more_chars = metachar; - } - return(more_chars); - - case KBD_META: /* these keys are */ - case KBD_ALTGR: /* handled directly */ - case KBD_SCROLL: /* by the keyboard */ - case KBD_CAPS: /* handler - they are */ - case KBD_SHFTLOCK: /* ignored here */ - case KBD_CTL: - case KBD_NONE: - default: - return 0; - } -} - -/*---------------------------------------------------------------------------* - * get keystrokes from the keyboard. - * if noblock = 0, wait until a key is pressed. - * else return NULL if no characters present. - *---------------------------------------------------------------------------*/ - -#if PCVT_KBD_FIFO -extern u_char pcvt_kbd_fifo[]; -extern int pcvt_kbd_rptr; -extern short pcvt_kbd_count; -#endif - -u_char * -sgetc(int noblock) -{ - u_char *cp; - u_char dt; - u_char key; - u_short type; - -#if PCVT_KBD_FIFO - int s; -#endif - - static u_char kbd_lastkey = 0; /* last keystroke */ - - static struct - { - u_char extended: 1; /* extended prefix seen */ - u_char ext1: 1; /* extended prefix 1 seen */ - u_char breakseen: 1; /* break code seen */ - u_char vshift: 1; /* virtual shift pending */ - u_char vcontrol: 1; /* virtual control pending */ - u_char sysrq: 1; /* sysrq pressed */ - } kbd_status = {0}; - -#ifdef XSERVER - static char keybuf[2] = {0}; /* the second 0 is a delimiter! */ -#endif /* XSERVER */ - -loop: - -#ifdef XSERVER - -#if PCVT_KBD_FIFO - - /* see if there is data from the keyboard available either from */ - /* the keyboard fifo or from the 8042 keyboard controller */ - - if ((( noblock) && (pcvt_kbd_count)) || - ((!noblock) && (inb(CONTROLLER_CTRL) & STATUS_OUTPBF))) - { - if (!noblock) /* source = 8042 */ - { - PCVT_KBD_DELAY(); /* 7 us delay */ - dt = inb(CONTROLLER_DATA); /* get from obuf */ - } - else /* source = keyboard fifo */ - { - dt = pcvt_kbd_fifo[pcvt_kbd_rptr++]; - s = spltty(); - pcvt_kbd_count--; - splx(s); - if (pcvt_kbd_rptr >= PCVT_KBD_FIFO_SZ) - pcvt_kbd_rptr = 0; - } - -#else /* !PCVT_KB_FIFO */ - - /* see if there is data from the keyboard available from the 8042 */ - - if (inb(CONTROLLER_CTRL) & STATUS_OUTPBF) - { - PCVT_KBD_DELAY(); /* 7 us delay */ - dt = inb(CONTROLLER_DATA); /* yes, get data */ - -#endif /* !PCVT_KBD_FIFO */ - - /* - * If x mode is active, only care for locking keys, then - * return the scan code instead of any key translation. - * Additionally, this prevents us from any attempts to - * execute pcvt internal functions caused by keys (such - * as screen flipping). - */ - - if (vsp->kbd_state == K_RAW) - { - keybuf[0] = dt; - -#if PCVT_EMU_MOUSE - /* - * The (mouse systems) mouse emulator. The mouse - * device allocates the first device node that is - * not used by a virtual terminal. (E.g., you have - * eight vtys, /dev/ttyv0 thru /dev/ttyv7, so the - * mouse emulator were /dev/ttyv8.) - * Currently the emulator only works if the keyboard - * is in raw (PC scan code) mode. This is the typic- - * al case when running the X server. - * It is activated if the num locks LED is active - * for the current vty, and if the mouse device - * has been opened by at least one process. It - * grabs the numerical keypad events (but only - * the "non-extended", so the separate arrow keys - * continue to work), and three keys for the "mouse - * buttons", preferrably F1 thru F3. Any of the - * eight directions (N, NE, E, SE, S, SW, W, NW) - * is supported, and frequent key presses (less - * than e.g. half a second between key presses) - * cause the emulator to accelerate the pointer - * movement by 6, while single presses result in - * single moves, so each point can be reached. - */ - /* - * NB: the following code is spagghetti. - * Only eat it with lotta tomato ketchup and - * Parmesan cheese:-) - */ - /* - * look whether we will have to steal the keys - * and cook them into mouse events - */ - if(vsp->num_lock && mouse.opened) - { - int button, accel, i; - enum mouse_dir - { - MOUSE_NW, MOUSE_N, MOUSE_NE, - MOUSE_W, MOUSE_0, MOUSE_E, - MOUSE_SW, MOUSE_S, MOUSE_SE - } - move; - struct timeval now; - /* from sys/kern/kern_time.c */ - extern void timevalsub - (struct timeval *, struct timeval *); - dev_t dummy = makedev(0, mouse.minor); - struct tty *mousetty = get_pccons(dummy); - /* - * strings to send for each mouse event, - * indexed by the movement direction and - * the "accelerator" value (TRUE for frequent - * key presses); note that the first byte - * of each string is actually overwritten - * by the current button value before sending - * the string - */ - static u_char mousestrings[2][MOUSE_SE+1][5] = - { - { - /* first, the non-accelerated strings*/ - {0x87, -1, 1, 0, 0}, /* NW */ - {0x87, 0, 1, 0, 0}, /* N */ - {0x87, 1, 1, 0, 0}, /* NE */ - {0x87, -1, 0, 0, 0}, /* W */ - {0x87, 0, 0, 0, 0}, /* 0 */ - {0x87, 1, 0, 0, 0}, /* E */ - {0x87, -1, -1, 0, 0}, /* SW */ - {0x87, 0, -1, 0, 0}, /* S */ - {0x87, 1, -1, 0, 0} /* SE */ - }, - { - /* now, 6 steps at once */ - {0x87, -4, 4, 0, 0}, /* NW */ - {0x87, 0, 6, 0, 0}, /* N */ - {0x87, 4, 4, 0, 0}, /* NE */ - {0x87, -6, 0, 0, 0}, /* W */ - {0x87, 0, 0, 0, 0}, /* 0 */ - {0x87, 6, 0, 0, 0}, /* E */ - {0x87, -4, -4, 0, 0}, /* SW */ - {0x87, 0, -6, 0, 0}, /* S */ - {0x87, 4, -4, 0, 0} /* SE */ - } - }; - - if(dt == 0xe0) - { - /* ignore extended scan codes */ - mouse.extendedseen = 1; - goto no_mouse_event; - } - if(mouse.extendedseen) - { - mouse.extendedseen = 0; - goto no_mouse_event; - } - mouse.extendedseen = 0; - - /* - * Note that we cannot use a switch here - * since we want to have the keycodes in - * a variable - */ - if((dt & 0x7f) == mousedef.leftbutton) { - button = 4; - goto do_button; - } - else if((dt & 0x7f) == mousedef.middlebutton) { - button = 2; - goto do_button; - } - else if((dt & 0x7f) == mousedef.rightbutton) { - button = 1; - do_button: - - /* - * i would really like to give - * some acustical support - * (pling/plong); i am not sure - * whether it is safe to call - * sysbeep from within an intr - * service, since it calls - * timeout in turn which mani- - * pulates the spl mask - jw - */ - -# define PLING sysbeep(PCVT_SYSBEEPF / 1500, 2) -# define PLONG sysbeep(PCVT_SYSBEEPF / 1200, 2) - - if(mousedef.stickybuttons) - { - if(dt & 0x80) { - mouse.breakseen = 1; - return (u_char *)0; - } - else if(mouse.buttons == button - && !mouse.breakseen) { - /* ignore repeats */ - return (u_char *)0; - } - else - mouse.breakseen = 0; - if(mouse.buttons == button) { - /* release it */ - mouse.buttons = 0; - PLONG; - } else { - /* - * eventually, release - * any other button, - * and stick this one - */ - mouse.buttons = button; - PLING; - } - } - else - { - if(dt & 0x80) { - mouse.buttons &= - ~button; - PLONG; - } - else if((mouse.buttons - & button) == 0) { - mouse.buttons |= - button; - PLING; - } - /*else: ignore same btn press*/ - } - move = MOUSE_0; - accel = 0; - } -# undef PLING -# undef PLONG - else switch(dt & 0x7f) - { - /* the arrow keys - KP 1 thru KP 9 */ - case 0x47: move = MOUSE_NW; goto do_move; - case 0x48: move = MOUSE_N; goto do_move; - case 0x49: move = MOUSE_NE; goto do_move; - case 0x4b: move = MOUSE_W; goto do_move; - case 0x4c: move = MOUSE_0; goto do_move; - case 0x4d: move = MOUSE_E; goto do_move; - case 0x4f: move = MOUSE_SW; goto do_move; - case 0x50: move = MOUSE_S; goto do_move; - case 0x51: move = MOUSE_SE; - do_move: - if(dt & 0x80) - /* - * arrow key break events are - * of no importance for us - */ - return (u_char *)0; - /* - * see whether the last move did - * happen "recently", i.e. before - * less than half a second - */ - now = time; - timevalsub(&now, &mouse.lastmove); - mouse.lastmove = time; - accel = (now.tv_sec == 0 - && now.tv_usec - < mousedef.acceltime); - break; - - default: /* not a mouse-emulating key */ - goto no_mouse_event; - } - mousestrings[accel][move][0] = - 0x80 + (~mouse.buttons & 7); - /* finally, send the string */ - for(i = 0; i < 5; i++) - (*linesw[mousetty->t_line].l_rint) - (mousestrings[accel][move][i], - mousetty); - return (u_char *)0; /* not a kbd event */ - } -no_mouse_event: - -#endif /* PCVT_EMU_MOUSE */ - - return ((u_char *)keybuf); - } - } - -#else /* !XSERVER */ - -# if PCVT_KBD_FIFO - - /* see if there is data from the keyboard available either from */ - /* the keyboard fifo or from the 8042 keyboard controller */ - - if ((( noblock) && (pcvt_kbd_count)) || - ((!noblock) && (inb(CONTROLLER_CTRL) & STATUS_OUTPBF))) - { - if (!noblock) /* source = 8042 */ - { - PCVT_KBD_DELAY(); /* 7 us delay */ - dt = inb(CONTROLLER_DATA); - } - else /* source = keyboard fifo */ - { - dt = pcvt_kbd_fifo[pcvt_kbd_rptr++]; /* yes, get it ! */ - s = spltty(); - pcvt_kbd_count--; - splx(s); - if (pcvt_kbd_rptr >= PCVT_KBD_FIFO_SZ) - pcvt_kbd_rptr = 0; - } - } - -#else /* !PCVT_KBD_FIFO */ - - /* see if there is data from the keyboard available from the 8042 */ - - if(inb(CONTROLLER_CTRL) & STATUS_OUTPBF) - { - PCVT_KBD_DELAY(); /* 7 us delay */ - dt = inb(CONTROLLER_DATA); /* yes, get data ! */ - } - -#endif /* !PCVT_KBD_FIFO */ - -#endif /* !XSERVER */ - - else - { - if(noblock) - return NULL; - else - goto loop; - } - -#if PCVT_SHOWKEYS - showkey (' ', dt); -#endif /* PCVT_SHOWKEYS */ - - /* lets look what we got */ - switch(dt) - { - case KEYB_R_OVERRUN0: /* keyboard buffer overflow */ - -#if PCVT_SCANSET == 2 - case KEYB_R_SELFOK: /* keyboard selftest ok */ -#endif /* PCVT_SCANSET == 2 */ - - case KEYB_R_ECHO: /* keyboard response to KEYB_C_ECHO */ - case KEYB_R_ACK: /* acknowledge after command has rx'd*/ - case KEYB_R_SELFBAD: /* keyboard selftest FAILED */ - case KEYB_R_DIAGBAD: /* keyboard self diagnostic failure */ - case KEYB_R_RESEND: /* keyboard wants us to resend cmnd */ - case KEYB_R_OVERRUN1: /* keyboard buffer overflow */ - break; - - case KEYB_R_EXT1: /* keyboard extended scancode pfx 2 */ - kbd_status.ext1 = 1; - /* FALLTHROUGH */ - case KEYB_R_EXT0: /* keyboard extended scancode pfx 1 */ - kbd_status.extended = 1; - break; - -#if PCVT_SCANSET == 2 - case KEYB_R_BREAKPFX: /* break code prefix for set 2 and 3 */ - kbd_status.breakseen = 1; - break; -#endif /* PCVT_SCANSET == 2 */ - - default: - goto regular; /* regular key */ - } - - if(noblock) - return NULL; - else - goto loop; - - /* got a normal scan key */ -regular: - -#if PCVT_SCANSET == 1 - kbd_status.breakseen = dt & 0x80 ? 1 : 0; - dt &= 0x7f; -#endif /* PCVT_SCANSET == 1 */ - - /* make a keycode from scan code */ - if(dt >= sizeof scantokey / sizeof(u_char)) - key = 0; - else - key = kbd_status.extended ? extscantokey[dt] : scantokey[dt]; - - if(kbd_status.ext1 && key == 64) - /* virtual control key */ - key = 129; - - kbd_status.extended = kbd_status.ext1 = 0; - -#if PCVT_CTRL_ALT_DEL /* Check for cntl-alt-del */ - if((key == 76) && ctrl_down && (meta_down||altgr_down)) - cpu_reset(); -#endif /* PCVT_CTRL_ALT_DEL */ - -#ifdef DDB /* Check for cntl-alt-esc */ - - if((key == 110) && ctrl_down && (meta_down || altgr_down)) - { - static u_char in_Debugger; - - if(!in_Debugger && pcvt_is_console) - { - in_Debugger = 1; - console_debugger(); - in_Debugger = 0; - if(noblock) - return NULL; - else - goto loop; - } - } -#endif /* DDB */ - - /* look for keys with special handling */ - if(key == 128) - { - /* - * virtual shift; sent around PrtScr, and around the arrow - * keys if the NumLck LED is on - */ - kbd_status.vshift = !kbd_status.breakseen; - key = 0; /* no key */ - } - else if(key == 129) - { - /* - * virtual control - the most ugly thingie at all - * the Pause key sends: - * - */ - if(!kbd_status.breakseen) - kbd_status.vcontrol = 1; - /* else: let the numlock hook clear this */ - key = 0; /* no key */ - } - else if(key == 90) - { - /* NumLock, look whether this is rather a Pause */ - if(kbd_status.vcontrol) - key = 126; - /* - * if this is the final break code of a Pause key, - * clear the virtual control status, too - */ - if(kbd_status.vcontrol && kbd_status.breakseen) - kbd_status.vcontrol = 0; - } - else if(key == 127) - { - /* - * a SysRq; some keyboards are brain-dead enough to - * repeat the SysRq key make code by sending PrtScr - * make codes; other keyboards do not repeat SysRq - * at all. We keep track of the SysRq state here. - */ - kbd_status.sysrq = !kbd_status.breakseen; - } - else if(key == 124) - { - /* - * PrtScr; look whether this is really PrtScr or rather - * a silly repeat of a SysRq key - */ - if(kbd_status.sysrq) - /* ignore the garbage */ - key = 0; - } - - /* in NOREPEAT MODE ignore the key if it was the same as before */ - - if(!kbrepflag && key == kbd_lastkey && !kbd_status.breakseen) - { - if(noblock) - return NULL; - else - goto loop; - } - - type = key2ascii[key].type; - - if(type & KBD_OVERLOAD) - type = ovltbl[key2ascii[key].ovlindex].type; - - type &= KBD_MASK; - - switch(type) - { - case KBD_SHFTLOCK: - if(!kbd_status.breakseen && key != kbd_lastkey) - { - vsp->shift_lock ^= 1; - } - break; - - case KBD_CAPS: - if(!kbd_status.breakseen && key != kbd_lastkey) - { - vsp->caps_lock ^= 1; - update_led(); - } - break; - - case KBD_SCROLL: - if(!kbd_status.breakseen && key != kbd_lastkey) - { - vsp->scroll_lock ^= 1; - update_led(); - - if(!(vsp->scroll_lock)) - { - /* someone may be sleeping */ - wakeup((caddr_t)&(vsp->scroll_lock)); - } - } - break; - - case KBD_SHIFT: - shift_down = kbd_status.breakseen ? 0 : 1; - break; - - case KBD_META: - meta_down = kbd_status.breakseen ? 0 : 0x80; - break; - - case KBD_ALTGR: - altgr_down = kbd_status.breakseen ? 0 : 1; - break; - - case KBD_CTL: - ctrl_down = kbd_status.breakseen ? 0 : 1; - break; - - case KBD_NONE: - default: - break; /* deliver a key */ - } - - if(kbd_status.breakseen) - { - key |= 0x80; - kbd_status.breakseen = 0; - kbd_lastkey = 0; /* -hv- I know this is a bug with */ - } /* N-Key-Rollover, but I ignore that */ - else /* because avoidance is too complicated */ - kbd_lastkey = key; - - cp = xlatkey2ascii(key); /* have a key */ - - if(cp == NULL && !noblock) - goto loop; - - return cp; -} - -/*---------------------------------------------------------------------------* - * reflect status of locking keys & set led's - *---------------------------------------------------------------------------*/ -static void -setlockkeys(int snc) -{ - vsp->scroll_lock = snc & 1; - vsp->num_lock = (snc & 2) ? 1 : 0; - vsp->caps_lock = (snc & 4) ? 1 : 0; - update_led(); -} - -/*---------------------------------------------------------------------------* - * remove a key definition - *---------------------------------------------------------------------------*/ -static int -rmkeydef(int key) -{ - register Ovl_tbl *ref; - - if(key==0 || key > MAXKEYNUM) - return EINVAL; - - if(key2ascii[key].type & KBD_OVERLOAD) - { - ref = &ovltbl[key2ascii[key].ovlindex]; - ref->keynum = 0; - ref->type = 0; - ref->unshift[0] = - ref->shift[0] = - ref->ctrl[0] = - ref->altgr[0] = 0; - key2ascii[key].type &= KBD_MASK; - } - return 0; -} - -/*---------------------------------------------------------------------------* - * overlay a key - *---------------------------------------------------------------------------*/ -static int -setkeydef(Ovl_tbl *data) -{ - register int i; - - if( data->keynum > MAXKEYNUM || - (data->type & KBD_MASK) == KBD_BREAK || - (data->type & KBD_MASK) > KBD_SHFTLOCK) - return EINVAL; - - data->unshift[KBDMAXOVLKEYSIZE] = - data->shift[KBDMAXOVLKEYSIZE] = - data->ctrl[KBDMAXOVLKEYSIZE] = - data->altgr[KBDMAXOVLKEYSIZE] = 0; - - data->subu = - data->subs = - data->subc = - data->suba = KBD_SUBT_STR; /* just strings .. */ - - data->type |= KBD_OVERLOAD; /* mark overloaded */ - - /* if key already overloaded, use that slot else find free slot */ - - if(key2ascii[data->keynum].type & KBD_OVERLOAD) - { - i = key2ascii[data->keynum].ovlindex; - } - else - { - for(i=0; ikeynum].type |= KBD_OVERLOAD; /* mark key */ - key2ascii[data->keynum].ovlindex = i; - - return 0; -} - -/*---------------------------------------------------------------------------* - * keyboard ioctl's entry - *---------------------------------------------------------------------------*/ -int -kbdioctl(Dev_t dev, int cmd, caddr_t data, int flag) -{ - int key; - - switch(cmd) - { - case KBDRESET: - doreset(); - ovlinit(1); - settpmrate(KBD_TPD500|KBD_TPM100); - setlockkeys(0); - break; - - case KBDGTPMAT: - *(int *)data = tpmrate; - break; - - case KBDSTPMAT: - settpmrate(*(int *)data); - break; - - case KBDGREPSW: - *(int *)data = kbrepflag; - break; - - case KBDSREPSW: - kbrepflag = (*(int *)data) & 1; - break; - - case KBDGLOCK: - *(int *)data = ( (vsp->scroll_lock) | - (vsp->num_lock * 2) | - (vsp->caps_lock * 4)); - break; - - case KBDSLOCK: - setlockkeys(*(int *)data); - break; - - case KBDGCKEY: - key = ((Ovl_tbl *)data)->keynum; - return getckeydef(key,(Ovl_tbl *)data); - - case KBDSCKEY: - key = ((Ovl_tbl *)data)->keynum; - return setkeydef((Ovl_tbl *)data); - - case KBDGOKEY: - key = ((Ovl_tbl *)data)->keynum; - return getokeydef(key,(Ovl_tbl *)data); - - case KBDRMKEY: - key = *(int *)data; - return rmkeydef(key); - - case KBDDEFAULT: - ovlinit(1); - break; - - default: - /* proceed with vga ioctls */ - return -1; - } - return 0; -} - -#if PCVT_EMU_MOUSE -/*--------------------------------------------------------------------------* - * mouse emulator ioctl - *--------------------------------------------------------------------------*/ -int -mouse_ioctl(Dev_t dev, int cmd, caddr_t data) -{ - struct mousedefs *def = (struct mousedefs *)data; - - switch(cmd) - { - case KBDMOUSEGET: - *def = mousedef; - break; - - case KBDMOUSESET: - mousedef = *def; - break; - - default: - return -1; - } - return 0; -} -#endif /* PCVT_EMU_MOUSE */ - -/*---------------------------------------------------------------------------* - * convert ISO-8859 style keycode into IBM 437 - *---------------------------------------------------------------------------*/ -static inline u_char -iso2ibm(u_char c) -{ - if(c < 0x80) - return c; - return iso2ibm437[c - 0x80]; -} - -/*---------------------------------------------------------------------------* - * build up a USL style keyboard map - *---------------------------------------------------------------------------*/ -void -get_usl_keymap(keymap_t *map) -{ - int i; - - bzero((caddr_t)map, sizeof(keymap_t)); - - map->n_keys = 0x59; /* that many keys we know about */ - - for(i = 1; i < N_KEYNUMS; i++) - { - Ovl_tbl kdef; - u_char c; - int j; - int idx = key2scan1[i]; - - if(idx == 0 || idx >= map->n_keys) - continue; - - getckeydef(i, &kdef); - kdef.type &= KBD_MASK; - switch(kdef.type) - { - case KBD_ASCII: - case KBD_RETURN: - map->key[idx].map[0] = iso2ibm(kdef.unshift[0]); - map->key[idx].map[1] = iso2ibm(kdef.shift[0]); - map->key[idx].map[2] = map->key[idx].map[3] = - iso2ibm(kdef.ctrl[0]); - map->key[idx].map[4] = map->key[idx].map[5] = - iso2ibm(c = kdef.altgr[0]); - /* - * XXX this is a hack - * since we currently do not map strings to AltGr + - * shift, we attempt to use the unshifted AltGr - * definition here and try to toggle the case - * this should at least work for ISO8859 letters, - * but also for (e.g.) russian KOI-8 style - */ - if((c & 0x7f) >= 0x40) - map->key[idx].map[5] = iso2ibm(c ^ 0x20); - break; - - case KBD_FUNC: - /* we are only interested in F1 thru F12 here */ - if(i >= 112 && i <= 123) { - map->key[idx].map[0] = i - 112 + 27; - map->key[idx].spcl = 0x80; - } - break; - - case KBD_SHIFT: - c = i == 44? 2 /* lSh */: 3 /* rSh */; goto special; - - case KBD_CAPS: - c = 4; goto special; - - case KBD_NUM: - c = 5; goto special; - - case KBD_SCROLL: - c = 6; goto special; - - case KBD_META: - c = 7; goto special; - - case KBD_CTL: - c = 9; goto special; - special: - for(j = 0; j < NUM_STATES; j++) - map->key[idx].map[j] = c; - map->key[idx].spcl = 0xff; - break; - - default: - break; - } - } -} - -/*---------------------------------------------------------------------------* - * switch keypad to numeric mode - *---------------------------------------------------------------------------*/ -void -vt_keynum(struct video_state *svsp) -{ - svsp->num_lock = 1; - update_led(); -} - -/*---------------------------------------------------------------------------* - * switch keypad to application mode - *---------------------------------------------------------------------------*/ -void -vt_keyappl(struct video_state *svsp) -{ - svsp->num_lock = 0; - update_led(); -} - -#if !PCVT_VT220KEYB /* !PCVT_VT220KEYB, HP-like Keyboard layout */ - -/*---------------------------------------------------------------------------* - * function bound to function key 1 - *---------------------------------------------------------------------------*/ -static void -fkey1(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_columns(vsp); - else - more_chars = (u_char *)"\033[17~"; /* F6 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[26~"; /* F14 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 2 - *---------------------------------------------------------------------------*/ -static void -fkey2(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - vt_ris(vsp); - else - more_chars = (u_char *)"\033[18~"; /* F7 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[28~"; /* HELP */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 3 - *---------------------------------------------------------------------------*/ -static void -fkey3(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_24l(vsp); - else - more_chars = (u_char *)"\033[19~"; /* F8 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[29~"; /* DO */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 4 - *---------------------------------------------------------------------------*/ -static void -fkey4(void) -{ - if(!meta_down) - { - -#if PCVT_SHOWKEYS - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_kbddbg(vsp); - else - more_chars = (u_char *)"\033[20~"; /* F9 */ -#else - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[20~"; /* F9 */ -#endif /* PCVT_SHOWKEYS */ - - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[31~"; /* F17 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 5 - *---------------------------------------------------------------------------*/ -static void -fkey5(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_bell(vsp); - else - more_chars = (u_char *)"\033[21~"; /* F10 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[32~"; /* F18 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 6 - *---------------------------------------------------------------------------*/ -static void -fkey6(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_sevenbit(vsp); - else - more_chars = (u_char *)"\033[23~"; /* F11 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[33~"; /* F19 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 7 - *---------------------------------------------------------------------------*/ -static void -fkey7(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_dspf(vsp); - else - more_chars = (u_char *)"\033[24~"; /* F12 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[34~"; /* F20 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 8 - *---------------------------------------------------------------------------*/ -static void -fkey8(void) -{ - if(!meta_down) - { - if((vsp->vt_pure_mode == M_HPVT) - && (vsp->which_fkl == SYS_FKL)) - toggl_awm(vsp); - else - more_chars = (u_char *)"\033[25~"; /* F13 */ - } - else - { - if(vsp->vt_pure_mode == M_PUREVT - || (vsp->which_fkl == USR_FKL)) - more_chars = (u_char *)"\033[35~"; /* F21 ??!! */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 9 - *---------------------------------------------------------------------------*/ -static void -fkey9(void) -{ - if(meta_down) - { - if(vsp->vt_pure_mode == M_PUREVT) - return; - - if(vsp->labels_on) /* toggle label display on/off */ - fkl_off(vsp); - else - fkl_on(vsp); - } - else - { - do_vgapage(0); - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 10 - *---------------------------------------------------------------------------*/ -static void -fkey10(void) -{ - if(meta_down) - { - if(vsp->vt_pure_mode != M_PUREVT && vsp->labels_on) - { - if(vsp->which_fkl == USR_FKL) - sw_sfkl(vsp); - else if(vsp->which_fkl == SYS_FKL) - sw_ufkl(vsp); - } - } - else - { - do_vgapage(1); - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 11 - *---------------------------------------------------------------------------*/ -static void -fkey11(void) -{ - if(meta_down) - { - if(vsp->vt_pure_mode == M_PUREVT) - set_emulation_mode(vsp, M_HPVT); - else if(vsp->vt_pure_mode == M_HPVT) - set_emulation_mode(vsp, M_PUREVT); - } - else - { - do_vgapage(2); - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 12 - *---------------------------------------------------------------------------*/ -static void -fkey12(void) -{ - if(meta_down) - { - if(current_video_screen + 1 > totalscreens-1) - do_vgapage(0); - else - do_vgapage(current_video_screen + 1); - } - else - { - do_vgapage(3); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 1 - *---------------------------------------------------------------------------*/ -static void -sfkey1(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[0]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[0]]); - } - else - { - if(vsp->ukt.length[9]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[9]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 2 - *---------------------------------------------------------------------------*/ -static void -sfkey2(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[1]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[1]]); - } - else - { - if(vsp->ukt.length[11]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[11]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 3 - *---------------------------------------------------------------------------*/ -static void -sfkey3(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[2]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[2]]); - } - else - { - if(vsp->ukt.length[12]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[12]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 4 - *---------------------------------------------------------------------------*/ -static void -sfkey4(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[3]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[3]]); - } - else - { - if(vsp->ukt.length[13]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[13]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 5 - *---------------------------------------------------------------------------*/ -static void -sfkey5(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[4]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[4]]); - } - else - { - if(vsp->ukt.length[14]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[14]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 6 - *---------------------------------------------------------------------------*/ -static void -sfkey6(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[6]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[6]]); - } - else - { - if(vsp->ukt.length[15]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[15]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 7 - *---------------------------------------------------------------------------*/ -static void -sfkey7(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[7]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[7]]); - } - else - { - if(vsp->ukt.length[16]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[16]]); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 8 - *---------------------------------------------------------------------------*/ -static void -sfkey8(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[8]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[8]]); - } - else - { - if(vsp->ukt.length[17]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[17]]); - } -} -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 9 - *---------------------------------------------------------------------------*/ -static void -sfkey9(void) -{ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 10 - *---------------------------------------------------------------------------*/ -static void -sfkey10(void) -{ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 11 - *---------------------------------------------------------------------------*/ -static void -sfkey11(void) -{ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 12 - *---------------------------------------------------------------------------*/ -static void -sfkey12(void) -{ -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 1 - *---------------------------------------------------------------------------*/ -static void -cfkey1(void) -{ - if(meta_down) - do_vgapage(0); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 2 - *---------------------------------------------------------------------------*/ -static void -cfkey2(void) -{ - if(meta_down) - do_vgapage(1); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 3 - *---------------------------------------------------------------------------*/ -static void -cfkey3(void) -{ - if(meta_down) - do_vgapage(2); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 4 - *---------------------------------------------------------------------------*/ -static void -cfkey4(void) -{ - if(meta_down) - do_vgapage(3); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 5 - *---------------------------------------------------------------------------*/ -static void -cfkey5(void) -{ - if(meta_down) - do_vgapage(4); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 6 - *---------------------------------------------------------------------------*/ -static void -cfkey6(void) -{ - if(meta_down) - do_vgapage(5); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 7 - *---------------------------------------------------------------------------*/ -static void -cfkey7(void) -{ - if(meta_down) - do_vgapage(6); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 8 - *---------------------------------------------------------------------------*/ -static void -cfkey8(void) -{ - if(meta_down) - do_vgapage(7); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 9 - *---------------------------------------------------------------------------*/ -static void -cfkey9(void) -{ - if(meta_down) - do_vgapage(8); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 10 - *---------------------------------------------------------------------------*/ -static void -cfkey10(void) -{ - if(meta_down) - do_vgapage(9); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 11 - *---------------------------------------------------------------------------*/ -static void -cfkey11(void) -{ - if(meta_down) - do_vgapage(10); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 12 - *---------------------------------------------------------------------------*/ -static void -cfkey12(void) -{ - if(meta_down) - do_vgapage(11); -} - -#else /* PCVT_VT220 - VT220-like Keyboard layout */ - -/*---------------------------------------------------------------------------* - * function bound to function key 1 - *---------------------------------------------------------------------------*/ -static void -fkey1(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[23~"; /* F11 */ - else - do_vgapage(0); -} - -/*---------------------------------------------------------------------------* - * function bound to function key 2 - *---------------------------------------------------------------------------*/ -static void -fkey2(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[24~"; /* F12 */ - else - do_vgapage(1); -} - -/*---------------------------------------------------------------------------* - * function bound to function key 3 - *---------------------------------------------------------------------------*/ -static void -fkey3(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[25~"; /* F13 */ - else - do_vgapage(2); -} - -/*---------------------------------------------------------------------------* - * function bound to function key 4 - *---------------------------------------------------------------------------*/ -static void -fkey4(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[26~"; /* F14 */ - else - do_vgapage(3); -} - -/*---------------------------------------------------------------------------* - * function bound to function key 5 - *---------------------------------------------------------------------------*/ -static void -fkey5(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[28~"; /* Help */ - else - { - if((current_video_screen + 1) > totalscreens-1) - do_vgapage(0); - else - do_vgapage(current_video_screen + 1); - } -} - -/*---------------------------------------------------------------------------* - * function bound to function key 6 - *---------------------------------------------------------------------------*/ -static void -fkey6(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[29~"; /* DO */ - else - more_chars = (u_char *)"\033[17~"; /* F6 */ -} - -/*---------------------------------------------------------------------------* - * function bound to function key 7 - *---------------------------------------------------------------------------*/ -static void -fkey7(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[31~"; /* F17 */ - else - more_chars = (u_char *)"\033[18~"; /* F7 */ -} - -/*---------------------------------------------------------------------------* - * function bound to function key 8 - *---------------------------------------------------------------------------*/ -static void -fkey8(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[32~"; /* F18 */ - else - more_chars = (u_char *)"\033[19~"; /* F8 */ -} - -/*---------------------------------------------------------------------------* - * function bound to function key 9 - *---------------------------------------------------------------------------*/ -static void -fkey9(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[33~"; /* F19 */ - else - more_chars = (u_char *)"\033[20~"; /* F9 */ -} - -/*---------------------------------------------------------------------------* - * function bound to function key 10 - *---------------------------------------------------------------------------*/ -static void -fkey10(void) -{ - if(meta_down) - more_chars = (u_char *)"\033[34~"; /* F20 */ - else - more_chars = (u_char *)"\033[21~"; /* F10 */ -} - -/*---------------------------------------------------------------------------* - * function bound to function key 11 - *---------------------------------------------------------------------------*/ -static void -fkey11(void) -{ - if(meta_down) - more_chars = (u_char *)"\0x8FP"; /* PF1 */ - else - more_chars = (u_char *)"\033[23~"; /* F11 */ -} - -/*---------------------------------------------------------------------------* - * function bound to function key 12 - *---------------------------------------------------------------------------*/ -static void -fkey12(void) -{ - if(meta_down) - more_chars = (u_char *)"\0x8FQ"; /* PF2 */ - else - more_chars = (u_char *)"\033[24~"; /* F12 */ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 1 - *---------------------------------------------------------------------------*/ -static void -sfkey1(void) -{ - if(meta_down) - { - if(vsp->ukt.length[6]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[6]]); - else - more_chars = (u_char *)"\033[23~"; /* F11 */ - } - else - { - do_vgapage(4); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 2 - *---------------------------------------------------------------------------*/ -static void -sfkey2(void) -{ - if(meta_down) - { - if(vsp->ukt.length[7]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[7]]); - else - more_chars = (u_char *)"\033[24~"; /* F12 */ - } - else - { - do_vgapage(5); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 3 - *---------------------------------------------------------------------------*/ -static void -sfkey3(void) -{ - if(meta_down) - { - if(vsp->ukt.length[8]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[8]]); - else - more_chars = (u_char *)"\033[25~"; /* F13 */ - } - else - { - do_vgapage(6); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 4 - *---------------------------------------------------------------------------*/ -static void -sfkey4(void) -{ - if(meta_down) - { - if(vsp->ukt.length[9]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[9]]); - else - more_chars = (u_char *)"\033[26~"; /* F14 */ - } - else - { - do_vgapage(7); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 5 - *---------------------------------------------------------------------------*/ -static void -sfkey5(void) -{ - if(meta_down) - { - if(vsp->ukt.length[11]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[11]]); - else - more_chars = (u_char *)"\033[28~"; /* Help */ - } - else - { - if(current_video_screen <= 0) - do_vgapage(totalscreens-1); - else - do_vgapage(current_video_screen - 1); - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 6 - *---------------------------------------------------------------------------*/ -static void -sfkey6(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[0]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[0]]); - else - more_chars = (u_char *)"\033[17~"; /* F6 */ - } - else if(vsp->ukt.length[12]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[12]]); - else - more_chars = (u_char *)"\033[29~"; /* DO */ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 7 - *---------------------------------------------------------------------------*/ -static void -sfkey7(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[1]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[1]]); - else - more_chars = (u_char *)"\033[18~"; /* F7 */ - } - else if(vsp->ukt.length[14]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[14]]); - else - more_chars = (u_char *)"\033[31~"; /* F17 */ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 8 - *---------------------------------------------------------------------------*/ -static void -sfkey8(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[2]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[2]]); - else - more_chars = (u_char *)"\033[19~"; /* F8 */ - } - else if(vsp->ukt.length[14]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[15]]); - else - more_chars = (u_char *)"\033[32~"; /* F18 */ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 9 - *---------------------------------------------------------------------------*/ -static void -sfkey9(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[3]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[3]]); - else - more_chars = (u_char *)"\033[20~"; /* F9 */ - } - else if(vsp->ukt.length[16]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[16]]); - else - more_chars = (u_char *)"\033[33~"; /* F19 */ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 10 - *---------------------------------------------------------------------------*/ -static void -sfkey10(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[4]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[4]]); - else - more_chars = (u_char *)"\033[21~"; /* F10 */ - } - else if(vsp->ukt.length[17]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[17]]); - else - more_chars = (u_char *)"\033[34~"; /* F20 */ -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 11 - *---------------------------------------------------------------------------*/ -static void -sfkey11(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[6]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[6]]); - else - more_chars = (u_char *)"\033[23~"; /* F11 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to SHIFTED function key 12 - *---------------------------------------------------------------------------*/ -static void -sfkey12(void) -{ - if(!meta_down) - { - if(vsp->ukt.length[7]) /* entry available ? */ - more_chars = (u_char *) - &(vsp->udkbuf[vsp->ukt.first[7]]); - else - more_chars = (u_char *)"\033[24~"; /* F12 */ - } -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 1 - *---------------------------------------------------------------------------*/ -static void -cfkey1(void) -{ - if(vsp->which_fkl == SYS_FKL) - toggl_columns(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 2 - *---------------------------------------------------------------------------*/ -static void -cfkey2(void) -{ - if(vsp->which_fkl == SYS_FKL) - vt_ris(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 3 - *---------------------------------------------------------------------------*/ -static void -cfkey3(void) -{ - if(vsp->which_fkl == SYS_FKL) - toggl_24l(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 4 - *---------------------------------------------------------------------------*/ -static void -cfkey4(void) -{ - -#if PCVT_SHOWKEYS - if(vsp->which_fkl == SYS_FKL) - toggl_kbddbg(vsp); -#endif /* PCVT_SHOWKEYS */ - -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 5 - *---------------------------------------------------------------------------*/ -static void -cfkey5(void) -{ - if(vsp->which_fkl == SYS_FKL) - toggl_bell(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 6 - *---------------------------------------------------------------------------*/ -static void -cfkey6(void) -{ - if(vsp->which_fkl == SYS_FKL) - toggl_sevenbit(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 7 - *---------------------------------------------------------------------------*/ -static void -cfkey7(void) -{ - if(vsp->which_fkl == SYS_FKL) - toggl_dspf(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 8 - *---------------------------------------------------------------------------*/ -static void -cfkey8(void) -{ - if(vsp->which_fkl == SYS_FKL) - toggl_awm(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 9 - *---------------------------------------------------------------------------*/ -static void -cfkey9(void) -{ - if(vsp->labels_on) /* toggle label display on/off */ - fkl_off(vsp); - else - fkl_on(vsp); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 10 - *---------------------------------------------------------------------------*/ -static void -cfkey10(void) -{ - if(vsp->labels_on) /* toggle user/system fkey labels */ - { - if(vsp->which_fkl == USR_FKL) - sw_sfkl(vsp); - else if(vsp->which_fkl == SYS_FKL) - sw_ufkl(vsp); - } -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 11 - *---------------------------------------------------------------------------*/ -static void -cfkey11(void) -{ - if(vsp->vt_pure_mode == M_PUREVT) - set_emulation_mode(vsp, M_HPVT); - else if(vsp->vt_pure_mode == M_HPVT) - set_emulation_mode(vsp, M_PUREVT); -} - -/*---------------------------------------------------------------------------* - * function bound to control function key 12 - *---------------------------------------------------------------------------*/ -static void -cfkey12(void) -{ -} - -#endif /* PCVT_VT220KEYB */ - -/* ------------------------------- EOF -------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/pcvt_kbd.h b/sys/arch/i386/isa/pcvt/pcvt_kbd.h deleted file mode 100644 index d5ccc8330f50..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_kbd.h +++ /dev/null @@ -1,574 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore and Holger Veit. - * - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz and Don Ahn. - * - * This code is derived from software contributed to 386BSD by - * Holger Veit. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis, - * Brian Dunford-Shore and Joerg Wunsch. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_kbd.h, 3.32, Last Edit-Date: [Tue Oct 3 11:19:48 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_kbd.h VT220 Driver Keyboard Interface Header - * ------------------------------------------------------ - * -hm split off from pcvt_kbd.c - * -hm patch from Lon Willett to fix mapping of Control-R scancode - * -hm ---------------- Release 3.30 ----------------------- - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -/*---------------------------------------------------------------------------* - * this is one sub-entry for the table. the type can be either - * "pointer to a string" or "pointer to a function" - *---------------------------------------------------------------------------*/ -typedef struct -{ - u_char subtype; /* subtype, string or function */ -#ifdef PCVT_ALT_ENH - u_short str_leng; /* if string, stringlength */ -#endif - union what - { - u_char *string; /* ptr to string, null terminated */ - void (*func)(void); /* ptr to function */ - } what; -} entry; - -/*---------------------------------------------------------------------------* - * this is the "outer" table - *---------------------------------------------------------------------------*/ -typedef struct -{ - u_short type; /* type of key */ - u_short ovlindex; /* -hv- index into overload table */ - entry unshift; /* normal default codes/funcs */ - entry shift; /* shifted default codes/funcs */ - entry ctrl; /* control default codes/funcs */ -#ifdef PCVT_ALT_ENH - entry alt; /* normal default codes/funcs */ - entry alt_shift; /* shifted default codes/funcs */ - entry alt_ctrl; /* control default codes/funcs */ - entry alt_ctrl_shift; /* normal default codes/funcs */ -#endif -} Keycap_def; - -#define IDX0 0 /* default indexvalue into ovl table */ - -#define STR KBD_SUBT_STR /* subtype = ptr to string */ -#define FNC KBD_SUBT_FNC /* subtype = ptr to function */ - -#define CODE_SIZE 5 - -/*---------------------------------------------------------------------------* - * the overlaytable table is a static fixed size scratchpad where all the - * overloaded definitions are stored. - * an entry consists of a short (holding the new type attribute) and - * four entries for a new keydefinition. - *---------------------------------------------------------------------------*/ - -#define OVLTBL_SIZE 64 /* 64 keys can be overloaded */ - -#define Ovl_tbl struct kbd_ovlkey - -static Ovl_tbl *ovltbl; /* the table itself */ - -static int ovlinitflag = 0; /* the init flag for the table */ - -/* - * key codes >= 128 denote "virtual" shift/control - * They are resolved before any keymapping is handled - */ - -#if PCVT_SCANSET == 2 -static u_char scantokey[] = { -/* -0- -1- -2- -3- -4- -5- -6- -7- This layout is valid for US only */ -/*00*/ 0,120, 0,116,114,112,113,123, /* ?? F9 ?? F5 F3 F1 F2 F12 */ -/*08*/ 0,121,119,117,115, 16, 1, 0, /* ?? F10 F8 F6 F4 TAB ` ?? */ -/*10*/ 0, 60, 44, 0, 58, 17, 2, 0, /* ?? ALl SHl ?? CTl Q 1 ?? */ -/*18*/ 0, 0, 46, 32, 31, 18, 3, 0, /* ?? Z S A W 2 ?? ?? */ -/*20*/ 0, 48, 47, 33, 19, 5, 4, 0, /* ?? C X D E 4 3 ?? */ -/*28*/ 0, 61, 49, 34, 21, 20, 6, 0, /* ?? SP V F T R 5 ?? */ -/*30*/ 0, 51, 50, 36, 35, 22, 7, 0, /* ?? N B H G Y 6 ?? */ -/*38*/ 0, 0, 52, 37, 23, 8, 9, 0, /* ?? ?? M J U 7 8 ?? */ -/*40*/ 0, 53, 38, 24, 25, 11, 10, 0, /* ?? , K I O 0 9 ?? */ -/*48*/ 0, 54, 55, 39, 40, 26, 12, 0, /* ?? . / L ; P - ?? */ -/*50*/ 0, 0, 41, 0, 27, 13, 0, 0, /* ?? ?? " ?? [ = ?? ?? */ -/*58*/ 30, 57, 43, 28, 0, 29, 0, 0, /* CAP SHr ENT ] ?? \ ?? ?? */ -/*60*/ 0, 45, 0, 0, 0, 0, 15, 0, /* ?? NL1 ?? ?? ?? ?? BS ?? */ -/*68*/ 0, 93, 0, 92, 91, 0, 0, 0, /* ?? KP1 ?? KP4 KP7 ?? ?? ?? */ -/*70*/ 99,104, 98, 97,102, 96,110, 90, /* KP0 KP. KP2 KP5 KP6 KP8 ESC NUM */ -/*78*/ 122,106,103,105,100,101,125, 0, /* F11 KP+ KP3 KP- KP* KP9 LOC ?? */ -/*80*/ 0, 0, 0,118,127 /* ?? ?? ?? F7 SyRQ */ -}; - -static u_char extscantokey[] = { -/* -0- -1- -2- -3- -4- -5- -6- -7- This layout is valid for US only */ -/*00*/ 0,120, 0,116,114,112,113,123, /* ?? F9 ?? F5 F3 F1 F2 F12 */ -/*08*/ 0,121,119,117,115, 16, 1, 0, /* ?? F10 F8 F6 F4 TAB ` ?? */ -/*10*/ 0, 62,128, 0, 64, 17, 2, 0, /* ?? ALr vSh ?? CTr Q 1 ?? */ -/*18*/ 0, 0, 46, 32, 31, 18, 3, 0, /* ?? Z S A W 2 ?? ?? */ -/*20*/ 0, 48, 47, 33, 19, 5, 4, 0, /* ?? C X D E 4 3 ?? */ -/*28*/ 0, 61, 49, 34, 21, 20, 6, 0, /* ?? SP V F T R 5 ?? */ -/*30*/ 0, 51, 50, 36, 35, 22, 7, 0, /* ?? N B H G Y 6 ?? */ -/*38*/ 0, 0, 52, 37, 23, 8, 9, 0, /* ?? ?? M J U 7 8 ?? */ -/*40*/ 0, 53, 38, 24, 25, 11, 10, 0, /* ?? , K I O 0 9 ?? */ -/*48*/ 0, 54, 95, 39, 40, 26, 12, 0, /* ?? . KP/ L ; P - ?? */ -/*50*/ 0, 0, 41, 0, 27, 13, 0, 0, /* ?? ?? " ?? [ = ?? ?? */ -/*58*/ 30, 57,108, 28, 0, 29, 0, 0, /* CAP SHr KPE ] ?? \ ?? ?? */ -/*60*/ 0, 45, 0, 0, 0, 0, 15, 0, /* ?? NL1 ?? ?? ?? ?? BS ?? */ -/*68*/ 0, 81, 0, 79, 80, 0, 0, 0, /* ?? END ?? LA HOM ?? ?? ?? */ -/*70*/ 75, 76, 84, 97, 89, 83,110, 90, /* INS DEL DA KP5 RA UA ESC NUM */ -/*78*/ 122,106, 86,105,124, 85,126, 0, /* F11 KP+ PD KP- PSc PU Brk ?? */ -/*80*/ 0, 0, 0,118,127 /* ?? ?? ?? F7 SysRq */ -}; - -#else /* PCVT_SCANSET != 2 */ - -static u_char scantokey[] = { -/* -0- -1- -2- -3- -4- -5- -6- -7- This layout is valid for US only */ -/*00*/ 0,110, 2, 3, 4, 5, 6, 7, /* ?? ESC 1 2 3 4 5 6 */ -/*08*/ 8, 9, 10, 11, 12, 13, 15, 16, /* 7 8 9 0 - = BS TAB */ -/*10*/ 17, 18, 19, 20, 21, 22, 23, 24, /* Q W E R T Y U I */ -/*18*/ 25, 26, 27, 28, 43, 58, 31, 32, /* O P [ ] ENT CTl A S */ -/*20*/ 33, 34, 35, 36, 37, 38, 39, 40, /* D F G H J K L ; */ -/*28*/ 41, 1, 44, 29, 46, 47, 48, 49, /* ' ` SHl \ Z X C V */ -/*30*/ 50, 51, 52, 53, 54, 55, 57,100, /* B N M , . / SHr KP* */ -/*38*/ 60, 61, 30,112,113,114,115,116, /* ALl SP CAP F1 F2 F3 F4 F5 */ -/*40*/ 117,118,119,120,121, 90,125, 91, /* F6 F7 F8 F9 F10 NUM LOC KP7 */ -/*48*/ 96,101,105, 92, 97,102,106, 93, /* KP8 KP9 KP- KP4 KP5 KP6 KP+ KP1 */ -/*50*/ 98,103, 99,104,127, 0, 45,122, /* KP2 KP3 KP0 KP. SyRq?? NL1 F11 */ -/*58*/ 123 /* F12 */ -}; - -static u_char extscantokey[] = { -/* -0- -1- -2- -3- -4- -5- -6- -7- This layout is valid for US only */ -/*00*/ 0,110, 2, 3, 4, 5, 6, 7, /* ?? ESC 1 2 3 4 5 6 */ -/*08*/ 8, 9, 10, 11, 12, 13, 15, 16, /* 7 8 9 0 - = BS TAB */ -/*10*/ 17, 18, 19, 20, 21, 22, 23, 24, /* Q W E R T Y U I */ -/*18*/ 25, 26, 27, 28,108, 64, 31, 32, /* O P [ ] KPE CTr A S */ -/*20*/ 33, 34, 35, 36, 37, 38, 39, 40, /* D F G H J K L ; */ -/*28*/ 41, 1,128, 29, 46, 47, 48, 49, /* ' ` vSh \ Z X C V */ -/*30*/ 50, 51, 52, 53, 54, 95, 57,124, /* B N M , . KP/ SHr KP* */ -/*38*/ 62, 61, 30,112,113,114,115,116, /* ALr SP CAP F1 F2 F3 F4 F5 */ -/*40*/ 117,118,119,120,121, 90,126, 80, /* F6 F7 F8 F9 F10 NUM Brk HOM */ -/*48*/ 83, 85,105, 79, 97, 89,106, 81, /* UA PU KP- LA KP5 RA KP+ END */ -/*50*/ 84, 86, 75, 76, 0, 0, 45,122, /* DA PD INS DEL ?? ?? NL1 F11 */ -/*58*/ 123, /* F12 */ -}; -#endif /* PCVT_SCANSET == 2 */ - -static Keycap_def key2ascii[] = -{ - -#ifdef PCVT_ALT_ENH - -#define C (u_char *) -#define U (u_short) -#define V (void *) -#define S STR -#define F FNC -#define I IDX0 - -#define DFAULT {S, 0, { "" }} - -/* DONT EVER OVERLOAD KEY 0, THIS IS A KEY THAT MUSTN'T EXIST */ - -/* type index unshift shift ctrl alt alt_shift alt_ctrl alt_ctrl_shift */ -/* -------------------------------------------------------------------------------------------------------------------------------------------------- */ -/* 0*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 1*/ { KBD_ASCII, I, {S,1, { "`" }}, {S,1, { "~" }}, {S,1, { "`" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 2*/ { KBD_ASCII, I, {S,1, { "1" }}, {S,1, { "!" }}, {S,1, { "1" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 3*/ { KBD_ASCII, I, {S,1, { "2" }}, {S,1, { "@" }}, {S,1, { "\000" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 4*/ { KBD_ASCII, I, {S,1, { "3" }}, {S,1, { "#" }}, {S,1, { "3" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 5*/ { KBD_ASCII, I, {S,1, { "4" }}, {S,1, { "$" }}, {S,1, { "4" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 6*/ { KBD_ASCII, I, {S,1, { "5" }}, {S,1, { "%" }}, {S,1, { "5" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 7*/ { KBD_ASCII, I, {S,1, { "6" }}, {S,1, { "^" }}, {S,1, { "\036" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 8*/ { KBD_ASCII, I, {S,1, { "7" }}, {S,1, { "&" }}, {S,1, { "7" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 9*/ { KBD_ASCII, I, {S,1, { "8" }}, {S,1, { "*" }}, {S,1, { "8" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 10*/ { KBD_ASCII, I, {S,1, { "9" }}, {S,1, { "(" }}, {S,1, { "9" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 11*/ { KBD_ASCII, I, {S,1, { "0" }}, {S,1, { ")" }}, {S,1, { "0" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 12*/ { KBD_ASCII, I, {S,1, { "-" }}, {S,1, { "_" }}, {S,1, { "\037" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 13*/ { KBD_ASCII, I, {S,1, { "=" }}, {S,1, { "+" }}, {S,1, { "=" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 14*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 15*/ { KBD_ASCII, I, {S,1, { "\177" }}, {S,1, { "\010" }}, {S,1, { "\177" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 16*/ { KBD_ASCII, I, {S,1, { "\t" }}, {S,1, { "\t" }}, {S,1, { "\t" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 17*/ { KBD_ASCII, I, {S,1, { "q" }}, {S,1, { "Q" }}, {S,1, { "\021" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 18*/ { KBD_ASCII, I, {S,1, { "w" }}, {S,1, { "W" }}, {S,1, { "\027" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 19*/ { KBD_ASCII, I, {S,1, { "e" }}, {S,1, { "E" }}, {S,1, { "\005" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 20*/ { KBD_ASCII, I, {S,1, { "r" }}, {S,1, { "R" }}, {S,1, { "\022" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 21*/ { KBD_ASCII, I, {S,1, { "t" }}, {S,1, { "T" }}, {S,1, { "\024" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 22*/ { KBD_ASCII, I, {S,1, { "y" }}, {S,1, { "Y" }}, {S,1, { "\031" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 23*/ { KBD_ASCII, I, {S,1, { "u" }}, {S,1, { "U" }}, {S,1, { "\025" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 24*/ { KBD_ASCII, I, {S,1, { "i" }}, {S,1, { "I" }}, {S,1, { "\011" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 25*/ { KBD_ASCII, I, {S,1, { "o" }}, {S,1, { "O" }}, {S,1, { "\017" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 26*/ { KBD_ASCII, I, {S,1, { "p" }}, {S,1, { "P" }}, {S,1, { "\020" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 27*/ { KBD_ASCII, I, {S,1, { "[" }}, {S,1, { "{" }}, {S,1, { "\033" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 28*/ { KBD_ASCII, I, {S,1, { "]" }}, {S,1, { "}" }}, {S,1, { "\035" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 29*/ { KBD_ASCII, I, {S,1, { "\\" }}, {S,1, { "|" }}, {S,1, { "\034" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -#ifdef PCVT_CAPS_IS_CTRL -/* 30*/ { KBD_CTL, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -#else -/* 30*/ { KBD_CAPS, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -#endif -/* 31*/ { KBD_ASCII, I, {S,1, { "a" }}, {S,1, { "A" }}, {S,1, { "\001" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 32*/ { KBD_ASCII, I, {S,1, { "s" }}, {S,1, { "S" }}, {S,1, { "\023" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 33*/ { KBD_ASCII, I, {S,1, { "d" }}, {S,1, { "D" }}, {S,1, { "\004" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 34*/ { KBD_ASCII, I, {S,1, { "f" }}, {S,1, { "F" }}, {S,1, { "\006" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 35*/ { KBD_ASCII, I, {S,1, { "g" }}, {S,1, { "G" }}, {S,1, { "\007" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 36*/ { KBD_ASCII, I, {S,1, { "h" }}, {S,1, { "H" }}, {S,1, { "\010" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 37*/ { KBD_ASCII, I, {S,1, { "j" }}, {S,1, { "J" }}, {S,1, { "\n" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 38*/ { KBD_ASCII, I, {S,1, { "k" }}, {S,1, { "K" }}, {S,1, { "\013" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 39*/ { KBD_ASCII, I, {S,1, { "l" }}, {S,1, { "L" }}, {S,1, { "\014" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 40*/ { KBD_ASCII, I, {S,1, { ";" }}, {S,1, { ":" }}, {S,1, { ";" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 41*/ { KBD_ASCII, I, {S,1, { "'" }}, {S,1, { "\" }"}, {S,1, { "'" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 42*/ { KBD_ASCII, I, {S,1, { "\\" }}, {S,1, { "|" }}, {S,1, { "\034" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 43*/ { KBD_RETURN,I, {S,1, { "\r" }}, {S,1, { "\r" }}, {S,1, { "\r" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 44*/ { KBD_SHIFT, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 45*/ { KBD_ASCII, I, {S,1, { "<" }}, {S,1, { ">" }}, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 46*/ { KBD_ASCII, I, {S,1, { "z" }}, {S,1, { "Z" }}, {S,1, { "\032" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 47*/ { KBD_ASCII, I, {S,1, { "x" }}, {S,1, { "X" }}, {S,1, { "\030" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 48*/ { KBD_ASCII, I, {S,1, { "c" }}, {S,1, { "C" }}, {S,1, { "\003" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 49*/ { KBD_ASCII, I, {S,1, { "v" }}, {S,1, { "V" }}, {S,1, { "\026" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 50*/ { KBD_ASCII, I, {S,1, { "b" }}, {S,1, { "B" }}, {S,1, { "\002" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 51*/ { KBD_ASCII, I, {S,1, { "n" }}, {S,1, { "N" }}, {S,1, { "\016" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 52*/ { KBD_ASCII, I, {S,1, { "m" }}, {S,1, { "M" }}, {S,1, { "\r" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 53*/ { KBD_ASCII, I, {S,1, { "," }}, {S,1, { "<" }}, {S,1, { "," }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 54*/ { KBD_ASCII, I, {S,1, { "." }}, {S,1, { ">" }}, {S,1, { "." }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 55*/ { KBD_ASCII, I, {S,1, { "/" }}, {S,1, { "?" }}, {S,1, { "/" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 56*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 57*/ { KBD_SHIFT, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 58*/ { KBD_CTL, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 59*/ { KBD_ASCII, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 60*/ { KBD_META, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -#if !PCVT_NULLCHARS -/* 61*/ { KBD_ASCII, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -#else -/* 61*/ { KBD_ASCII, I, DFAULT, DFAULT, {S,1, { "\000" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -#endif /* PCVT_NULLCHARS */ -/* 62*/ { KBD_META, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 63*/ { KBD_ASCII, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 64*/ { KBD_CTL, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 65*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 66*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 67*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 68*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 69*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 70*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 71*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 72*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 73*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 74*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 75*/ { KBD_FUNC, I, {S,4, { "\033[2~" }}, {S,4, { "\033[2~" }}, {S,4, { "\033[2~" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 76*/ { KBD_FUNC, I, {S,4, { "\033[3~" }}, {S,4, { "\033[3~" }}, {S,4, { "\033[3~" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 77*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 78*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 79*/ { KBD_CURSOR,I, {S,4, { "\033[D" }}, {S,4, { "\033OD" }}, {S,4, { "\033[D" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 80*/ { KBD_FUNC, I, {S,4, { "\033[1~" }}, {S,4, { "\033[1~" }}, {S,4, { "\033[1~" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 81*/ { KBD_FUNC, I, {S,4, { "\033[4~" }}, {S,4, { "\033[4~" }}, {S,4, { "\033[4~" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 82*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 83*/ { KBD_CURSOR,I, {S,4, { "\033[A" }}, {S,4, { "\033OA" }}, {S,4, { "\033[A" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 84*/ { KBD_CURSOR,I, {S,4, { "\033[B" }}, {S,4, { "\033OB" }}, {S,4, { "\033[B" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 85*/ { KBD_FUNC, I, {S,4, { "\033[5~" }}, {S,4, { "\033[5~" }}, {S,4, { "\033[5~" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 86*/ { KBD_FUNC, I, {S,4, { "\033[6~" }}, {S,4, { "\033[6~" }}, {S,4, { "\033[6~" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 87*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 88*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 89*/ { KBD_CURSOR,I, {S,3, { "\033[C" }}, {S,3, { "\033OC" }}, {S,3, { "\033[C" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 90*/ { KBD_NUM, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 91*/ { KBD_KP, I, {S,1, { "7" }}, {S,2, { "\033Ow" }}, {S,1, { "7" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 92*/ { KBD_KP, I, {S,1, { "4" }}, {S,2, { "\033Ot" }}, {S,1, { "4" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 93*/ { KBD_KP, I, {S,1, { "1" }}, {S,2, { "\033Oq" }}, {S,1, { "1" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 94*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 95*/ { KBD_KP, I, {S,1, { "/" }}, {S,1, { "/" }}, {S,1, { "/" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 96*/ { KBD_KP, I, {S,1, { "8" }}, {S,2, { "\033Ox" }}, {S,1, { "8" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 97*/ { KBD_KP, I, {S,1, { "5" }}, {S,2, { "\033Ou" }}, {S,1, { "5" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 98*/ { KBD_KP, I, {S,1, { "2" }}, {S,2, { "\033Or" }}, {S,1, { "2" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/* 99*/ { KBD_KP, I, {S,1, { "0" }}, {S,2, { "\033Op" }}, {S,1, { "0" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*100*/ { KBD_KP, I, {S,1, { "*" }}, {S,1, { "*" }}, {S,1, { "*" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*101*/ { KBD_KP, I, {S,1, { "9" }}, {S,2, { "\033Oy" }}, {S,1, { "9" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*102*/ { KBD_KP, I, {S,1, { "6" }}, {S,2, { "\033Ov" }}, {S,1, { "6" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*103*/ { KBD_KP, I, {S,1, { "3" }}, {S,2, { "\033Os" }}, {S,1, { "3" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*104*/ { KBD_KP, I, {S,1, { "." }}, {S,2, { "\033On" }}, {S,1, { "." }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*105*/ { KBD_KP, I, {S,1, { "-" }}, {S,2, { "\033Om" }}, {S,1, { "-" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*106*/ { KBD_KP, I, {S,1, { "+" }}, {S,1, { "+" }}, {S,1, { "+" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*107*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/*108*/ { KBD_RETURN,I, {S,1, { "\r" }}, {S,2, { "\033OM" }}, {S,1, { "\r" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*109*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/*110*/ { KBD_ASCII, I, {S,1, { "\033" }}, {S,2, { "\033" }}, {S,1, { "\033" }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*111*/ { KBD_NONE, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/*112*/ { KBD_FUNC, I, {F,0, { C fkey1 }}, {F,0, { C sfkey1 }}, {F,0, { C cfkey1 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*113*/ { KBD_FUNC, I, {F,0, { C fkey2 }}, {F,0, { C sfkey2 }}, {F,0, { C cfkey2 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*114*/ { KBD_FUNC, I, {F,0, { C fkey3 }}, {F,0, { C sfkey3 }}, {F,0, { C cfkey3 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*115*/ { KBD_FUNC, I, {F,0, { C fkey4 }}, {F,0, { C sfkey4 }}, {F,0, { C cfkey4 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*116*/ { KBD_FUNC, I, {F,0, { C fkey5 }}, {F,0, { C sfkey5 }}, {F,0, { C cfkey5 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*117*/ { KBD_FUNC, I, {F,0, { C fkey6 }}, {F,0, { C sfkey6 }}, {F,0, { C cfkey6 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*118*/ { KBD_FUNC, I, {F,0, { C fkey7 }}, {F,0, { C sfkey7 }}, {F,0, { C cfkey7 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*119*/ { KBD_FUNC, I, {F,0, { C fkey8 }}, {F,0, { C sfkey8 }}, {F,0, { C cfkey8 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*120*/ { KBD_FUNC, I, {F,0, { C fkey9 }}, {F,0, { C sfkey9 }}, {F,0, { C cfkey9 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*121*/ { KBD_FUNC, I, {F,0, { C fkey10 }}, {F,0, { C sfkey10 }}, {F,0, { C cfkey10 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*122*/ { KBD_FUNC, I, {F,0, { C fkey11 }}, {F,0, { C sfkey11 }}, {F,0, { C cfkey11 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*123*/ { KBD_FUNC, I, {F,0, { C fkey12 }}, {F,0, { C sfkey12 }}, {F,0, { C cfkey12 }}, DFAULT, DFAULT, DFAULT, DFAULT }, -/*124*/ { KBD_KP, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/*125*/ { KBD_SCROLL,I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/*126*/ { KBD_BREAK, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, -/*127*/ { KBD_FUNC, I, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT, DFAULT }, - -#undef C -#undef U -#undef V -#undef S -#undef F -#undef I -#undef DFLT -}; - -#else /* PCVT_ALT_ENH */ - -/* define some shorthands to make the table (almost) fit into 80 columns */ -#define C (u_char *) -#define V (void *) -#define S STR -#define F FNC -#define I IDX0 - -/* DONT EVER OVERLOAD KEY 0, THIS IS A KEY THAT MUSTN'T EXIST */ - -/* type index unshift shift ctrl */ -/* ---------------------------------------------------------- */ -/* 0*/ { KBD_NONE, I, {S, { "df" }}, {S, { "" }}, {S, { "" }} }, -/* 1*/ { KBD_ASCII, I, {S, { "`" }}, {S, { "~" }}, {S, { "`" }} }, -/* 2*/ { KBD_ASCII, I, {S, { "1" }}, {S, { "!" }}, {S, { "1" }} }, -/* 3*/ { KBD_ASCII, I, {S, { "2" }}, {S, { "@" }}, {S, { "\000" }} }, -/* 4*/ { KBD_ASCII, I, {S, { "3" }}, {S, { "#" }}, {S, { "3" }} }, -/* 5*/ { KBD_ASCII, I, {S, { "4" }}, {S, { "$" }}, {S, { "4" }} }, -/* 6*/ { KBD_ASCII, I, {S, { "5" }}, {S, { "%" }}, {S, { "5" }} }, -/* 7*/ { KBD_ASCII, I, {S, { "6" }}, {S, { "^" }}, {S, { "\036" }} }, -/* 8*/ { KBD_ASCII, I, {S, { "7" }}, {S, { "&" }}, {S, { "7" }} }, -/* 9*/ { KBD_ASCII, I, {S, { "8" }}, {S, { "*" }}, {S, { "8" }} }, -/* 10*/ { KBD_ASCII, I, {S, { "9" }}, {S, { "(" }}, {S, { "9" }} }, -/* 11*/ { KBD_ASCII, I, {S, { "0" }}, {S, { ")" }}, {S, { "0" }} }, -/* 12*/ { KBD_ASCII, I, {S, { "-" }}, {S, { "_" }}, {S, { "\037" }} }, -/* 13*/ { KBD_ASCII, I, {S, { "=" }}, {S, { "+" }}, {S, { "=" }} }, -/* 14*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 15*/ { KBD_ASCII, I, {S, { "\177" }}, {S, { "\010" }}, {S, { "\177" }} }, /* BS */ -/* 16*/ { KBD_ASCII, I, {S, { "\t" }}, {S, { "\t" }}, {S, { "\t" }} }, /* TAB */ -/* 17*/ { KBD_ASCII, I, {S, { "q" }}, {S, { "Q" }}, {S, { "\021" }} }, -/* 18*/ { KBD_ASCII, I, {S, { "w" }}, {S, { "W" }}, {S, { "\027" }} }, -/* 19*/ { KBD_ASCII, I, {S, { "e" }}, {S, { "E" }}, {S, { "\005" }} }, -/* 20*/ { KBD_ASCII, I, {S, { "r" }}, {S, { "R" }}, {S, { "\022" }} }, -/* 21*/ { KBD_ASCII, I, {S, { "t" }}, {S, { "T" }}, {S, { "\024" }} }, -/* 22*/ { KBD_ASCII, I, {S, { "y" }}, {S, { "Y" }}, {S, { "\031" }} }, -/* 23*/ { KBD_ASCII, I, {S, { "u" }}, {S, { "U" }}, {S, { "\025" }} }, -/* 24*/ { KBD_ASCII, I, {S, { "i" }}, {S, { "I" }}, {S, { "\011" }} }, -/* 25*/ { KBD_ASCII, I, {S, { "o" }}, {S, { "O" }}, {S, { "\017" }} }, -/* 26*/ { KBD_ASCII, I, {S, { "p" }}, {S, { "P" }}, {S, { "\020" }} }, -/* 27*/ { KBD_ASCII, I, {S, { "[" }}, {S, { "{" }}, {S, { "\033" }} }, -/* 28*/ { KBD_ASCII, I, {S, { "]" }}, {S, { "}" }}, {S, { "\035" }} }, -/* 29*/ { KBD_ASCII, I, {S, { "\\" }}, {S, { "|" }}, {S, { "\034" }} }, -#ifdef PCVT_CAPS_IS_CTRL -/* 30*/ { KBD_CTL, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -#else -/* 30*/ { KBD_CAPS, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -#endif -/* 31*/ { KBD_ASCII, I, {S, { "a" }}, {S, { "A" }}, {S, { "\001" }} }, -/* 32*/ { KBD_ASCII, I, {S, { "s" }}, {S, { "S" }}, {S, { "\023" }} }, -/* 33*/ { KBD_ASCII, I, {S, { "d" }}, {S, { "D" }}, {S, { "\004" }} }, -/* 34*/ { KBD_ASCII, I, {S, { "f" }}, {S, { "F" }}, {S, { "\006" }} }, -/* 35*/ { KBD_ASCII, I, {S, { "g" }}, {S, { "G" }}, {S, { "\007" }} }, -/* 36*/ { KBD_ASCII, I, {S, { "h" }}, {S, { "H" }}, {S, { "\010" }} }, -/* 37*/ { KBD_ASCII, I, {S, { "j" }}, {S, { "J" }}, {S, { "\n" }} }, -/* 38*/ { KBD_ASCII, I, {S, { "k" }}, {S, { "K" }}, {S, { "\013" }} }, -/* 39*/ { KBD_ASCII, I, {S, { "l" }}, {S, { "L" }}, {S, { "\014" }} }, -/* 40*/ { KBD_ASCII, I, {S, { ";" }}, {S, { ":" }}, {S, { ";" }} }, -/* 41*/ { KBD_ASCII, I, {S, { "'" }}, {S, { "\"" }}, {S, { "'" }} }, -/* 42*/ { KBD_ASCII, I, {S, { "\\" }}, {S, { "|" }}, {S, { "\034" }} }, /* special */ -/* 43*/ { KBD_RETURN,I, {S, { "\r" }}, {S, { "\r" }}, {S, { "\r" }} }, /* RETURN */ -/* 44*/ { KBD_SHIFT, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* SHIFT left */ -/* 45*/ { KBD_ASCII, I, {S, { "<" }}, {S, { ">" }}, {S, { "" }} }, -/* 46*/ { KBD_ASCII, I, {S, { "z" }}, {S, { "Z" }}, {S, { "\032" }} }, -/* 47*/ { KBD_ASCII, I, {S, { "x" }}, {S, { "X" }}, {S, { "\030" }} }, -/* 48*/ { KBD_ASCII, I, {S, { "c" }}, {S, { "C" }}, {S, { "\003" }} }, -/* 49*/ { KBD_ASCII, I, {S, { "v" }}, {S, { "V" }}, {S, { "\026" }} }, -/* 50*/ { KBD_ASCII, I, {S, { "b" }}, {S, { "B" }}, {S, { "\002" }} }, -/* 51*/ { KBD_ASCII, I, {S, { "n" }}, {S, { "N" }}, {S, { "\016" }} }, -/* 52*/ { KBD_ASCII, I, {S, { "m" }}, {S, { "M" }}, {S, { "\r" }} }, -/* 53*/ { KBD_ASCII, I, {S, { "," }}, {S, { "<" }}, {S, { "," }} }, -/* 54*/ { KBD_ASCII, I, {S, { "." }}, {S, { ">" }}, {S, { "." }} }, -/* 55*/ { KBD_ASCII, I, {S, { "/" }}, {S, { "?" }}, {S, { "/" }} }, -/* 56*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 57*/ { KBD_SHIFT, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* SHIFT right */ -/* 58*/ { KBD_CTL, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* CTL left */ -/* 59*/ { KBD_ASCII, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 60*/ { KBD_META, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* ALT left */ -#if !PCVT_NULLCHARS -/* 61*/ { KBD_ASCII, I, {S, { " " }}, {S, { " " }}, {S, { " " }} }, /* SPACE */ -#else -/* 61*/ { KBD_ASCII, I, {S, { " " }}, {S, { " " }}, {S, { "\000" }} }, /* SPACE */ -#endif /* PCVT_NULLCHARS */ -/* 62*/ { KBD_META, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* ALT right */ -/* 63*/ { KBD_ASCII, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 64*/ { KBD_CTL, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* CTL right */ -/* 65*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 66*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 67*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 68*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 69*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 70*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 71*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 72*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 73*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 74*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 75*/ { KBD_FUNC, I, {S, { "\033[2~" }},{S, { "\033[2~" }},{S, { "\033[2~" }} },/* INS */ -/* 76*/ { KBD_FUNC, I, {S, { "\033[3~" }},{S, { "\033[3~" }},{S, { "\033[3~" }} },/* DEL */ -/* 77*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 78*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 79*/ { KBD_CURSOR,I, {S, { "\033[D" }},{S, { "\033OD" }},{S, { "\033[D" }} }, /* CU <- */ -/* 80*/ { KBD_FUNC, I, {S, { "\033[1~" }},{S, { "\033[1~" }},{S, { "\033[1~" }} },/* HOME = FIND*/ -/* 81*/ { KBD_FUNC, I, {S, { "\033[4~" }},{S, { "\033[4~" }},{S, { "\033[4~" }} },/* END = SELECT */ -/* 82*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 83*/ { KBD_CURSOR,I, {S, { "\033[A" }},{S, { "\033OA" }},{S, { "\033[A" }} }, /* CU ^ */ -/* 84*/ { KBD_CURSOR,I, {S, { "\033[B" }},{S, { "\033OB" }},{S, { "\033[B" }} }, /* CU v */ -/* 85*/ { KBD_FUNC, I, {S, { "\033[5~" }},{S, { "\033[5~" }},{S, { "\033[5~" }} },/*PG UP*/ -/* 86*/ { KBD_FUNC, I, {S, { "\033[6~" }},{S, { "\033[6~" }},{S, { "\033[6~" }} },/*PG DN*/ -/* 87*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 88*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 89*/ { KBD_CURSOR,I, {S, { "\033[C" }},{S, { "\033OC" }},{S, { "\033[C" }} }, /* CU -> */ -/* 90*/ { KBD_NUM, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 91*/ { KBD_KP, I, {S, { "7" }}, {S, { "\033Ow" }},{S, { "7" }} }, -/* 92*/ { KBD_KP, I, {S, { "4" }}, {S, { "\033Ot" }},{S, { "4" }} }, -/* 93*/ { KBD_KP, I, {S, { "1" }}, {S, { "\033Oq" }},{S, { "1" }} }, -/* 94*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/* 95*/ { KBD_KP, I, {S, { "/" }}, {S, { "/" }}, {S, { "/" }} }, -/* 96*/ { KBD_KP, I, {S, { "8" }}, {S, { "\033Ox" }},{S, { "8" }} }, -/* 97*/ { KBD_KP, I, {S, { "5" }}, {S, { "\033Ou" }},{S, { "5" }} }, -/* 98*/ { KBD_KP, I, {S, { "2" }}, {S, { "\033Or" }},{S, { "2" }} }, -/* 99*/ { KBD_KP, I, {S, { "0" }}, {S, { "\033Op" }},{S, { "0" }} }, -/*100*/ { KBD_KP, I, {S, { "*" }}, {S, { "*" }}, {S, { "*" }} }, -/*101*/ { KBD_KP, I, {S, { "9" }}, {S, { "\033Oy" }},{S, { "9" }} }, -/*102*/ { KBD_KP, I, {S, { "6" }}, {S, { "\033Ov" }},{S, { "6" }} }, -/*103*/ { KBD_KP, I, {S, { "3" }}, {S, { "\033Os" }},{S, { "3" }} }, -/*104*/ { KBD_KP, I, {S, { "." }}, {S, { "\033On" }},{S, { "." }} }, -/*105*/ { KBD_KP, I, {S, { "-" }}, {S, { "\033Om" }},{S, { "-" }} }, -/*106*/ { KBD_KP, I, {S, { "+" }}, {S, { "+" }}, {S, { "+" }} }, -/*107*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/*108*/ { KBD_RETURN,I, {S, { "\r" }}, {S, { "\033OM" }},{S, { "\r" }} }, /* KP ENTER */ -/*109*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/*110*/ { KBD_ASCII, I, {S, { "\033" }}, {S, { "\033" }}, {S, { "\033" }} }, -/*111*/ { KBD_NONE, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/*112*/ { KBD_FUNC, I, {F, { C fkey1 }}, {F, { C sfkey1 }}, {F, { C cfkey1 }} }, /* F1 */ -/*113*/ { KBD_FUNC, I, {F, { C fkey2 }}, {F, { C sfkey2 }}, {F, { C cfkey2 }} }, /* F2 */ -/*114*/ { KBD_FUNC, I, {F, { C fkey3 }}, {F, { C sfkey3 }}, {F, { C cfkey3 }} }, /* F3 */ -/*115*/ { KBD_FUNC, I, {F, { C fkey4 }}, {F, { C sfkey4 }}, {F, { C cfkey4 }} }, /* F4 */ -/*116*/ { KBD_FUNC, I, {F, { C fkey5 }}, {F, { C sfkey5 }}, {F, { C cfkey5 }} }, /* F5 */ -/*117*/ { KBD_FUNC, I, {F, { C fkey6 }}, {F, { C sfkey6 }}, {F, { C cfkey6 }} }, /* F6 */ -/*118*/ { KBD_FUNC, I, {F, { C fkey7 }}, {F, { C sfkey7 }}, {F, { C cfkey7 }} }, /* F7 */ -/*119*/ { KBD_FUNC, I, {F, { C fkey8 }}, {F, { C sfkey8 }}, {F, { C cfkey8 }} }, /* F8 */ -/*120*/ { KBD_FUNC, I, {F, { C fkey9 }}, {F, { C sfkey9 }}, {F, { C cfkey9 }} }, /* F9 */ -/*121*/ { KBD_FUNC, I, {F, { C fkey10 }}, {F, { C sfkey10 }}, {F, { C cfkey10 }} }, /* F10 */ -/*122*/ { KBD_FUNC, I, {F, { C fkey11 }}, {F, { C sfkey11 }}, {F, { C cfkey11 }} }, /* F11 */ -/*123*/ { KBD_FUNC, I, {F, { C fkey12 }}, {F, { C sfkey12 }}, {F, { C cfkey12 }} }, /* F12 */ -/*124*/ { KBD_KP, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/*125*/ { KBD_SCROLL,I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/*126*/ { KBD_BREAK, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, -/*127*/ { KBD_FUNC, I, {S, { "" }}, {S, { "" }}, {S, { "" }} }, /* SysRq */ - -#undef C -#undef V -#undef S -#undef F -#undef I -}; - -#endif /* PCVT_ALT_ENH */ - -static short keypad2num[] = { - 7, 4, 1, -1, -1, 8, 5, 2, 0, -1, 9, 6, 3, -1, -1, -1, -1 -}; - -#define N_KEYNUMS 128 - -/* - * this is the reverse mapping from keynumbers to scanset 1 codes - * it is used to emulate the SysV-style GIO_KEYMAP ioctl cmd - */ - -static u_char key2scan1[N_KEYNUMS] = { - 0,0x29,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09, /* 0 */ - 0x0a,0x0b,0x0c,0x0d, 0,0x0e,0x0f,0x10,0x11,0x12, /* 10 */ - 0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x1a,0x1b,0x2b, /* 20 */ - 0x3a,0x1e,0x1f,0x20,0x21,0x22,0x23,0x24,0x25,0x26, /* 30 */ - 0x27,0x28, 0,0x1c,0x2a,0x56,0x2c,0x2d,0x2e,0x2f, /* 40 */ - 0x30,0x31,0x32,0x33,0x34,0x35,0x56,0x36,0x1d, 0, /* 50 */ - 0x38,0x39, 0, 0, 0, 0, 0, 0, 0, 0, /* 60 */ - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* 70 */ - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* 80 */ - 0x45,0x47,0x4b,0x4f, 0, 0,0x48,0x4c,0x50,0x52, /* 90 */ - 0x37,0x49,0x4d,0x51,0x53,0x4a,0x4e, 0, 0, 0, /* 100 */ - 0x01, 0,0x3b,0x3c,0x3d,0x3e,0x3f,0x40,0x41,0x42, /* 110 */ - 0x43,0x44,0x57,0x58, 0,0x46, 0,0x54 /* 120 */ -}; - -/* - * SysV is brain-dead enough to stick on the IBM code page 437. So we - * have to translate our keymapping into IBM 437 (possibly losing keys), - * in order to have the X server convert it back into ISO8859.1 - */ - -/* NB: this table only contains the mapping for codes >= 128 */ - -static u_char iso2ibm437[] = -{ - 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, - 0xff, 0xad, 0x9b, 0x9c, 0, 0x9d, 0, 0x40, - 0x6f, 0x63, 0x61, 0xae, 0, 0, 0, 0, - 0xf8, 0xf1, 0xfd, 0x33, 0, 0xe6, 0, 0xfa, - 0, 0x31, 0x6f, 0xaf, 0xac, 0xab, 0, 0xa8, - 0x41, 0x41, 0x41, 0x41, 0x8e, 0x8f, 0x92, 0x80, - 0x45, 0x90, 0x45, 0x45, 0x49, 0x49, 0x49, 0x49, - 0x81, 0xa5, 0x4f, 0x4f, 0x4f, 0x4f, 0x99, 0x4f, - 0x4f, 0x55, 0x55, 0x55, 0x9a, 0x59, 0, 0xe1, - 0x85, 0xa0, 0x83, 0x61, 0x84, 0x86, 0x91, 0x87, - 0x8a, 0x82, 0x88, 0x89, 0x8d, 0xa1, 0x8c, 0x8b, - 0, 0xa4, 0x95, 0xa2, 0x93, 0x6f, 0x94, 0x6f, - 0x6f, 0x97, 0xa3, 0x96, 0x81, 0x98, 0, 0 -}; - -/* EOF */ diff --git a/sys/arch/i386/isa/pcvt/pcvt_out.c b/sys/arch/i386/isa/pcvt/pcvt_out.c deleted file mode 100644 index 14ed909e6694..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_out.c +++ /dev/null @@ -1,2251 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore. - * - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz and Don Ahn. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis, - * Brian Dunford-Shore and Joerg Wunsch. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_out.c, 3.32, Last Edit-Date: [Tue Oct 3 11:19:49 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_out.c VT220 Terminal Emulator - * --------------------------------------- - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -hm integrating patch from Thomas Gellekum - * -hm bugfix: clear last line when hpmode 28lines and force 24 - * -hm right fkey labels after soft/hard reset - * -hm patch from Joerg for comconsole operation - * -hm patch from Lon Willet to preserve the initial cursor shape - * -hm if FAT_CURSOR is defined, you get the old cursor type back .. - * -hm patch from Lon Willett regarding winsize settings - * -hm applying patch from Joerg fixing Crtat bug, non VGA startup bug - * -hm setting variable color for CGA and MDA/HGC in coldinit - * -hm fixing bug initializing cursor position on startup - * -hm fixing support for EGA boards in vt_coldinit() - * -hm bugfix from Joerg: check for svsp->vs_tty before using it - * -hm patches from Michael for NetBSD-current (Apr/21/95) support - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Thomas Gellekum to support C1 controls - * -hm patch from Frank van der Linden for keyboard state per VT - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#define PCVT_INCLUDE_VT_SELATTR /* get inline function from pcvt_hdr.h */ - -#include "pcvt_hdr.h" /* global include */ - -static void check_scroll ( struct video_state *svsp ); -static void hp_entry ( U_char ch, struct video_state *svsp ); -static void wrfkl ( int num, u_char *string, struct video_state *svsp ); -static void writefkl ( int num, u_char *string, struct video_state *svsp ); -static __inline void write_char (struct video_state *, u_short, u_short ch); - - -/*---------------------------------------------------------------------------* - * do character set transformation and write to display memory (inline) - *---------------------------------------------------------------------------*/ - -#define video (svsp->Crtat + svsp->cur_offset) - -static __inline void write_char (svsp, attrib, ch) -struct video_state *svsp; -u_short attrib, ch; -{ - if ((ch >= 0x20) && (ch <= 0x7f)) /* use GL if ch >= 0x20 */ - { - if(!svsp->ss) /* single shift G2/G3 -> GL ? */ - { - *video = attrib | svsp->GL[ch-0x20]; - } - else - { - *video = attrib | svsp->Gs[ch-0x20]; - svsp->ss = 0; - } - } - else - { - svsp->ss = 0; - - if(ch >= 0x80) /* display controls C1 */ - { - if(ch >= 0xA0) /* use GR if ch >= 0xA0 */ - { - *video = attrib | svsp->GR[ch-0xA0]; - } - else - { - if(vgacs[svsp->vga_charset].secondloaded) - { - *video = attrib | ((ch-0x60) | CSH); - } - else /* use normal ibm charset for - control display */ - { - *video = attrib | ch; - } - } - } - else /* display controls C0 */ - { - if(vgacs[svsp->vga_charset].secondloaded) - { - *video = attrib | (ch | CSH); - } - else /* use normal ibm charset for control display*/ - { - *video = attrib | ch; - } - } - } -} - -/*---------------------------------------------------------------------------* - * emulator main entry - *---------------------------------------------------------------------------*/ -void -sput (u_char *s, U_char kernel, int len, int page) -{ - register struct video_state *svsp; - u_short attrib; - u_short ch; - - if(page >= PCVT_NSCREENS) /* failsafe */ - page = 0; - - svsp = &vs[page]; /* pointer to current screen state */ - - if(do_initialization) /* first time called ? */ - vt_coldinit(); /* yes, we have to init ourselves */ - - if(svsp == vsp) /* on current displayed page ? */ - { - cursor_pos_valid = 0; /* do not update cursor */ - -#if PCVT_SCREENSAVER - if(scrnsv_active) /* screen blanked ? */ - pcvt_scrnsv_reset(); /* unblank NOW ! */ - else - reset_screen_saver = 1; /* do it asynchronously */ -#endif /* PCVT_SCREENSAVER */ - - } - - attrib = kernel ? kern_attr : svsp->c_attr; - - while (len-- > 0) - if ((ch = (*(s++))) != 0) - { - if(svsp->sevenbit) - ch &= 0x7f; - - if((svsp->transparent == 0) - && ((ch <= 0x1f) - || (svsp->C1_ctls && (ch > 0x7f) && (ch < 0xa0)))) - { - - /* always process control-chars in the range 0x00..0x1f !!! */ - - /* also process the C1 control chars a VT220 recognizes and - * ignore the others. - */ - if(svsp->dis_fnc) - { - if(svsp->lastchar && svsp->m_awm - && (svsp->lastrow == svsp->row)) - { - svsp->cur_offset++; - svsp->col = 0; - svsp->lastchar = 0; - check_scroll(svsp); - } - - if(svsp->irm) - bcopy((svsp->Crtat + svsp->cur_offset), - (svsp->Crtat + svsp->cur_offset) + 1, - (((svsp->maxcol)-1) - svsp->col)*CHR); - - write_char(svsp, attrib, ch); - - vt_selattr(svsp); - - if(svsp->col >= ((svsp->maxcol)-1) - && ch != 0x0a && ch != 0x0b && ch != 0x0c) - { - svsp->lastchar = 1; - svsp->lastrow = svsp->row; - } - else if(ch == 0x0a || ch == 0x0b || ch == 0x0c) - { - svsp->cur_offset -= svsp->col; - svsp->cur_offset += svsp->maxcol; - svsp->col = 0; - svsp->lastchar = 0; - check_scroll(svsp); /* check scroll up */ - } - else - { - svsp->cur_offset++; - svsp->col++; - svsp->lastchar = 0; - } - } - else - { - switch(ch) - { - case 0x00: /* NUL */ - case 0x01: /* SOH */ - case 0x02: /* STX */ - case 0x03: /* ETX */ - case 0x04: /* EOT */ - case 0x05: /* ENQ */ - case 0x06: /* ACK */ - break; - - case 0x07: /* BEL */ - if(svsp->bell_on) - sysbeep(PCVT_SYSBEEPF/1500, hz/4); - break; - - case 0x08: /* BS */ - if(svsp->col > 0) - { - svsp->cur_offset--; - svsp->col--; - } - break; - - case 0x09: /* TAB */ - while(svsp->col < ((svsp->maxcol)-1)) - { - svsp->cur_offset++; - if(svsp-> - tab_stops[++svsp->col]) - break; - } - break; - - case 0x0a: /* LF */ - case 0x0b: /* VT */ - case 0x0c: /* FF */ - if(svsp->lnm) - { - svsp->cur_offset -= svsp->col; - svsp->cur_offset += - svsp->maxcol; - svsp->col = 0; - } - else - { - svsp->cur_offset += - svsp->maxcol; - } - check_scroll(svsp); - break; - - case 0x0d: /* CR */ - svsp->cur_offset -= svsp->col; - svsp->col = 0; - break; - - case 0x0e: /* SO */ - svsp->GL = svsp->G1; - break; - - case 0x0f: /* SI */ - svsp->GL = svsp->G0; - break; - - case 0x10: /* DLE */ - case 0x11: /* DC1/XON */ - case 0x12: /* DC2 */ - case 0x13: /* DC3/XOFF */ - case 0x14: /* DC4 */ - case 0x15: /* NAK */ - case 0x16: /* SYN */ - case 0x17: /* ETB */ - break; - - case 0x18: /* CAN */ - svsp->state = STATE_INIT; - clr_parms(svsp); - break; - - case 0x19: /* EM */ - break; - - case 0x1a: /* SUB */ - svsp->state = STATE_INIT; - clr_parms(svsp); - break; - - case 0x1b: /* ESC */ - svsp->state = STATE_ESC; - clr_parms(svsp); - break; - - case 0x1c: /* FS */ - case 0x1d: /* GS */ - case 0x1e: /* RS */ - case 0x1f: /* US */ - break; - - case 0x80: /* */ - case 0x81: /* */ - case 0x82: /* */ - case 0x83: /* */ - break; - - case 0x84: /* IND */ - vt_ind(svsp); - break; - - case 0x85: /* NEL */ - vt_nel(svsp); - break; - - case 0x86: /* SSA */ - case 0x87: /* ESA */ - break; - - case 0x88: /* HTS */ - svsp->tab_stops[svsp->col] = 1; - break; - - case 0x89: /* HTJ */ - case 0x8a: /* VTS */ - case 0x8b: /* PLD */ - case 0x8c: /* PLU */ - break; - - case 0x8d: /* RI */ - vt_ri(svsp); - break; - - case 0x8e: /* SS2 */ - svsp->Gs = svsp->G2; - svsp->ss = 1; - break; - - case 0x8f: /* SS3 */ - svsp->Gs = svsp->G3; - svsp->ss = 1; - break; - - case 0x90: /* DCS */ - svsp->dcs_state = DCS_INIT; - svsp->state = STATE_DCS; - break; - - case 0x91: /* PU1 */ - case 0x92: /* PU2 */ - case 0x93: /* STS */ - case 0x94: /* CCH */ - case 0x95: /* MW */ - case 0x96: /* SPA */ - case 0x97: /* EPA */ - case 0x98: /* */ - case 0x99: /* */ - case 0x9a: /* */ - break; - - case 0x9b: /* CSI */ - clr_parms(svsp); - svsp->state = STATE_CSI; - break; - - case 0x9c: /* ST */ - svsp->state = STATE_INIT; - break; - - case 0x9d: /* OSC */ - case 0x9e: /* PM */ - case 0x9f: /* APC */ - /* only in VT320's */ - break; - } - } - } - else - { - - /* char range 0x20...0xff processing depends on current state */ - - switch(svsp->state) - { - case STATE_INIT: - if(svsp->lastchar && svsp->m_awm && - (svsp->lastrow == svsp->row)) - { - svsp->cur_offset++; - svsp->col = 0; - svsp->lastchar = 0; - check_scroll(svsp); - } - - if(svsp->irm) - bcopy ((svsp->Crtat - + svsp->cur_offset), - (svsp->Crtat - + svsp->cur_offset) + 1, - (((svsp->maxcol)-1) - - svsp->col) * CHR); - - write_char(svsp, attrib, ch); - - vt_selattr(svsp); - - if(svsp->col >= ((svsp->maxcol)-1)) - { - svsp->lastchar = 1; - svsp->lastrow = svsp->row; - } - else - { - svsp->lastchar = 0; - svsp->cur_offset++; - svsp->col++; - } - break; - - case STATE_ESC: - switch(ch) - { - case ' ': /* ESC sp family */ - svsp->state = STATE_BLANK; - break; - - case '#': /* ESC # family */ - svsp->state = STATE_HASH; - break; - - case '&': /* ESC & family (HP) */ - if(svsp->vt_pure_mode == - M_HPVT) - { - svsp->state = - STATE_AMPSND; - svsp->hp_state = - SHP_INIT; - } - else - svsp->state = - STATE_INIT; - break; - - case '(': /* ESC ( family */ - svsp->state = STATE_BROPN; - break; - - case ')': /* ESC ) family */ - svsp->state = STATE_BRCLO; - break; - - case '*': /* ESC * family */ - svsp->state = STATE_STAR; - break; - - case '+': /* ESC + family */ - svsp->state = STATE_PLUS; - break; - - case '-': /* ESC - family */ - svsp->state = STATE_MINUS; - break; - - case '.': /* ESC . family */ - svsp->state = STATE_DOT; - break; - - case '/': /* ESC / family */ - svsp->state = STATE_SLASH; - break; - - case '7': /* SAVE CURSOR */ - vt_sc(svsp); - svsp->state = STATE_INIT; - break; - - case '8': /* RESTORE CURSOR */ - vt_rc(svsp); - if (!kernel) - attrib = svsp->c_attr; - svsp->state = STATE_INIT; - break; - - case '=': /* keypad application mode */ -#if !PCVT_INHIBIT_NUMLOCK - vt_keyappl(svsp); -#endif - svsp->state = STATE_INIT; - break; - - case '>': /* keypad numeric mode */ -#if !PCVT_INHIBIT_NUMLOCK - vt_keynum(svsp); -#endif - svsp->state = STATE_INIT; - break; - - case 'D': /* INDEX */ - vt_ind(svsp); - svsp->state = STATE_INIT; - break; - - case 'E': /* NEXT LINE */ - vt_nel(svsp); - svsp->state = STATE_INIT; - break; - - case 'H': /* set TAB at current col */ - svsp->tab_stops[svsp->col] = 1; - svsp->state = STATE_INIT; - break; - - case 'M': /* REVERSE INDEX */ - vt_ri(svsp); - svsp->state = STATE_INIT; - break; - - case 'N': /* SINGLE SHIFT G2 */ - svsp->Gs = svsp->G2; - svsp->ss = 1; - svsp->state = STATE_INIT; - break; - - case 'O': /* SINGLE SHIFT G3 */ - svsp->Gs = svsp->G3; - svsp->ss = 1; - svsp->state = STATE_INIT; - break; - - case 'P': /* DCS detected */ - svsp->dcs_state = DCS_INIT; - svsp->state = STATE_DCS; - break; - - case 'Z': /* What are you = ESC [ c */ - vt_da(svsp); - svsp->state = STATE_INIT; - break; - - case '[': /* CSI detected */ - clr_parms(svsp); - svsp->state = STATE_CSI; - break; - - case '\\': /* String Terminator */ - svsp->state = STATE_INIT; - break; - - case 'c': /* hard reset */ - vt_ris(svsp); - if (!kernel) - attrib = svsp->c_attr; - svsp->state = STATE_INIT; - break; - -#if PCVT_SETCOLOR - case 'd': /* set color sgr */ - if(color) - { - /* set shiftwidth=4 */ - sgr_tab_color - [svsp-> - vtsgr] = - svsp->c_attr - >> 8; - user_attr = - sgr_tab_color - [0] << 8; - } - svsp->state = STATE_INIT; - break; -#endif /* PCVT_SETCOLOR */ - case 'n': /* Lock Shift G2 -> GL */ - svsp->GL = svsp->G2; - svsp->state = STATE_INIT; - break; - - case 'o': /* Lock Shift G3 -> GL */ - svsp->GL = svsp->G3; - svsp->state = STATE_INIT; - break; - - case '}': /* Lock Shift G2 -> GR */ - svsp->GR = svsp->G2; - svsp->state = STATE_INIT; - break; - - case '|': /* Lock Shift G3 -> GR */ - svsp->GR = svsp->G3; - svsp->state = STATE_INIT; - break; - - case '~': /* Lock Shift G1 -> GR */ - svsp->GR = svsp->G1; - svsp->state = STATE_INIT; - break; - - default: - svsp->state = STATE_INIT; - break; - } - break; - - case STATE_BLANK: /* ESC space [FG], which are */ - svsp->state = STATE_INIT; /* currently ignored*/ - break; - - case STATE_HASH: - switch(ch) - { - case '3': /* double height top half */ - case '4': /*double height bottom half*/ - case '5': /*single width sngle height*/ - case '6': /*double width sngle height*/ - svsp->state = STATE_INIT; - break; - - case '8': /* fill sceen with 'E's */ - vt_aln(svsp); - svsp->state = STATE_INIT; - break; - - default: /* anything else */ - svsp->state = STATE_INIT; - break; - } - break; - - case STATE_BROPN: /* designate G0 */ - case STATE_BRCLO: /* designate G1 */ - case STATE_STAR: /* designate G2 */ - case STATE_PLUS: /* designate G3 */ - case STATE_MINUS: /* designate G1 (96) */ - case STATE_DOT: /* designate G2 (96) */ - case STATE_SLASH: /* designate G3 (96) */ - svsp->which[svsp->whichi++] = ch; - if(ch >= 0x20 && ch <= 0x2f - && svsp->whichi <= 2) - break; - else if(ch >=0x30 && ch <= 0x7e) - { - svsp->which[svsp->whichi] = '\0'; - vt_designate(svsp); - } - svsp->whichi = 0; - svsp->state = STATE_INIT; - break; - - case STATE_CSIQM: /* DEC private modes */ - switch(ch) - { - case '0': - case '1': - case '2': - case '3': - case '4': - case '5': - case '6': - case '7': - case '8': - case '9': /* parameters */ - svsp->parms[svsp->parmi] *= 10; - svsp->parms[svsp->parmi] += - (ch -'0'); - break; - - case ';': /* next parameter */ - svsp->parmi = - (svsp->parmi+1 < MAXPARMS) ? - svsp->parmi+1 : svsp->parmi; - break; - - case 'h': /* set mode */ - vt_set_dec_priv_qm(svsp); - svsp->state = STATE_INIT; - break; - - case 'l': /* reset mode */ - vt_reset_dec_priv_qm(svsp); - svsp->state = STATE_INIT; - break; - - case 'n': /* Reports */ - vt_dsr(svsp); - svsp->state = STATE_INIT; - break; - - case 'K': /* selective erase in line */ - vt_sel(svsp); - svsp->state = STATE_INIT; - break; - - case 'J':/*selective erase in display*/ - vt_sed(svsp); - svsp->state = STATE_INIT; - break; - - default: - svsp->state = STATE_INIT; - break; - - } - break; - - case STATE_CSI: - switch(ch) - { - case '0': - case '1': - case '2': - case '3': - case '4': - case '5': - case '6': - case '7': - case '8': - case '9': /* parameters */ - svsp->parms[svsp->parmi] *= 10; - svsp->parms[svsp->parmi] += - (ch -'0'); - break; - - case ';': /* next parameter */ - svsp->parmi = - (svsp->parmi+1 < MAXPARMS) ? - svsp->parmi+1 : svsp->parmi; - break; - - case '?': /* ESC [ ? family */ - svsp->state = STATE_CSIQM; - break; - - case '@': /* insert char */ - vt_ic(svsp); - svsp->state = STATE_INIT; - break; - - case '"': /* select char attribute */ - svsp->state = STATE_DQUOTE; - break; - - case '\'': /* for DECELR/DECSLE */ -/* XXX */ /* another state needed -hm */ - break; - - case '!': /* soft terminal reset */ - svsp->state = STATE_STR; - break; - - case 'A': /* cursor up */ - vt_cuu(svsp); - svsp->state = STATE_INIT; - break; - - case 'B': /* cursor down */ - vt_cud(svsp); - svsp->state = STATE_INIT; - break; - - case 'C': /* cursor forward */ - vt_cuf(svsp); - svsp->state = STATE_INIT; - break; - - case 'D': /* cursor backward */ - vt_cub(svsp); - svsp->state = STATE_INIT; - break; - - case 'H': /* direct cursor addressing*/ - vt_curadr(svsp); - svsp->state = STATE_INIT; - break; - - case 'J': /* erase screen */ - vt_clreos(svsp); - svsp->state = STATE_INIT; - break; - - case 'K': /* erase line */ - vt_clreol(svsp); - svsp->state = STATE_INIT; - break; - - case 'L': /* insert line */ - vt_il(svsp); - svsp->state = STATE_INIT; - break; - - case 'M': /* delete line */ - vt_dl(svsp); - svsp->state = STATE_INIT; - break; - - case 'P': /* delete character */ - vt_dch(svsp); - svsp->state = STATE_INIT; - break; - - case 'S': /* scroll up */ - vt_su(svsp); - svsp->state = STATE_INIT; - break; - - case 'T': /* scroll down */ - vt_sd(svsp); - svsp->state = STATE_INIT; - break; - - case 'X': /* erase character */ - vt_ech(svsp); - svsp->state = STATE_INIT; - break; - - case 'c': /* device attributes */ - vt_da(svsp); - svsp->state = STATE_INIT; - break; - - case 'f': /* direct cursor addressing*/ - vt_curadr(svsp); - svsp->state = STATE_INIT; - break; - - case 'g': /* clear tabs */ - vt_clrtab(svsp); - svsp->state = STATE_INIT; - break; - - case 'h': /* set mode(s) */ - vt_set_ansi(svsp); - svsp->state = STATE_INIT; - break; - - case 'i': /* media copy */ - vt_mc(svsp); - svsp->state = STATE_INIT; - break; - - case 'l': /* reset mode(s) */ - vt_reset_ansi(svsp); - svsp->state = STATE_INIT; - break; - - case 'm': /* select graphic rendition*/ - vt_sgr(svsp); - if (!kernel) - attrib = svsp->c_attr; - svsp->state = STATE_INIT; - break; - - case 'n': /* reports */ - vt_dsr(svsp); - svsp->state = STATE_INIT; - break; - - case 'r': /* set scrolling region */ - vt_stbm(svsp); - svsp->state = STATE_INIT; - break; - - case 'x': /*request/report parameters*/ - vt_reqtparm(svsp); - svsp->state = STATE_INIT; - break; - - case 'y': /* invoke selftest(s) */ - vt_tst(svsp); - svsp->state = STATE_INIT; - break; - - case 'z': /* DECELR, ignored */ - case '{': /* DECSLE, ignored */ - svsp->state = STATE_INIT; - break; - - default: - svsp->state = STATE_INIT; - break; - } - break; - - case STATE_AMPSND: - hp_entry(ch,svsp); - break; - - case STATE_DCS: - vt_dcsentry(ch,svsp); - break; - - case STATE_DQUOTE: - switch(ch) - { - case 'p': /* compatibility level */ - vt_scl(svsp); - svsp->state = STATE_INIT; - break; - - case 'q': /* select char attributes */ - vt_sca(svsp); - svsp->state = STATE_INIT; - break; - - default: - svsp->state = STATE_INIT; - break; - } - break; - - case STATE_STR: - switch(ch) - { - case 'p': /* soft terminal reset */ - vt_str(svsp); - if (!kernel) - attrib = svsp->c_attr; - svsp->state = STATE_INIT; - break; - - default: - svsp->state = STATE_INIT; - break; - } - break; - - default: /* failsafe */ - svsp->state = STATE_INIT; - break; - - } - } - - svsp->row = svsp->cur_offset / svsp->maxcol; /* current row update */ - - /* take care of last character on line behaviour */ - - if(svsp->lastchar && (svsp->col < ((svsp->maxcol)-1))) - svsp->lastchar = 0; - } - - if(svsp == vsp) /* on current displayed page ? */ - cursor_pos_valid = 1; /* position is valid now */ -} - -/*---------------------------------------------------------------------------* - * this is the absolute cold initialization of the emulator - *---------------------------------------------------------------------------*/ -void -vt_coldinit(void) -{ - extern u_short csd_ascii[]; /* pcvt_tbl.h */ - extern u_short csd_supplemental[]; - - u_short was; - int nscr, charset; - int equipment; - - struct video_state *svsp; - - do_initialization = 0; /* reset init necessary flag */ - - /* get the equipment byte from the RTC chip */ - - equipment = mc146818_read(NULL, NVRAM_EQUIPMENT); - switch(equipment & NVRAM_EQUIPMENT_MONITOR) - { - default: - panic("vt_coldinit: impossible equipment"); - - case EQ_EGAVGA: - /* set memory start to CGA == B8000 */ - - Crtat = ISA_HOLE_VADDR(CGA_BUF); - - /* find out, what monitor is connected */ - - was = *Crtat; - *Crtat = (u_short) 0xA55A; - if (*Crtat != 0xA55A) - { - Crtat = ISA_HOLE_VADDR(MONO_BUF); - addr_6845 = MONO_BASE; - color = 0; - } - else - { - *Crtat = was; - addr_6845 = CGA_BASE; - color = 1; - } - - if(vga_test()) /* EGA or VGA ? */ - { - adaptor_type = VGA_ADAPTOR; - totalfonts = 8; - - if(color == 0) - { - mda2egaorvga(); - } - - /* find out which chipset we are running on */ - vga_type = vga_chipset(); - } - else - { - adaptor_type = EGA_ADAPTOR; - totalfonts = 4; - - if(color == 0) - { - mda2egaorvga(); - } - } - - /* decouple ega/vga charsets and intensity */ - set_2ndcharset(); - - break; - - case EQ_40COLOR: /* XXX should panic in 40 col mode ! */ - case EQ_80COLOR: - - Crtat = ISA_HOLE_VADDR (CGA_BUF); - - addr_6845 = CGA_BASE; - adaptor_type = CGA_ADAPTOR; - color = 1; - totalfonts = 0; - break; - - case EQ_80MONO: - - Crtat = ISA_HOLE_VADDR (MONO_BUF); - - addr_6845 = MONO_BASE; - adaptor_type = MDA_ADAPTOR; - color = 0; - totalfonts = 0; - break; - } - - /* establish default colors */ - - if(color) - { - kern_attr = (COLOR_KERNEL_FG | COLOR_KERNEL_BG) << 8; - user_attr = sgr_tab_color[0] << 8; - } - else - { - kern_attr = (MONO_KERNEL_FG | MONO_KERNEL_BG) << 8; - if(adaptor_type == MDA_ADAPTOR) - user_attr = sgr_tab_imono[0] << 8; - else - user_attr = sgr_tab_mono[0] << 8; - } - - totalscreens = 1; /* for now until malloced */ - - for(nscr = 0, svsp = vs; nscr < PCVT_NSCREENS; nscr++, svsp++) - { - svsp->Crtat = Crtat; /* all same until malloc'ed */ - svsp->Memory = Crtat; /* until malloc'ed */ - svsp->cur_offset = 0; /* cursor offset */ - svsp->c_attr = user_attr; /* non-kernel attributes */ - svsp->bell_on = 1; /* enable bell */ - svsp->sevenbit = 0; /* set to 8-bit path */ - svsp->dis_fnc = 0; /* disable display functions */ - svsp->transparent = 0; /* disable internal tranparency */ - svsp->C1_ctls = 0; /* process only C0 ctls */ - svsp->lastchar = 0; /* VTxxx behaviour of last */ - /* char on line */ - svsp->report_chars = NULL; /* VTxxx reports init */ - svsp->report_count = 0; /* VTxxx reports init */ - svsp->state = STATE_INIT; /* main state machine init */ - svsp->m_awm = 1; /* enable auto wrap mode */ - svsp->m_om = 0; /* origin mode = absolute */ - svsp->sc_flag = 0; /* init saved cursor flag */ - svsp->which_fkl = SYS_FKL; /* display system fkey-labels */ - svsp->labels_on = 1; /* if in HP-mode, display */ - /* fkey-labels */ - svsp->attribute = 0; /* HP mode init */ - svsp->key = 0; /* HP mode init */ - svsp->l_len = 0; /* HP mode init */ - svsp->s_len = 0; /* HP mode init */ - svsp->m_len = 0; /* HP mode init */ - svsp->i = 0; /* HP mode init */ - svsp->vt_pure_mode = M_PUREVT; /* initial mode: pure VT220*/ - svsp->vga_charset = CH_SET0; /* use bios default charset */ - -#if PCVT_24LINESDEF /* true compatibility */ - svsp->screen_rows = 24; /* default 24 rows on screen */ -#else /* full screen */ - svsp->screen_rows = 25; /* default 25 rows on screen */ -#endif /* PCVT_24LINESDEF */ - - svsp->screen_rowsize = 25; /* default 25 rows on screen */ - svsp->scrr_beg = 0; /* scrolling region begin row*/ - svsp->scrr_len = svsp->screen_rows; /* scrolling region length*/ - svsp->scrr_end = svsp->scrr_len - 1;/* scrolling region end */ - - if(nscr == 0) - { - if(adaptor_type == VGA_ADAPTOR) - { - /* only VGA can read cursor shape registers ! */ - /* Preserve initial cursor shape */ - outb(addr_6845,CRTC_CURSTART); - svsp->cursor_start = inb(addr_6845+1); - outb(addr_6845,CRTC_CUREND); - svsp->cursor_end = inb(addr_6845+1); - } - else - { - /* MDA,HGC,CGA,EGA registers are write-only */ - svsp->cursor_start = 0; - svsp->cursor_end = 15; - } - } - else - { - svsp->cursor_start = vs[0].cursor_start; - svsp->cursor_end = vs[0].cursor_end; - } - -#ifdef FAT_CURSOR - svsp->cursor_end = 15; /* cursor lower scanline */ -#endif - - svsp->cursor_on = 1; /* cursor is on */ - svsp->ckm = 1; /* normal cursor key mode */ - svsp->irm = 0; /* replace mode */ - svsp->lnm = 0; /* CR only */ - svsp->selchar = 0; /* selective attribute off */ - svsp->G0 = csd_ascii; /* G0 = ascii */ - svsp->G1 = csd_ascii; /* G1 = ascii */ - svsp->G2 = csd_supplemental; /* G2 = supplemental */ - svsp->G3 = csd_supplemental; /* G3 = supplemental */ - svsp->GL = svsp->G0; /* GL = G0 */ - svsp->GR = svsp->G2; /* GR = G2 */ - svsp->whichi = 0; /* char set designate init */ - svsp->which[0] = '\0'; /* char set designate init */ - svsp->hp_state = SHP_INIT; /* init HP mode state machine*/ - svsp->dcs_state = DCS_INIT; /* init DCS mode state machine*/ - svsp->ss = 0; /* init single shift 2/3 */ - svsp->Gs = NULL; /* Gs single shift 2/3 */ - svsp->maxcol = SCR_COL80; /* 80 columns now (MUST!!!) */ - svsp->wd132col = 0; /* help good old WD .. */ - svsp->scroll_lock = 0; /* scrollock off */ - -#if PCVT_INHIBIT_NUMLOCK - svsp->num_lock = 0; /* numlock off */ -#else - svsp->num_lock = 1; /* numlock on */ -#endif - - svsp->caps_lock = 0; /* capslock off */ - svsp->shift_lock = 0; /* shiftlock off */ - -#if PCVT_24LINESDEF /* true compatibility */ - svsp->force24 = 1; /* force 24 lines */ -#else /* maximum screen size */ - svsp->force24 = 0; /* no 24 lines force yet */ -#endif /* PCVT_24LINESDEF */ - - vt_clearudk(svsp); /* clear vt220 udk's */ - - vt_str(svsp); /* init emulator */ - - if(nscr == 0) - { - /* - * Preserve data on the startup screen that - * precedes the cursor position. Leave the - * cursor where it was found. - */ - unsigned cursorat; - int filllen; - - /* CRTC regs 0x0e and 0x0f are r/w everywhere */ - - outb(addr_6845, CRTC_CURSORH); - cursorat = inb(addr_6845+1) << 8; - outb(addr_6845, CRTC_CURSORL); - cursorat |= inb(addr_6845+1); - - svsp->cur_offset = cursorat; - svsp->row = cursorat / svsp->maxcol; - svsp->col = cursorat % svsp->maxcol; - - if (svsp->row >= svsp->screen_rows) - { - - /* - * Scroll up; this should only happen when - * PCVT_24LINESDEF is set - */ - int nscroll = - svsp->row + 1 - - svsp->screen_rows; - bcopy (svsp->Crtat - + nscroll*svsp->maxcol, - svsp->Crtat, - svsp->screen_rows - * svsp->maxcol * CHR); - svsp->row -= nscroll; - svsp->cur_offset -= - nscroll * svsp->maxcol; - } - - filllen = (svsp->maxcol * svsp->screen_rowsize) - - svsp->cur_offset; - - if (filllen > 0) - fillw(user_attr | ' ', - svsp->Crtat+svsp->cur_offset, - filllen); - } - svsp->smode.mode = VT_AUTO; - svsp->smode.relsig = svsp->smode.acqsig = - svsp->smode.frsig = 0; - svsp->proc = 0; - svsp->kbd_state = K_XLATE; - svsp->pid = svsp->vt_status = 0; - } - - for(charset = 0;charset < NVGAFONTS;charset++) - { - vgacs[charset].loaded = 0; /* not populated yet */ - vgacs[charset].secondloaded = 0; /* not populated yet */ - - switch(adaptor_type) - { - case VGA_ADAPTOR: - - /* - * for a VGA, do not assume any - * constant - instead, read the actual - * values. This avoid problems with - * LCD displays that apparently happen - * to use font matrices up to 19 - * scan lines and 475 scan lines - * total in order to make use of the - * whole screen area - */ - - outb(addr_6845, CRTC_VDE); - vgacs[charset].scr_scanlines = - inb(addr_6845 + 1); - outb(addr_6845, CRTC_MAXROW); - vgacs[charset].char_scanlines = - inb(addr_6845 + 1); - break; - - case EGA_ADAPTOR: - /* 0x5D for 25 lines */ - vgacs[charset].scr_scanlines = 0x5D; - /* 0x4D for 25 lines */ - vgacs[charset].char_scanlines = 0x4D; - break; - - case CGA_ADAPTOR: - case MDA_ADAPTOR: - default: - /* These shouldn't be used for CGA/MDA */ - vgacs[charset].scr_scanlines = 0; - vgacs[charset].char_scanlines = 0; - break; - } - vgacs[charset].screen_size = SIZ_25ROWS; /* set screen size */ - } - - vgacs[0].loaded = 1; /* The BIOS loaded this at boot */ - - /* set cursor for first screen */ - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1,vs[0].cursor_start); - outb(addr_6845,CRTC_CUREND); /* cursor end reg */ - outb(addr_6845+1,vs[0].cursor_end); - - /* this is to satisfy ddb */ - - if(!keyboard_is_initialized) - kbd_code_init1(); - - /* update keyboard led's */ - - update_led(); -} - -/*---------------------------------------------------------------------------* - * get kernel memory for virtual screens - * - * CAUTION: depends on "can_do_132col" being set properly, or - * depends on vga_type() being run before calling this !!! - * - *---------------------------------------------------------------------------*/ -void -vt_coldmalloc(void) -{ - int nscr; - int screen_max_size; - - /* we need to initialize in case we are not the console */ - - if(do_initialization) - vt_coldinit(); - - switch(adaptor_type) - { - default: - case MDA_ADAPTOR: - case CGA_ADAPTOR: - screen_max_size = MAXROW_MDACGA * MAXCOL_MDACGA * CHR; - break; - - case EGA_ADAPTOR: - screen_max_size = MAXROW_EGA * MAXCOL_EGA * CHR; - break; - - case VGA_ADAPTOR: - if(can_do_132col) - screen_max_size = - MAXROW_VGA * MAXCOL_SVGA * CHR; - else - screen_max_size = - MAXROW_VGA * MAXCOL_VGA * CHR; - } - - for(nscr = 0; nscr < PCVT_NSCREENS; nscr++) - { - if((vs[nscr].Memory = - (u_short *)malloc(screen_max_size * 2, M_DEVBUF, M_WAITOK)) - == NULL) - { - printf("pcvt: screen memory malloc failed, " - "NSCREEN=%d, nscr=%d\n", - PCVT_NSCREENS, nscr); - break; - } - if(nscr != 0) - { - vs[nscr].Crtat = vs[nscr].Memory; - fillw(user_attr | ' ', - vs[nscr].Crtat, - vs[nscr].maxcol * vs[nscr].screen_rowsize); - totalscreens++; - } - } -} - -/*---------------------------------------------------------------------------* - * check if we must scroll up screen - *---------------------------------------------------------------------------*/ -static void -check_scroll(struct video_state *svsp) -{ - if(!svsp->abs_write) - { - /* we write within scroll region */ - - if(svsp->cur_offset >= ((svsp->scrr_end + 1) * svsp->maxcol)) - { - /* the following piece of code has to be protected */ - /* from trying to switch to another virtual screen */ - /* while being in there ... */ - - critical_scroll = 1; /* flag protect ON */ - - roll_up(svsp, 1); /* rolling up .. */ - - svsp->cur_offset -= svsp->maxcol;/* update position */ - - if(switch_page != -1) /* someone wanted to switch ? */ - { - vgapage(switch_page); /* yes, then switch ! */ - switch_page = -1; /* reset switch flag */ - } - - critical_scroll = 0; /* flag protect OFF */ - } - } - else - { - /* clip, if outside of screen */ - - if (svsp->cur_offset >= svsp->screen_rows * svsp->maxcol) - svsp->cur_offset -= svsp->maxcol; - } -} - -/*---------------------------------------------------------------------------* - * write to one user function key label - *---------------------------------------------------------------------------*/ -static void -writefkl(int num, u_char *string, struct video_state *svsp) -{ - if((num < 0) || (num > 7)) /* range ok ? */ - return; - - strncpy(svsp->ufkl[num], string, 16); /* save string in static array */ - - if(svsp->which_fkl == USR_FKL) - wrfkl(num,string,svsp); -} - -/*---------------------------------------------------------------------------* - * write to one system function key label - *---------------------------------------------------------------------------*/ -void -swritefkl(int num, u_char *string, struct video_state *svsp) -{ - if((num < 0) || (num > 7)) /* range ok ? */ - return; - - strncpy(svsp->sfkl[num], string, 16); /* save string in static array */ - - if(svsp->which_fkl == SYS_FKL) - wrfkl(num,string,svsp); -} - -/*---------------------------------------------------------------------------* - * write function key label onto screen - *---------------------------------------------------------------------------*/ -static void -wrfkl(int num, u_char *string, struct video_state *svsp) -{ - register u_short *p; - register u_short *p1; - register int cnt = 0; - - if(!svsp->labels_on || (svsp->vt_pure_mode == M_PUREVT)) - return; - - p = (svsp->Crtat - + (svsp->screen_rows * svsp->maxcol)); /* screen_rows+1 line */ - - if(svsp->maxcol == SCR_COL80) - { - if(num < 4) /* labels 1 .. 4 */ - p += (num * LABEL_LEN); - else /* labels 5 .. 8 */ - p += ((num * LABEL_LEN) + LABEL_MID + 1); - } - else - { - if(num < 4) /* labels 1 .. 4 */ - p += (num * (LABEL_LEN + 6)); - else /* labels 5 .. 8 */ - p += ((num * (LABEL_LEN + 6)) + LABEL_MID + 11); - - } - p1 = p + svsp->maxcol; /* second label line */ - - while((*string != '\0') && (cnt < 8)) - { - *p = ((0x70 << 8) + (*string & 0xff)); - p++; - string++; - cnt++; - } - while(cnt < 8) - { - *p = ((0x70 << 8) + ' '); - p++; - cnt++; - } - - while((*string != '\0') && (cnt < 16)) - { - *p1 = ((0x70 << 8) + (*string & 0xff)); - p1++; - string++; - cnt++; - } - while(cnt < 16) - { - *p1 = ((0x70 << 8) + ' '); - p1++; - cnt++; - } -} - -/*---------------------------------------------------------------------------* - * remove (=blank) function key labels, row/col and status line - *---------------------------------------------------------------------------*/ -void -fkl_off(struct video_state *svsp) -{ - register u_short *p; - register int num; - register int size; - - svsp->labels_on = 0; - - if((vgacs[svsp->vga_charset].screen_size==SIZ_28ROWS) && svsp->force24) - size = 4; - else - size = 3; - - p = (svsp->Crtat + (svsp->screen_rows * svsp->maxcol)); - - for(num = 0; num < (size * svsp->maxcol); num++) - *p++ = ' '; -} - -/*---------------------------------------------------------------------------* - * (re-) display function key labels, row/col and status line - *---------------------------------------------------------------------------*/ -void -fkl_on(struct video_state *svsp) -{ - svsp->labels_on = 1; - - if(svsp->which_fkl == SYS_FKL) - sw_sfkl(svsp); - else if(svsp->which_fkl == USR_FKL) - sw_ufkl(svsp); -} - -/*---------------------------------------------------------------------------* - * set emulation mode, switch between pure VTxxx mode and HP/VTxxx mode - *---------------------------------------------------------------------------*/ -void -set_emulation_mode(struct video_state *svsp, int mode) -{ - if(svsp->vt_pure_mode == mode) - return; - - clr_parms(svsp); /* escape parameter init */ - svsp->state = STATE_INIT; /* initial state */ - svsp->scrr_beg = 0; /* start of scrolling region */ - svsp->sc_flag = 0; /* invalidate saved cursor position */ - svsp->transparent = 0; /* disable control code processing */ - - if(mode == M_HPVT) /* vt-pure -> hp/vt-mode */ - { - svsp->screen_rows = svsp->screen_rowsize - 3; - if (svsp->force24 && svsp->screen_rows == 25) - svsp->screen_rows = 24; - - if (svsp->row >= svsp->screen_rows) { - /* Scroll up */ - int nscroll = svsp->row + 1 - svsp->screen_rows; - bcopy (svsp->Crtat + nscroll * svsp->maxcol, - svsp->Crtat, - svsp->screen_rows * svsp->maxcol * CHR); - svsp->row -= nscroll; - svsp->cur_offset -= nscroll * svsp->maxcol; - } - - svsp->vt_pure_mode = M_HPVT; - - if (svsp->vs_tty) - svsp->vs_tty->t_winsize.ws_row = svsp->screen_rows; - - svsp->scrr_len = svsp->screen_rows; - svsp->scrr_end = svsp->scrr_len - 1; - - update_hp(svsp); - } - else if(mode == M_PUREVT) /* hp/vt-mode -> vt-pure */ - { - fillw(user_attr | ' ', - svsp->Crtat + svsp->screen_rows * svsp->maxcol, - (svsp->screen_rowsize - svsp->screen_rows) - * svsp->maxcol); - - svsp->vt_pure_mode = M_PUREVT; - - svsp->screen_rows = svsp->screen_rowsize; - if (svsp->force24 && svsp->screen_rows == 25) - svsp->screen_rows = 24; - - if (svsp->vs_tty) - svsp->vs_tty->t_winsize.ws_row = svsp->screen_rows; - - svsp->scrr_len = svsp->screen_rows; - svsp->scrr_end = svsp->scrr_len - 1; - } - -#if PCVT_SIGWINCH - if (svsp->vs_tty && svsp->vs_tty->t_pgrp) - pgsignal(svsp->vs_tty->t_pgrp, SIGWINCH, 1); -#endif /* PCVT_SIGWINCH */ - -} - -/*---------------------------------------------------------------------------* - * initialize user function key labels - *---------------------------------------------------------------------------*/ -void -init_ufkl(struct video_state *svsp) -{ - writefkl(0,(u_char *)" f1",svsp); /* init fkey labels */ - writefkl(1,(u_char *)" f2",svsp); - writefkl(2,(u_char *)" f3",svsp); - writefkl(3,(u_char *)" f4",svsp); - writefkl(4,(u_char *)" f5",svsp); - writefkl(5,(u_char *)" f6",svsp); - writefkl(6,(u_char *)" f7",svsp); - writefkl(7,(u_char *)" f8",svsp); -} - -/*---------------------------------------------------------------------------* - * initialize system user function key labels - *---------------------------------------------------------------------------*/ -void -init_sfkl(struct video_state *svsp) -{ - /* 1234567812345678 */ - if(can_do_132col) - /* 1234567812345678 */ - swritefkl(0,(u_char *)"132 COLUMNS ",svsp); - else - swritefkl(0,(u_char *)" ",svsp); - - /* 1234567812345678 */ - swritefkl(1,(u_char *)"SOFT-RSTTERMINAL",svsp); - - if(svsp->force24) - swritefkl(2,(u_char *)"FORCE24 ENABLE *",svsp); - else - swritefkl(2,(u_char *)"FORCE24 ENABLE ",svsp); - -#if PCVT_SHOWKEYS /* 1234567812345678 */ - if(svsp == &vs[0]) - swritefkl(3,(u_char *)"KEYBSCANDISPLAY ",svsp); - else - swritefkl(3,(u_char *)" ",svsp); -#else - swritefkl(3,(u_char *)" ",svsp); -#endif /* PCVT_SHOWKEYS */ - - /* 1234567812345678 */ - if(svsp->bell_on) - swritefkl(4,(u_char *)"BELL ENABLE *",svsp); - else - swritefkl(4,(u_char *)"BELL ENABLE ",svsp); - - if(svsp->sevenbit) - swritefkl(5,(u_char *)"8-BIT ENABLE ",svsp); - else - swritefkl(5,(u_char *)"8-BIT ENABLE *",svsp); - - swritefkl(6,(u_char *)"DISPLAY FUNCTNS ",svsp); - - swritefkl(7,(u_char *)"AUTOWRAPENABLE *",svsp); - /* 1234567812345678 */ -} - -/*---------------------------------------------------------------------------* - * switch display to user function key labels - *---------------------------------------------------------------------------*/ -void -sw_ufkl(struct video_state *svsp) -{ - int i; - svsp->which_fkl = USR_FKL; - for(i = 0; i < 8; i++) - wrfkl(i,svsp->ufkl[i],svsp); -} - -/*---------------------------------------------------------------------------* - * switch display to system function key labels - *---------------------------------------------------------------------------*/ -void -sw_sfkl(struct video_state *svsp) -{ - int i; - svsp->which_fkl = SYS_FKL; - for(i = 0; i < 8; i++) - wrfkl(i,svsp->sfkl[i],svsp); -} - -/*---------------------------------------------------------------------------* - * toggle force 24 lines - *---------------------------------------------------------------------------*/ -void -toggl_24l(struct video_state *svsp) -{ - if(svsp->which_fkl == SYS_FKL) - { - if(svsp->force24) - { - svsp->force24 = 0; - swritefkl(2,(u_char *)"FORCE24 ENABLE ",svsp); - } - else - { - svsp->force24 = 1; - swritefkl(2,(u_char *)"FORCE24 ENABLE *",svsp); - } - set_screen_size(svsp, vgacs[(svsp->vga_charset)].screen_size); - } -} - -#if PCVT_SHOWKEYS -/*---------------------------------------------------------------------------* - * toggle keyboard scancode display - *---------------------------------------------------------------------------*/ -void -toggl_kbddbg(struct video_state *svsp) -{ - if((svsp->which_fkl == SYS_FKL) && (svsp == &vs[0])) - { - if(keyboard_show) - { - keyboard_show = 0; - swritefkl(3,(u_char *)"KEYBSCANDISPLAY ",svsp); - } - else - { - keyboard_show = 1; - swritefkl(3,(u_char *)"KEYBSCANDISPLAY*",svsp); - } - } -} -#endif /* PCVT_SHOWKEYS */ - -/*---------------------------------------------------------------------------* - * toggle display functions - *---------------------------------------------------------------------------*/ -void -toggl_dspf(struct video_state *svsp) -{ - if(svsp->which_fkl == SYS_FKL) - { - if(svsp->dis_fnc) - { - svsp->dis_fnc = 0; - swritefkl(6,(u_char *)"DISPLAY FUNCTNS ",svsp); - } - else - { - svsp->dis_fnc = 1; - swritefkl(6,(u_char *)"DISPLAY FUNCTNS*",svsp); - } - } -} - -/*---------------------------------------------------------------------------* - * auto wrap on/off - *---------------------------------------------------------------------------*/ -void -toggl_awm(struct video_state *svsp) -{ - if(svsp->which_fkl == SYS_FKL) - { - if(svsp->m_awm) - { - svsp->m_awm = 0; - swritefkl(7,(u_char *)"AUTOWRAPENABLE ",svsp); - } - else - { - svsp->m_awm = 1; - swritefkl(7,(u_char *)"AUTOWRAPENABLE *",svsp); - } - } -} - -/*---------------------------------------------------------------------------* - * bell on/off - *---------------------------------------------------------------------------*/ -void -toggl_bell(struct video_state *svsp) -{ - if(svsp->which_fkl == SYS_FKL) - { - if(svsp->bell_on) - { - svsp->bell_on = 0; - swritefkl(4,(u_char *)"BELL ENABLE ",svsp); - } - else - { - svsp->bell_on = 1; - swritefkl(4,(u_char *)"BELL ENABLE *",svsp); - } - } -} - -/*---------------------------------------------------------------------------* - * 7/8 bit usage - *---------------------------------------------------------------------------*/ -void -toggl_sevenbit(struct video_state *svsp) -{ - if(svsp->which_fkl == SYS_FKL) - { - if(svsp->sevenbit) - { - svsp->sevenbit = 0; - swritefkl(5,(u_char *)"8-BIT ENABLE *",svsp); - } - else - { - svsp->sevenbit = 1; - swritefkl(5,(u_char *)"8-BIT ENABLE ",svsp); - } - } -} - -/*---------------------------------------------------------------------------* - * 80 / 132 columns - *---------------------------------------------------------------------------*/ -void -toggl_columns(struct video_state *svsp) -{ - if(svsp->which_fkl == SYS_FKL) - { - if(svsp->maxcol == SCR_COL132) - { - if(vt_col(svsp, SCR_COL80)) - svsp->maxcol = 80; - } - else - { - if(vt_col(svsp, SCR_COL132)) - svsp->maxcol = 132; - } - } -} - -/*---------------------------------------------------------------------------* - * toggle vga 80/132 column operation - *---------------------------------------------------------------------------*/ -int -vt_col(struct video_state *svsp, int cols) -{ - if(vga_col(svsp, cols) == 0) - return(0); - - if(cols == SCR_COL80) - swritefkl(0,(u_char *)"132 COLUMNS ",svsp); - else - swritefkl(0,(u_char *)"132 COLUMNS*",svsp); - - fillw(user_attr | ' ', - svsp->Crtat, - svsp->maxcol * svsp->screen_rowsize); - - clr_parms(svsp); /* escape parameter init */ - svsp->state = STATE_INIT; /* initial state */ - svsp->col = 0; /* init row */ - svsp->row = 0; /* init col */ - svsp->cur_offset = 0; /* cursor offset init */ - svsp->sc_flag = 0; /* invalidate saved cursor position */ - svsp->scrr_beg = 0; /* reset scrolling region */ - svsp->scrr_len = svsp->screen_rows; /*reset scrolling region legnth */ - svsp->scrr_end = svsp->scrr_len - 1; - svsp->transparent = 0; /* disable control code processing */ - svsp->selchar = 0; /* selective attr off */ - vt_initsel(svsp); /* re-init sel attr */ - - update_hp(svsp); /* update labels, row/col, page ind */ - - /* Update winsize struct to reflect screen size */ - - if(svsp->vs_tty) - { - svsp->vs_tty->t_winsize.ws_row = svsp->screen_rows; - svsp->vs_tty->t_winsize.ws_col = svsp->maxcol; - svsp->vs_tty->t_winsize.ws_xpixel = - (cols == SCR_COL80)? 720: 1056; - svsp->vs_tty->t_winsize.ws_ypixel = 400; - -#if PCVT_SIGWINCH - if(svsp->vs_tty->t_pgrp) - pgsignal(svsp->vs_tty->t_pgrp, SIGWINCH, 1); -#endif /* PCVT_SIGWINCH */ - - } - return(1); -} - -/*---------------------------------------------------------------------------* - * update HP stuff on screen - *---------------------------------------------------------------------------*/ -void -update_hp(struct video_state *svsp) -{ - if(svsp->vt_pure_mode != M_HPVT) - return; - - fillw (user_attr | ' ', - svsp->Crtat + svsp->screen_rows * svsp->maxcol, - (svsp->screen_rowsize - svsp->screen_rows) * svsp->maxcol); - - if (!svsp->labels_on) - return; - - /* update fkey labels */ - - fkl_off(svsp); - fkl_on(svsp); - - if(vsp == svsp) - { - /* update current displayed screen indicator */ - - *((svsp->Crtat + ((svsp->screen_rows + 2) * svsp->maxcol)) - + svsp->maxcol - 3) = user_attr | '['; - *((svsp->Crtat + ((svsp->screen_rows + 2) * svsp->maxcol)) - + svsp->maxcol - 2) = user_attr | (current_video_screen + '0'); - *((svsp->Crtat + ((svsp->screen_rows + 2) * svsp->maxcol)) - + svsp->maxcol - 1) = user_attr | ']'; - } -} - -/*---------------------------------------------------------------------------* - * initialize ANSI escape sequence parameter buffers - *---------------------------------------------------------------------------*/ -void -clr_parms(struct video_state *svsp) -{ - register int i; - for(i=0; i < MAXPARMS; i++) - svsp->parms[i] = 0; - svsp->parmi = 0; -} - - -/*---------------------------------------------------------------------------* - * - * partial HP 2392 ANSI mode Emulator - * ================================== - * - * this part tooks over the emulation of some escape sequences - * needed to handle the function key labels - * - * They are modeled after the corresponding escape sequences - * introduced with the HP2392 terminals from Hewlett-Packard. - * - * see: - * "HP2392A, Display Terminal Reference Manual", - * HP Manual Part Number 02390-90001 - * and: - * Reference Manual Supplement - * "2392A Display Terminal Option 049, ANSI Operation" - * HP Manual Part Number 02390-90023EN - * - *---------------------------------------------------------------------------*/ - -static void -hp_entry(U_char ch, struct video_state *svsp) -{ - switch(svsp->hp_state) - { - case SHP_INIT: - switch(ch) - { - case 'f': - svsp->hp_state = SHP_AND_F; - svsp->attribute = 0; - svsp->key = 0; - svsp->l_len = 0; - svsp->s_len = 0; - svsp->i = 0; - break; - - case 'j': - svsp->m_len = 0; - svsp->hp_state = SHP_AND_J; - break; - - case 's': - svsp->hp_state = SHP_AND_ETE; - break; - - default: - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - break; - } - break; - - case SHP_AND_F: - if((ch >= '0') && (ch <= '8')) - { - svsp->attribute = ch; - svsp->hp_state = SHP_AND_Fa; - } - else - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - break; - - case SHP_AND_Fa: - if(ch == 'a') - svsp->hp_state = SHP_AND_Fak; - else if(ch == 'k') - { - svsp->key = svsp->attribute; - svsp->hp_state = SHP_AND_Fakd; - } - else - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - break; - - case SHP_AND_Fak: - if((ch >= '1') && (ch <= '8')) - { - svsp->key = ch; - svsp->hp_state = SHP_AND_Fak1; - } - else - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - break; - - case SHP_AND_Fak1: - if(ch == 'k') - svsp->hp_state = SHP_AND_Fakd; - else - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - break; - - case SHP_AND_Fakd: - if(svsp->l_len > 16) - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - else if(ch >= '0' && ch <= '9') - { - svsp->l_len *= 10; - svsp->l_len += (ch -'0'); - } - else if(ch == 'd') - svsp->hp_state = SHP_AND_FakdL; - else - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - break; - - case SHP_AND_FakdL: - if(svsp->s_len > 80) - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - else if(ch >= '0' && ch <= '9') - { - svsp->s_len *= 10; - svsp->s_len += (ch -'0'); - } - else if(ch == 'L') - { - svsp->hp_state = SHP_AND_FakdLl; - svsp->transparent = 1; - } - else - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - } - break; - - case SHP_AND_FakdLl: - svsp->l_buf[svsp->i] = ch; - if(svsp->i >= svsp->l_len-1) - { - svsp->hp_state = SHP_AND_FakdLls; - svsp->i = 0; - if(svsp->s_len == 0) - { - svsp->state = STATE_INIT; - svsp->hp_state = SHP_INIT; - svsp->transparent = 0; - svsp->i = 0; - svsp->l_buf[svsp->l_len] = '\0'; - svsp->s_buf[svsp->s_len] = '\0'; - writefkl((svsp->key - '0' -1), - svsp->l_buf, svsp); - } - } - else - svsp->i++; - break; - - case SHP_AND_FakdLls: - svsp->s_buf[svsp->i] = ch; - if(svsp->i >= svsp->s_len-1) - { - svsp->state = STATE_INIT; - svsp->hp_state = SHP_INIT; - svsp->transparent = 0; - svsp->i = 0; - svsp->l_buf[svsp->l_len] = '\0'; - svsp->s_buf[svsp->s_len] = '\0'; - writefkl((svsp->key - '0' -1), svsp->l_buf, - svsp); - } - else - svsp->i++; - break; - - case SHP_AND_J: - switch(ch) - { - case '@': /* enable user keys, remove */ - /* all labels & status from */ - /* screen */ - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - fkl_off(svsp); - break; - - case 'A': /* enable & display "modes" */ - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - fkl_on(svsp); - sw_sfkl(svsp); - break; - - case 'B': /* enable & display "user" */ - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - fkl_on(svsp); - sw_ufkl(svsp); - break; - - case 'C': /* remove (clear) status line*/ - /* and restore current labels*/ - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - fkl_on(svsp); - break; - - case 'R': /* enable usr/menu keys */ - /* and fkey label modes */ - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - break; - - case 'S': /* disable usr/menu keys */ - /* and fkey label modes */ - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - break; - - case '0': - case '1': - case '2': - case '3': - case '4': - case '5': - case '6': - case '7': - case '8': - case '9': /* parameters for esc & j xx L mm */ - svsp->m_len *= 10; - svsp->m_len += (ch -'0'); - break; - - case 'L': - svsp->hp_state = SHP_AND_JL; - svsp->i = 0; - svsp->transparent = 1; - break; - - default: - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - break; - - } - break; - - - case SHP_AND_JL: - svsp->m_buf[svsp->i] = ch; - if(svsp->i >= svsp->m_len-1) - { - svsp->state = STATE_INIT; - svsp->hp_state = SHP_INIT; - svsp->transparent = 0; - svsp->i = 0; - svsp->m_buf[svsp->m_len] = '\0'; - /* display status line */ - /* needs to be implemented */ - /* see 2392 man, 3-14 */ - - } - else - svsp->i++; - break; - - case SHP_AND_ETE: /* eat chars until uppercase */ - if(ch >= '@' && ch <= 'Z') - { - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - svsp->transparent = 0; - } - break; - - default: - svsp->hp_state = SHP_INIT; - svsp->state = STATE_INIT; - svsp->transparent = 0; - break; - } -} - -/* ------------------------- E O F ------------------------------------------*/ - diff --git a/sys/arch/i386/isa/pcvt/pcvt_sup.c b/sys/arch/i386/isa/pcvt/pcvt_sup.c deleted file mode 100644 index ceb86f98ae3a..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_sup.c +++ /dev/null @@ -1,2049 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore and Scott Turner. - * - * Copyright (C) 1992, 1993 Soeren Schmidt. - * - * All rights reserved. - * - * For the sake of compatibility, portions of this code regarding the - * X server interface are taken from Soeren Schmidt's syscons driver. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis, - * Brian Dunford-Shore, Joerg Wunsch, Scott Turner and Soeren Schmidt. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_sup.c, 3.32, Last Edit-Date: [Tue Oct 3 11:19:49 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_sup.c VT220 Driver Support Routines - * --------------------------------------------- - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -hm removed paranoid delay()/DELAY() from vga_test() - * -hm removing vgapage() protection if PCVT_KBD_FIFO - * -hm some new CONF_ - values - * -hm Joerg's patches for FreeBSD ttymalloc - * -hm applying Joerg's patches for FreeBSD 2.0 - * -hm applying Lon Willet's patches for NetBSD - * -hm NetBSD PR #400: patch to short-circuit TIOCSWINSZ - * -hm getting PCVT_BURST reported correctly for FreeBSD 2.0 - * -hm applying patch from Joerg fixing Crtat bug - * -hm moving ega/vga coldinit support code to mda2egaorvga() - * -hm patch from Thomas Eberhardt fixing force 24 lines fkey update - * -hm bugfix from Joerg: check for svsp->vs_tty before using it - * -hm added support for CONF_MDAFASTSCROLL - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Frank van der Linden for keyboard state per VT - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#include "pcvt_hdr.h" /* global include */ - -static void vid_cursor ( struct cursorshape *data ); -static void vgasetfontattr ( struct vgafontattr *data ); -static void vgagetfontattr ( struct vgafontattr *data ); -static void vgaloadchar ( struct vgaloadchar *data ); -static void vid_getscreen ( struct screeninfo *data, Dev_t dev ); -static void vid_setscreen ( struct screeninfo *data, Dev_t dev ); -static void setchargen ( void ); -static void setchargen3 ( void ); -static void resetchargen ( void ); -static void vgareadpel ( struct vgapel *data, Dev_t dev ); -static void vgawritepel ( struct vgapel *data, Dev_t dev ); -static void vgapcvtid ( struct pcvtid *data ); -static void vgapcvtinfo ( struct pcvtinfo *data ); - -#ifdef XSERVER -static unsigned char * compute_charset_base ( unsigned fontset ); -#endif /* XSERVER */ - -#if PCVT_SCREENSAVER -static void scrnsv_timedout ( void *arg ); -static u_short *savedscreen = (u_short *)0; /* ptr to screen contents */ -static size_t scrnsv_size = (size_t)-1; /* size of saved image */ -static struct callout scrnsv_timedout_ch = CALLOUT_INITIALIZER; - -#if PCVT_PRETTYSCRNS -static u_short *scrnsv_current = (u_short *)0; /* attention char ptr */ -static void scrnsv_blink ( void ); -static u_short getrand ( void ); -#endif /* PCVT_PRETTYSCRNS */ - -#endif /* PCVT_SCREENSAVER */ - - -/*---------------------------------------------------------------------------* - * execute vga ioctls - *---------------------------------------------------------------------------*/ -int -vgaioctl(Dev_t dev, int cmd, caddr_t data, int flag) -{ - if(minor(dev) >= PCVT_NSCREENS) - return -1; - -/* - * Some of the commands are not applicable if the vt in question, or the - * current vt is in graphics mode (i.e., the X server acts on it); they - * will cause an EAGAIN (resource temporarily unavailable) to be returned. - */ - -#ifdef XSERVER -#define is_dev_grafx vs[minor(dev)].vt_status & VT_GRAFX -#define is_current_grafx vsp->vt_status & VT_GRAFX -#else /* !XSERVER */ -#define is_dev_grafx 0 /* not applicable */ -#define is_current_grafx 0 -#endif /* XSERVER */ - - switch(cmd) - { - case VGACURSOR: - if(is_current_grafx) - return EAGAIN; - vid_cursor((struct cursorshape *)data); - break; - - case VGALOADCHAR: - if((adaptor_type != VGA_ADAPTOR) && - (adaptor_type != EGA_ADAPTOR)) - return -1; - if(is_current_grafx) - return EAGAIN; - vgaloadchar((struct vgaloadchar *)data); - break; - - case VGASETFONTATTR: - if((adaptor_type != VGA_ADAPTOR) && - (adaptor_type != EGA_ADAPTOR)) - return -1; - -#if PCVT_SCREENSAVER - pcvt_scrnsv_reset(); -#endif /* PCVT_SCREENSAVER */ - - vgasetfontattr((struct vgafontattr *)data); - break; - - case VGAGETFONTATTR: - if((adaptor_type != VGA_ADAPTOR) && - (adaptor_type != EGA_ADAPTOR)) - return -1; - vgagetfontattr((struct vgafontattr *)data); - break; - - case VGASETSCREEN: - -#if PCVT_SCREENSAVER - pcvt_scrnsv_reset(); -#endif /* PCVT_SCREENSAVER */ - - vid_setscreen((struct screeninfo *)data, dev); - break; - - case VGAGETSCREEN: - vid_getscreen((struct screeninfo *)data, dev); - break; - - case VGAREADPEL: - if(adaptor_type != VGA_ADAPTOR) - return -1; - if(is_dev_grafx) - return EAGAIN; - vgareadpel((struct vgapel *)data, dev); - break; - - case VGAWRITEPEL: - if(adaptor_type != VGA_ADAPTOR) - return -1; - if(is_dev_grafx) - return EAGAIN; - vgawritepel((struct vgapel *)data, dev); - break; - -#if PCVT_SCREENSAVER - case VGASCREENSAVER: - if(is_current_grafx) - return EAGAIN; - pcvt_set_scrnsv_tmo(*(int *)data); - pcvt_scrnsv_reset(); - break; -#endif /* PCVT_SCREENSAVER */ - - case VGAPCVTID: - vgapcvtid((struct pcvtid *)data); - break; - - case VGAPCVTINFO: - vgapcvtinfo((struct pcvtinfo *)data); - break; - - case VGASETCOLMS: - if(is_dev_grafx) - return EAGAIN; - if(*(int *)data == 80) - (void)vt_col(&vs[minor(dev)], SCR_COL80); - else if(*(int *)data == 132) - { - if(vt_col(&vs[minor(dev)], SCR_COL132) == 0) - return EINVAL; /* not a VGA */ - } - else - return EINVAL; - break; - - case TIOCSWINSZ: - /* do nothing here */ - break; - - default: - return -1; - } - return 0; - -#undef is_dev_grafx -#undef is_current_grafx -} - -/*---------------------------------------------------------------------------* - * video ioctl - return driver id - *---------------------------------------------------------------------------*/ -static void -vgapcvtid(struct pcvtid *data) -{ - strcpy(data->name, PCVTIDNAME); - data->rmajor = PCVTIDMAJOR; - data->rminor = PCVTIDMINOR; -} - -/*---------------------------------------------------------------------------* - * video ioctl - return driver compile time options data - *---------------------------------------------------------------------------*/ -static void -vgapcvtinfo(struct pcvtinfo *data) -{ - data->opsys = CONF_NETBSD; - data->opsysrel = __NetBSD_Version__; /* ??? */ - - data->nscreens = PCVT_NSCREENS; - data->scanset = PCVT_SCANSET; - data->sysbeepf = PCVT_SYSBEEPF; - - data->pcburst = PCVT_PCBURST; - -#if PCVT_KBD_FIFO - data->kbd_fifo_sz = PCVT_KBD_FIFO_SZ; -#else - data->kbd_fifo_sz = 0; -#endif - - data->compile_opts = (0 - -#if PCVT_VT220KEYB - | CONF_VT220KEYB -#endif -#if PCVT_SCREENSAVER - | CONF_SCREENSAVER -#endif -#if PCVT_PRETTYSCRNS - | CONF_PRETTYSCRNS -#endif -#if PCVT_CTRL_ALT_DEL - | CONF_CTRL_ALT_DEL -#endif -#if PCVT_USEKBDSEC - | CONF_USEKBDSEC -#endif -#if PCVT_24LINESDEF - | CONF_24LINESDEF -#endif -#if PCVT_EMU_MOUSE - | CONF_EMU_MOUSE -#endif -#if PCVT_SHOWKEYS - | CONF_SHOWKEYS -#endif -#if PCVT_KEYBDID - | CONF_KEYBDID -#endif -#if PCVT_SIGWINCH - | CONF_SIGWINCH -#endif -#if PCVT_NULLCHARS - | CONF_NULLCHARS -#endif -#if PCVT_BACKUP_FONTS - | CONF_BACKUP_FONTS -#endif -#if PCVT_SW0CNOUTP /* was FORCE8BIT */ - | CONF_SW0CNOUTP -#endif -#if PCVT_SETCOLOR - | CONF_SETCOLOR -#endif -#if PCVT_132GENERIC - | CONF_132GENERIC -#endif -#if PCVT_PALFLICKER - | CONF_PALFLICKER -#endif -#if PCVT_WAITRETRACE - | CONF_WAITRETRACE -#endif -#ifdef XSERVER - | CONF_XSERVER -#endif -#if PCVT_PORTIO_DELAY - | CONF_PORTIO_DELAY -#endif -#if PCVT_INHIBIT_NUMLOCK - | CONF_INHIBIT_NUMLOCK -#endif -#if PCVT_META_ESC - | CONF_META_ESC -#endif -#if PCVT_KBD_FIFO - | CONF_KBD_FIFO -#endif -#if PCVT_NOFASTSCROLL - | CONF_NOFASTSCROLL -#endif -#if PCVT_MDAFASTSCROLL - | CONF_MDAFASTSCROLL -#endif -#if PCVT_NO_LED_UPDATE - | CONF_NO_LED_UPDATE -#endif - ); -} - -/*---------------------------------------------------------------------------* - * video ioctl - set cursor appearence - *---------------------------------------------------------------------------*/ -static void -vid_cursor(struct cursorshape *data) -{ - int screen; - int start; - int end; - int line_height; - int character_set; - - /* for which virtual screen, -1 for current */ - screen = data->screen_no; - - if(screen == -1) /* current ? */ - screen = current_video_screen; - else if(screen > totalscreens - 1) - screen = totalscreens - 1; - else if(screen < 0) - screen = 0; - - if(adaptor_type == VGA_ADAPTOR || adaptor_type == EGA_ADAPTOR) - { - character_set = vs[screen].vga_charset; - character_set = (character_set < 0) ? 0 : - ((character_set < totalfonts) ? - character_set : - totalfonts-1); - - line_height = vgacs[character_set].char_scanlines & 0x1F; - } - else if(adaptor_type == MDA_ADAPTOR) - { - line_height = 14; - } - else - { - line_height = 8; /* CGA */ - } - - start = (data->start < 0) ? 0 : - ((data->start > line_height) ? line_height : data->start); - - if((vga_family == VGA_F_TRI) && (start == 0)) - start = 1; - - end = (data->end < 0) ? 0 : - ((data->end > line_height) ? line_height : data->end); - - vs[screen].cursor_start = start; - vs[screen].cursor_end = end; - - if(screen == current_video_screen) - { - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1, start); - outb(addr_6845,CRTC_CUREND); /* cursor end reg */ - outb(addr_6845+1, end); - } -} - -/*---------------------------------------------------------------------------* - * ega/vga ioctl - set font attributes - *---------------------------------------------------------------------------*/ -static void -vgasetfontattr(struct vgafontattr *data) -{ - register int i; - int vga_character_set; - int lines_per_character; - int totscanlines; - int size; - - vga_character_set = data->character_set; - vga_character_set = (vga_character_set < 0) ? 0 : - ((vga_character_set < totalfonts) ? - vga_character_set : totalfonts-1); - - vgacs[vga_character_set].loaded = data->font_loaded; - - /* Limit Characters to 32 scanlines doubled */ - vgacs[vga_character_set].char_scanlines = - (data->character_scanlines & 0x1F) - | 0x40; /* always set bit 9 of line cmp reg */ - - if(adaptor_type == EGA_ADAPTOR) - /* ...and screen height to scan 350 lines */ - vgacs[vga_character_set].scr_scanlines = - (data->screen_scanlines > 0x5d) ? - 0x5d : data->screen_scanlines; - else - /* ...and screen height to scan 480 lines */ - vgacs[vga_character_set].scr_scanlines = - (data->screen_scanlines > 0xdF) ? - 0xdF : data->screen_scanlines; - - lines_per_character = - (int)(0x1F & vgacs[vga_character_set].char_scanlines)+1; - - totscanlines = 0x101 + (int)vgacs[vga_character_set].scr_scanlines; - - size = data->screen_size; - - if(adaptor_type == EGA_ADAPTOR) - { - switch(size) - { - case SIZ_25ROWS: /* This case is always OK */ - break; - - case SIZ_35ROWS: - if(totscanlines/lines_per_character >= 35) - size = SIZ_35ROWS; - else - size = SIZ_25ROWS; - break; - - case SIZ_43ROWS: - default: - if(totscanlines/lines_per_character >= 43) - size = SIZ_43ROWS; - else if(totscanlines/lines_per_character >= 35) - size = SIZ_35ROWS; - else - size = SIZ_25ROWS; - break; - } - } - else - { - switch(size) - { - case SIZ_25ROWS: /* This case is always OK */ - break; - - case SIZ_28ROWS: - if(totscanlines/lines_per_character >= 28) - size = SIZ_28ROWS; - else - size = SIZ_25ROWS; - break; - - case SIZ_40ROWS: - if(totscanlines/lines_per_character >= 40) - size = SIZ_40ROWS; - else if(totscanlines/lines_per_character >= 28) - size = SIZ_28ROWS; - else - size = SIZ_25ROWS; - break; - - case SIZ_50ROWS: - default: - if(totscanlines/lines_per_character >= 50) - size = SIZ_50ROWS; - else if(totscanlines/lines_per_character >= 40) - size = SIZ_40ROWS; - else if(totscanlines/lines_per_character >= 28) - size = SIZ_28ROWS; - else - size = SIZ_25ROWS; - break; - } - } - - vgacs[vga_character_set].screen_size = size; - - for (i = 0;i < PCVT_NSCREENS;i++) - { - if(vga_character_set == vs[i].vga_charset) - set_charset(&(vs[i]),vga_character_set); - } - switch_screen(current_video_screen, 0, 0); -} - -/*---------------------------------------------------------------------------* - * ega/vga ioctl - get font attributes - *---------------------------------------------------------------------------*/ -static void -vgagetfontattr(struct vgafontattr *data) -{ - int vga_character_set; - - vga_character_set = data->character_set; - vga_character_set = (vga_character_set < 0) ? 0 : - ((vga_character_set < (int)totalfonts) ? - vga_character_set : - (int)(totalfonts-1)); - - data->character_set = (int)vga_character_set; - - data->font_loaded = (int)vgacs[vga_character_set].loaded; - - data->character_scanlines = - (int)vgacs[vga_character_set].char_scanlines - & 0x1f; /* do not display the overflow bits */ - - data->screen_scanlines = (int)vgacs[vga_character_set].scr_scanlines; - - data->screen_size = (int)vgacs[vga_character_set].screen_size; -} - -/*---------------------------------------------------------------------------* - * ega/vga ioctl - load a character shape into character set - *---------------------------------------------------------------------------*/ -static void -vgaloadchar(struct vgaloadchar *data) -{ - int vga_character_set; - int character; - int lines_per_character; - - vga_character_set = data->character_set; - vga_character_set = (vga_character_set < 0) ? 0 : - ((vga_character_set < (int)totalfonts) ? - vga_character_set : (int)(totalfonts-1)); - - character = (data->character < 0) ? 0 : - ((data->character > 255) ? 255 : data->character); - - lines_per_character = (int)data->character_scanlines; - lines_per_character = (lines_per_character < 0) ? 0 : - ((lines_per_character > 32) ? 32 : lines_per_character); - - loadchar(vga_character_set,character,lines_per_character, - data->char_table); -} - -/*---------------------------------------------------------------------------* - * video ioctl - get screen information - *---------------------------------------------------------------------------*/ -static void -vid_getscreen(struct screeninfo *data, Dev_t dev) -{ - int device = minor(dev); - data->adaptor_type = adaptor_type; /* video adapter installed */ - data->monitor_type = color; /* monitor type installed */ - data->totalfonts = totalfonts; /* no of downloadble fonts */ - data->totalscreens = totalscreens; /* no of virtual screens */ - data->screen_no = device; /* this screen number */ - data->current_screen = current_video_screen; /* displayed screen no */ - /* screen size */ - data->screen_size = vgacs[(vs[device].vga_charset)].screen_size; - /* pure VT mode or HP/VT mode */ - data->pure_vt_mode = vs[device].vt_pure_mode; - data->vga_family = vga_family; /* manufacturer, family */ - data->vga_type = vga_type; /* detected chipset type */ - data->vga_132 = can_do_132col; /* 132 column support */ - data->force_24lines = vs[device].force24; /* force 24 lines */ -} - -/*---------------------------------------------------------------------------* - * video ioctl - set screen information - *---------------------------------------------------------------------------*/ -static void -vid_setscreen(struct screeninfo *data, Dev_t dev) -{ - int screen, x, waitfor; - - if(data->current_screen == -1) - { - screen = minor(dev); - } - else - { - if(data->current_screen >= PCVT_NSCREENS) - return; /* XXXXXX */ - screen = data->current_screen; - } - - vgapage(screen); - - x = spltty(); - - waitfor = screen + 1; - - /* if the vt is yet to be released by a process, wait here */ - - if(vs[screen].vt_status & VT_WAIT_REL) - (void)usl_vt_ioctl(dev, VT_WAITACTIVE, (caddr_t)&waitfor, 0, 0); - - splx(x); - - /* make sure the switch really happened */ - - if(screen != current_video_screen) - return; /* XXX should say "EAGAIN" here */ - - if((data->screen_size != -1) || (data->force_24lines != -1)) - { - if(data->screen_size == -1) - data->screen_size = - vgacs[(vs[screen].vga_charset)].screen_size; - - if(data->force_24lines != -1) - { - vs[screen].force24 = data->force_24lines; - - if(vs[screen].force24) - { - swritefkl(2,(u_char *)"FORCE24 ENABLE *", - &vs[screen]); - } - else - { - swritefkl(2,(u_char *)"FORCE24 ENABLE ", - &vs[screen]); - } - } - - if((data->screen_size == SIZ_25ROWS) || - (data->screen_size == SIZ_28ROWS) || - (data->screen_size == SIZ_35ROWS) || - (data->screen_size == SIZ_40ROWS) || - (data->screen_size == SIZ_43ROWS) || - (data->screen_size == SIZ_50ROWS)) - { - if(data->screen_no == -1) - set_screen_size(vsp, data->screen_size); - else - set_screen_size(&vs[minor(dev)], - data->screen_size); - } - } - - if(data->pure_vt_mode != -1) - { - if((data->pure_vt_mode == M_HPVT) || - (data->pure_vt_mode == M_PUREVT)) - { - if(data->screen_no == -1) - set_emulation_mode(vsp, data->pure_vt_mode); - else - set_emulation_mode(&vs[minor(dev)], - data->pure_vt_mode); - } - } -} - -/*---------------------------------------------------------------------------* - * set screen size/resolution for a virtual screen - *---------------------------------------------------------------------------*/ -void -set_screen_size(struct video_state *svsp, int size) -{ - int i; - - for(i = 0; i < totalfonts; i++) - { - if(vgacs[i].screen_size == size) - { - set_charset(svsp, i); - clr_parms(svsp); /* escape parameter init */ - svsp->state = STATE_INIT; /* initial state */ - svsp->scrr_beg = 0; /* start of scrolling region */ - svsp->sc_flag = 0; /* invalidate saved cursor - * position */ - svsp->transparent = 0; /* disable control code - * processing */ - - /* Update tty to reflect screen size */ - - if (svsp->vs_tty) - { - svsp->vs_tty->t_winsize.ws_col = svsp->maxcol; - svsp->vs_tty->t_winsize.ws_xpixel = - (svsp->maxcol == 80)? 720: 1056; - svsp->vs_tty->t_winsize.ws_ypixel = 400; - svsp->vs_tty->t_winsize.ws_row = - svsp->screen_rows; - } - - /* screen_rows already calculated in set_charset() */ - if(svsp->vt_pure_mode == M_HPVT && svsp->labels_on) - { - if(svsp->which_fkl == SYS_FKL) - sw_sfkl(svsp); - else if(svsp->which_fkl == USR_FKL) - sw_ufkl(svsp); - } - - svsp->scrr_len = svsp->screen_rows; - svsp->scrr_end = svsp->scrr_len - 1; - -#if PCVT_SIGWINCH - if (svsp->vs_tty && svsp->vs_tty->t_pgrp) - pgsignal(svsp->vs_tty->t_pgrp, SIGWINCH, 1); -#endif /* PCVT_SIGWINCH */ - - break; - } - } -} - -/*---------------------------------------------------------------------------* - * VGA ioctl - read DAC palette entry - *---------------------------------------------------------------------------*/ -static void -vgareadpel(struct vgapel *data, Dev_t dev) -{ - register unsigned vpage = minor(dev); - register unsigned idx = data->idx; - - if(idx >= NVGAPEL) - return; /* no such entry */ - - /* do not read VGA palette directly, use saved values */ - data->r = vs[vpage].palette[idx].r; - data->g = vs[vpage].palette[idx].g; - data->b = vs[vpage].palette[idx].b; -} - -/*---------------------------------------------------------------------------* - * VGA ioctl - write DAC palette entry - *---------------------------------------------------------------------------*/ -static void -vgawritepel(struct vgapel *data, Dev_t dev) -{ - register unsigned vpage = minor(dev); - register unsigned idx = data->idx; - - if(idx >= NVGAPEL) - return; /* no such entry */ - - /* first, update saved values for this video screen */ - vs[vpage].palette[idx].r = data->r; - vs[vpage].palette[idx].g = data->g; - vs[vpage].palette[idx].b = data->b; - - /* if this happens on active screen, update VGA DAC, too */ - if(vpage == current_video_screen) - vgapaletteio(idx, &vs[vpage].palette[idx], 1); -} - -/*---------------------------------------------------------------------------* - * VGA physical IO - read/write one palette entry - *---------------------------------------------------------------------------*/ -void -vgapaletteio(unsigned idx, struct rgb *val, int writeit) -{ - -#if PCVT_PALFLICKER - vga_screen_off(); -#endif /* PCVT_PALFLICKER */ - - if(writeit) - { - outb(VGA_DAC + 2, idx); - -#if PCVT_WAITRETRACE - wait_retrace(); -#endif /* PCVT_WAITRETRACE */ - - outb(VGA_DAC + 3, val->r & VGA_PMSK); - -#if PCVT_WAITRETRACE - wait_retrace(); -#endif /* PCVT_WAITRETRACE */ - - outb(VGA_DAC + 3, val->g & VGA_PMSK); - -#if PCVT_WAITRETRACE - wait_retrace(); -#endif /* PCVT_WAITRETRACE */ - - outb(VGA_DAC + 3, val->b & VGA_PMSK); - } - else /* read it */ - { - outb(VGA_DAC + 1, idx); - -#if PCVT_WAITRETRACE - wait_retrace(); -#endif /* PCVT_WAITRETRACE */ - - val->r = inb(VGA_DAC + 3) & VGA_PMSK; - -#if PCVT_WAITRETRACE - wait_retrace(); -#endif /* PCVT_WAITRETRACE */ - - val->g = inb(VGA_DAC + 3) & VGA_PMSK; - -#if PCVT_WAITRETRACE - wait_retrace(); -#endif /* PCVT_WAITRETRACE */ - - val->b = inb(VGA_DAC + 3) & VGA_PMSK; - } - -#if PCVT_PALFLICKER - vga_screen_on(); -#endif /* PCVT_PALFLICKER */ - -} - -/*---------------------------------------------------------------------------* - * - * update asynchronous: cursor, cursor pos displ, sys load, keyb scan - * - *---------------------------------------------------------------------------*/ -void -async_update() -{ - static int lastadr = 0; - static int lastpos = 0; - - /* first check if update is possible */ - - if(vsp->vt_status & VT_GRAFX) - return; - - if(chargen_access) /* does someone load characters? */ - return; /* yes, do not update anything */ - -#if PCVT_SCREENSAVER - if(reset_screen_saver) - { - pcvt_scrnsv_reset(); /* yes, do it */ - reset_screen_saver = 0; /* re-init */ - } - else if(scrnsv_active) /* is the screen not blanked? */ - { - return; /* do not update anything */ - } -#endif /* PCVT_SCREENSAVER */ - - /*-------------------------------------------------------------------*/ - /* this takes place on EVERY virtual screen (if not in X mode etc...)*/ - /*-------------------------------------------------------------------*/ - - if (cursor_pos_valid) - { - if (lastadr != (vsp->Crtat - Crtat)) - { - lastadr = vsp->Crtat - Crtat; - outb(addr_6845, CRTC_STARTADRH); /* high register */ - outb(addr_6845+1, ((lastadr) >> 8)); - outb(addr_6845, CRTC_STARTADRL); /* low register */ - outb(addr_6845+1, (lastadr)); - } - - if (lastpos != (lastadr + vsp->cur_offset)) - { - lastpos = lastadr + vsp->cur_offset; - outb(addr_6845, CRTC_CURSORH); /* high register */ - outb(addr_6845+1, ((lastpos) >> 8)); - outb(addr_6845, CRTC_CURSORL); /* low register */ - outb(addr_6845+1, (lastpos)); - } - } - - /*-------------------------------------------------------------------*/ - /* this takes place ONLY on screen 0 if in HP mode, labels on, !X */ - /*-------------------------------------------------------------------*/ - - /* additional processing for HP necessary ? */ - - if((vs[0].vt_pure_mode == M_HPVT) && (vs[0].labels_on)) - { - static volatile u_char buffer[] = - "System Load: 1min: 0.00 5min: 0.00 15min: 0.00"; - register int tmp, i; -#if PCVT_SHOWKEYS - extern u_char rawkeybuf[80]; - - if(keyboard_show) - { - for(i = 0; i < 80; i++) - { - *((vs[0].Crtat+((vs[0].screen_rows+2) - * vs[0].maxcol))+i) = - user_attr | rawkeybuf[i]; - } - } - else - { -#endif /* PCVT_SHOWKEYS */ - - /* display load averages in last line (taken from tty.c) */ - i = 18; -#ifdef NEW_AVERUNNABLE - tmp = (averunnable.ldavg[0] * 100 + FSCALE / 2) - >> FSHIFT; -#else - tmp = (averunnable[0] * 100 + FSCALE / 2) >> FSHIFT; -#endif - - buffer[i++] = - ((((tmp/100)/10) == 0) ? - ' ' : - ((tmp/100)/10) + '0'); - buffer[i++] = ((tmp/100)%10) + '0'; - buffer[i++] = '.'; - buffer[i++] = ((tmp%100)/10) + '0'; - buffer[i++] = ((tmp%100)%10) + '0'; - i += 6; -#ifdef NEW_AVERUNNABLE - tmp = (averunnable.ldavg[1] * 100 + FSCALE / 2) - >> FSHIFT; -#else - tmp = (averunnable[1] * 100 + FSCALE / 2) >> FSHIFT; -#endif - buffer[i++] = ((((tmp/100)/10) == 0) ? - ' ' : - ((tmp/100)/10) + '0'); - buffer[i++] = ((tmp/100)%10) + '0'; - buffer[i++] = '.'; - buffer[i++] = ((tmp%100)/10) + '0'; - buffer[i++] = ((tmp%100)%10) + '0'; - i += 7; -#ifdef NEW_AVERUNNABLE - tmp = (averunnable.ldavg[2] * 100 + FSCALE / 2) - >> FSHIFT; -#else - tmp = (averunnable[2] * 100 + FSCALE / 2) >> FSHIFT; -#endif - buffer[i++] = ((((tmp/100)/10) == 0) ? - ' ' : - ((tmp/100)/10) + '0'); - buffer[i++] = ((tmp/100)%10) + '0'; - buffer[i++] = '.'; - buffer[i++] = ((tmp%100)/10) + '0'; - buffer[i++] = ((tmp%100)%10) + '0'; - buffer[i] = '\0'; - - for(i = 0; buffer[i]; i++) - { - *((vs[0].Crtat + - ((vs[0].screen_rows + 2) * vs[0].maxcol) - ) + i - ) = user_attr | buffer[i]; - } - -#if PCVT_SHOWKEYS - for(; i < 77; i++) - { - *((vs[0].Crtat + - ((vs[0].screen_rows + 2) * vs[0].maxcol) - ) + i - ) = user_attr | ' '; - } - - } -#endif /* PCVT_SHOWKEYS */ - } - - /*-------------------------------------------------------------------*/ - /* this takes place on EVERY screen which is in HP mode, labels on,!X*/ - /*-------------------------------------------------------------------*/ - - if((vsp->vt_pure_mode == M_HPVT) && (vsp->labels_on)) - { - register int col = vsp->col+1; - register u_short *p = vsp->Crtat + - (vsp->screen_rows * vsp->maxcol); - - /* update column display between labels */ - - if(vsp->maxcol == SCR_COL132) - { - p += (SCR_COL132 - SCR_COL80)/2; - - if(col >= 100) - { - *(p + LABEL_COLU) = user_attr | '1'; - col -= 100; - } - else - { - *(p + LABEL_COLU) = user_attr | '0'; - } - } - *(p + LABEL_COLH) = user_attr | ((col/10) + '0'); - *(p + LABEL_COLL) = user_attr | ((col%10) + '0'); - - /* update row display between labels */ - - *(p + LABEL_ROWH) = (user_attr | (((vsp->row+1)/10) + '0')); - *(p + LABEL_ROWL) = (user_attr | (((vsp->row+1)%10) + '0')); - } -} - -/*---------------------------------------------------------------------------* - * set character set for virtual screen - *---------------------------------------------------------------------------*/ -void -set_charset(struct video_state *svsp, int curvgacs) -{ - static int sizetab[] = { 25, 28, 35, 40, 43, 50 }; - int oldsize, oldrows, newsize, newrows; - - if((curvgacs < 0) || (curvgacs > (NVGAFONTS-1))) - return; - - svsp->vga_charset = curvgacs; - - select_vga_charset(curvgacs); - - oldsize = svsp->screen_rowsize; - oldrows = svsp->screen_rows; - newsize = sizetab[(vgacs[curvgacs].screen_size)]; - newrows = newsize; - if (svsp->vt_pure_mode == M_HPVT) - newrows -= 3; - if (newrows == 25 && svsp->force24) - newrows = 24; - if (newrows < oldrows) { - int nscroll = svsp->row + 1 - newrows; - - if (svsp->row >= oldrows) /* Sanity check */ - nscroll = oldrows - newrows; - if (nscroll > 0) { - /* Scroll up */ - bcopy (svsp->Crtat + nscroll * svsp->maxcol, - svsp->Crtat, - newrows * svsp->maxcol * CHR); - svsp->row -= nscroll; - svsp->cur_offset -= nscroll * svsp->maxcol; - } - if (newrows < newsize) - fillw(user_attr | ' ', - svsp->Crtat + newrows * svsp->maxcol, - (newsize - newrows) * svsp->maxcol); - } else if (oldrows < newsize) - fillw(user_attr | ' ', - svsp->Crtat + oldrows * svsp->maxcol, - (newsize - oldrows) * svsp->maxcol); - - svsp->screen_rowsize = newsize; - svsp->screen_rows = newrows; - - /* Clip scrolling region */ - if(svsp->scrr_end > svsp->screen_rows - 1) - svsp->scrr_end = svsp->screen_rows - 1; - svsp->scrr_len = svsp->scrr_end - svsp->scrr_beg + 1; - - /* Clip cursor pos */ - - if(svsp->cur_offset > (svsp->scrr_len * svsp->maxcol)) - svsp->cur_offset = (svsp->scrr_len * svsp->maxcol) + svsp->col; -} - -/*---------------------------------------------------------------------------* - * select a vga character set - *---------------------------------------------------------------------------*/ -void -select_vga_charset(int vga_charset) -{ - int first, second; - int fflag = 0; - int sflag = 0; - u_char cmap = 0; - - static u_char cmaptaba[] = - {0x00, 0x01, 0x02, 0x03, 0x10, 0x11, 0x12, 0x13}; - - static u_char cmaptabb[] = - {0x00, 0x04, 0x08, 0x0c, 0x20, 0x24, 0x28, 0x2c}; - - if((adaptor_type != EGA_ADAPTOR) && (adaptor_type != VGA_ADAPTOR)) - return; - - if((vga_charset < 0) || (vga_charset >= totalfonts)) - return; - - if(!vgacs[vga_charset].loaded) - return; - - /*-------------------------------------------------------------- - find the first and second charset of a given resolution. - the first is used for lower 256 and the second (if any) is - used for the upper 256 entries of a complete 512 entry ega/ - vga charset. - --------------------------------------------------------------*/ - - for(first = 0; first < totalfonts; first++) - { - if(!vgacs[first].loaded) - continue; - if(vgacs[first].screen_size != vgacs[vga_charset].screen_size) - continue; - if(vgacs[first].char_scanlines != - vgacs[vga_charset].char_scanlines) - continue; - if(vgacs[first].scr_scanlines != - vgacs[vga_charset].scr_scanlines) - continue; - fflag = 1; - break; - } - - if(fflag != 1) - return; - - for(second = first+1; second < totalfonts; second++) - { - if(!vgacs[second].loaded) - continue; - if(vgacs[second].screen_size != vgacs[vga_charset].screen_size) - continue; - if(vgacs[second].char_scanlines != - vgacs[vga_charset].char_scanlines) - continue; - if(vgacs[second].scr_scanlines != - vgacs[vga_charset].scr_scanlines) - continue; - sflag = 1; - break; - } - - cmap = cmaptaba[first]; - if(sflag) - { - cmap |= cmaptabb[second]; - vgacs[first].secondloaded = second; - } - else - { - vgacs[first].secondloaded = 0; /*cs 0 can never become a 2nd!*/ - } - - if(vsp->wd132col) - { - cmap = (vga_charset & 0x07); - cmap |= 0x10; - } - - outb(TS_INDEX, TS_FONTSEL); /* character map select register */ - outb(TS_DATA, cmap); /* new char map */ - - outb(addr_6845, CRTC_MAXROW); /* max scan line reg */ - outb(addr_6845+1, - vgacs[first].char_scanlines); /* scanlines/char */ - - outb(addr_6845, CRTC_VDE); /* vert display enable end */ - outb(addr_6845+1, - vgacs[first].scr_scanlines); /* low byte of scr scanlines */ - - if((color == 0) && (adaptor_type == VGA_ADAPTOR)) - { - outb(addr_6845, CRTC_ULOC); /* underline location reg */ - outb(addr_6845+1, (vgacs[first].char_scanlines & 0x1F)); - } -} - -/*---------------------------------------------------------------------------* - * switch vga-card to load a character set - *---------------------------------------------------------------------------*/ -static void -setchargen(void) -{ - chargen_access = 1; /* flag we are accessing the chargen ram */ - - /* program sequencer to access character generator */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, TS_WRPLMASK); - outb(TS_DATA, 0x04); /* write to map 2 */ - - outb(TS_INDEX, TS_MEMMODE); - outb(TS_DATA, 0x07); /* sequential addressing */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - - /* program graphics controller to access character generator */ - - outb(GDC_INDEX, GDC_RDPLANESEL); - outb(GDC_DATA, 0x02); /* select map 2 for cpu reads */ - - outb(GDC_INDEX, GDC_MODE); - outb(GDC_DATA, 0x00); /* disable odd-even addressing */ - - outb(GDC_INDEX, GDC_MISC); - outb(GDC_DATA, 0x00); /* map starts at 0xA000 */ -} - -/*---------------------------------------------------------------------------* - * switch vga-card to load a character set to plane 3 - *---------------------------------------------------------------------------*/ -static void -setchargen3(void) -{ - chargen_access = 1; /* flag we are accessing the chargen ram */ - - /* program sequencer to access character generator */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, TS_WRPLMASK); - outb(TS_DATA, 0x08); /* write to map 3 */ - - outb(TS_INDEX, TS_MEMMODE); - outb(TS_DATA, 0x07); /* sequential addressing */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - - /* program graphics controller to access character generator */ - - outb(GDC_INDEX, GDC_RDPLANESEL); - outb(GDC_DATA, 0x03); /* select map 3 for cpu reads */ - - outb(GDC_INDEX, GDC_MODE); - outb(GDC_DATA, 0x00); /* disable odd-even addressing */ - - outb(GDC_INDEX, GDC_MISC); - outb(GDC_DATA, 0x00); /* map starts at 0xA000 */ -} - -/*---------------------------------------------------------------------------* - * switch back vga-card to normal operation - *---------------------------------------------------------------------------*/ -static void -resetchargen(void) -{ - /* program sequencer to access video ram */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, TS_WRPLMASK); - outb(TS_DATA, 0x03); /* write to map 0 & 1 */ - - outb(TS_INDEX, TS_MEMMODE); - outb(TS_DATA, 0x03); /* odd-even addressing */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ - - /* program graphics controller to access character generator */ - - outb(GDC_INDEX, GDC_RDPLANESEL); - outb(GDC_DATA, 0x00); /* select map 0 for cpu reads */ - - outb(GDC_INDEX, GDC_MODE); - outb(GDC_DATA, 0x10); /* enable odd-even addressing */ - - outb(GDC_INDEX, GDC_MISC); - if(color) - outb(GDC_DATA, 0x0e); /* map starts at 0xb800 */ - else - outb(GDC_DATA, 0x0a); /* map starts at 0xb000 */ - - chargen_access = 0; /* flag we are NOT accessing the chargen ram */ -} - -#if PCVT_WAITRETRACE -/*---------------------------------------------------------------------------* - * wait for being in a retrace time window - * NOTE: this is __VERY__ bad programming practice in this environment !! - *---------------------------------------------------------------------------*/ - -static void -wait_retrace(void) -{ - if(color) - { - while(!(inb(GN_INPSTAT1C) & 0x01)) - ; - } - else - { - while(!(inb(GN_INPSTAT1M) & 0x01)) - ; - } -} - -#endif /* PCVT_WAITRETRACE */ - -/*---------------------------------------------------------------------------* - * switch screen off (VGA only) - *---------------------------------------------------------------------------*/ -void -vga_screen_off(void) -{ - unsigned char old; - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, TS_MODE); /* clocking mode reg */ - old = inb(TS_DATA); /* get current value */ - - outb(TS_INDEX, TS_MODE); /* clocking mode reg */ - outb(TS_DATA, (old | 0x20)); /* screen off bit on */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ -} - -/*---------------------------------------------------------------------------* - * switch screen back on (VGA only) - *---------------------------------------------------------------------------*/ -void -vga_screen_on(void) -{ - unsigned char old; - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); /* synchronous reset */ - - outb(TS_INDEX, TS_MODE); /* clocking mode reg */ - old = inb(TS_DATA); /* get current value */ - - outb(TS_INDEX, TS_MODE); /* clocking mode reg */ - outb(TS_DATA, (old & ~0x20)); /* screen off bit off */ - - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); /* clear synchronous reset */ -} - -/*---------------------------------------------------------------------------* - * compute character set base address (in kernel map) - *---------------------------------------------------------------------------*/ -static unsigned char * -compute_charset_base(unsigned fontset) -{ - unsigned char *d = (unsigned char *)Crtat; - - static int charset_offset[8] = { 0x0000, 0x4000, 0x8000, 0xC000, - 0x2000, 0x6000, 0xA000, 0xE000 }; - - static int charsetw_offset[8] = { 0x0000, 0x2000, 0x4000, 0x6000, - 0x8000, 0xA000, 0xC000, 0xE000 }; - - switch(adaptor_type) - { - case EGA_ADAPTOR: - fontset = (fontset > 3) ? 3 : fontset; - break; - - case VGA_ADAPTOR: - fontset = (fontset > 7) ? 7 : fontset; - break; - - default: - return 0; - } - - if(color) - d -= (0xB8000 - 0xA0000); /* Point to 0xA0000 */ - else - d -= (0xB0000 - 0xA0000); /* Point to 0xA0000 */ - - if(vsp->wd132col) - d += charsetw_offset[fontset]; /* Load into Character set n */ - else - d += charset_offset[fontset]; /* Load into Character set n */ - - return d; -} - -/*---------------------------------------------------------------------------* - * load a char into ega/vga character generator ram - *---------------------------------------------------------------------------*/ -void -loadchar(int fontset, int character, int char_scanlines, u_char *char_table) -{ - unsigned char *d; - -#if PCVT_BACKUP_FONTS - unsigned char *bak; -#endif /* PCVT_BACKUP_FONTS */ - - int j, k; - - if((d = compute_charset_base(fontset)) == 0) - return; - - d += (character * 32); /* 32 bytes per character */ - - if(vsp->wd132col && - (fontset == 1||fontset == 3||fontset == 5||fontset == 7)) - setchargen3(); /* access chargen ram */ - else - setchargen(); /* access chargen ram */ - - for(j = k = 0; j < char_scanlines; j++) /* x bit high characters */ - { - *d = char_table[k]; - d++; - k++; - } - for(; j < 32; j++) /* Up to 32 bytes per character image*/ - { - *d = 0x00; - d++; - } - - resetchargen(); /* access video ram */ - -#if PCVT_BACKUP_FONTS - if(saved_charsets[fontset] == 0) - saved_charsets[fontset] = - (u_char *)malloc(32 * 256, M_DEVBUF, M_WAITOK); - - if((bak = saved_charsets[fontset])) - { - /* make a backup copy of this char */ - bak += (character * 32); - bzero(bak, 32); - bcopy(char_table, bak, char_scanlines); - } -#ifdef DIAGNOSTIC - else - panic("pcvt loadchar: no backup buffer"); -#endif /* DIAGNOSTIC */ - -#endif /* PCVT_BACKUP_FONTS */ - -} - -/*---------------------------------------------------------------------------* - * save/restore character set n to addr b - *---------------------------------------------------------------------------*/ -#if !PCVT_BACKUP_FONTS - -void -vga_move_charset(unsigned n, unsigned char *b, int save_it) -{ - unsigned char *d = compute_charset_base(n); - -#ifdef DIAGNOSTIC - if(d == 0) - panic("vga_move_charset: wrong adaptor"); -#endif - - if(vsp->wd132col && (n == 1||n == 3||n == 5||n == 7)) - { - setchargen3(); - d -= 0x2000; - } - else - { - setchargen(); - } - - /* PLEASE, leave the following alone using bcopyb, as several */ - /* chipsets have problems if their memory is accessed with 32 */ - /* or 16 bits wide, don't change this to using bcopy for speed! */ - - if(save_it) - bcopyb(d, b, 256 /* chars */ * 32 /* bytes per char */); - else - bcopyb(b, d, 256 /* chars */ * 32 /* bytes per char */); - - resetchargen(); -} - -#else /* PCVT_BACKUP_FONTS */ - -/* since there are always backed up copies, we do not save anything here */ -/* parameter "b" is totally ignored */ - -void -vga_move_charset(unsigned n, unsigned char *b, int save_it) -{ - unsigned char *d = compute_charset_base(n); - - if(save_it) - return; - - if(saved_charsets[n] == 0) -#ifdef DIAGNOSTIC - panic("pcvt: restoring unbuffered charset"); -#else - return; -#endif - -#ifdef DIAGNOSTIC - if(d == 0) - panic("vga_move_charset: wrong adaptor"); -#endif - - if(vsp->wd132col && (n == 1||n == 3||n == 5||n == 7)) - { - setchargen3(); - d -= 0x2000; - } - else - { - setchargen(); - } - - /* PLEASE, leave the following alone using bcopyb, as several */ - /* chipsets have problems if their memory is accessed with 32 */ - /* or 16 bits wide, don't change this to using bcopy for speed! */ - - bcopyb(saved_charsets[n], d, - 256 /* chars */ * 32 /* bytes per char */); - - resetchargen(); -} - -#endif /* PCVT_BACKUP_FONTS */ - -/*---------------------------------------------------------------------------* - * test if it is a vga - *---------------------------------------------------------------------------*/ -int -vga_test(void) -{ - u_char old, new, check; - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - old = inb(addr_6845+1); /* get current value */ - - new = old | CURSOR_ON_BIT; /* set cursor on by setting bit 5 on */ - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1,new); /* cursor should be on now */ - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - check = inb(addr_6845+1); /* get current value */ - - if(check != new) - { - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1,old); /* failsafe */ - return(0); /* must be ega */ - } - - new = old & ~CURSOR_ON_BIT; /* turn cursor off by clearing bit 5 */ - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1,new); /* cursor should be off now */ - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - check = inb(addr_6845+1); /* get current value */ - - if(check != new) - { - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1,old); /* failsafe */ - return(0); /* must be ega */ - } - - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1,old); /* failsafe */ - - return(1); /* vga */ -} - -/*---------------------------------------------------------------------------* - * convert upper/lower sixel font array to vga font array - *---------------------------------------------------------------------------*/ -void -sixel_vga(struct sixels *sixelp, u_char *vgachar) -{ - register int i, j; - register int shift; - register u_char mask; - - for(j = 0; j < 16; j++) - vgachar[j] = 0; - - mask = 0x01; - for(j = 0; j < 6; j++) - { - for(i = 0, shift = 7; i < 8; i++, shift--) - vgachar[j] |= ((((sixelp->upper[i]) & mask) >> j) - << shift); - mask <<= 1; - } - - mask = 0x01; - for(j = 0; j < 4; j++) - { - for(i = 0, shift = 7; i < 8; i++, shift--) - vgachar[j+6] |= ((((sixelp->lower[i]) & mask) >>j) - << shift); - mask <<= 1; - } -} - -/*---------------------------------------------------------------------------* - * Expand 8x10 EGA/VGA characters to 8x16 EGA/VGA characters - *---------------------------------------------------------------------------*/ -void -vga10_vga16(u_char *invga, u_char *outvga) -{ - register int i,j; - - /* - * Keep the top and bottom scanlines the same and double every scan - * line in between. - */ - - outvga[0] = invga[0]; - outvga[1] = invga[1]; - outvga[14] = invga[8]; - outvga[15] = invga[9]; - - for(i = j = 2;i < 8 && j < 14;i++,j += 2) - { - outvga[j] = invga[i]; - outvga[j+1] = invga[i]; - } -} - -/*---------------------------------------------------------------------------* - * Expand 8x10 EGA/VGA characters to 8x14 EGA/VGA characters - *---------------------------------------------------------------------------*/ -void -vga10_vga14(u_char *invga, u_char *outvga) -{ - register int i; - - /* - * Double the top two and bottom two scanlines and copy everything - * in between. - */ - - outvga[0] = invga[0]; - outvga[1] = invga[0]; - outvga[2] = invga[1]; - outvga[3] = invga[1]; - outvga[10] = invga[8]; - outvga[11] = invga[8]; - outvga[12] = invga[9]; - outvga[13] = invga[9]; - - for(i = 2;i < 8;i++) - outvga[i+2] = invga[i]; -} - -/*---------------------------------------------------------------------------* - * Expand 8x10 EGA/VGA characters to 8x10 EGA/VGA characters - *---------------------------------------------------------------------------*/ -void -vga10_vga10(u_char *invga, u_char *outvga) -{ - register int i; - - for(i = 0;i < 10;i++) - outvga[i] = invga[i]; -} - -/*---------------------------------------------------------------------------* - * Contract 8x10 EGA/VGA characters to 8x8 EGA/VGA characters - *---------------------------------------------------------------------------*/ -void -vga10_vga8(u_char *invga, u_char *outvga) -{ - /* Skip scanlines 3 and 7 */ - - outvga[0] = invga[0]; - outvga[1] = invga[1]; - outvga[2] = invga[2]; - outvga[3] = invga[4]; - outvga[4] = invga[5]; - outvga[5] = invga[6]; - outvga[6] = invga[8]; - outvga[7] = invga[9]; -} - -/*---------------------------------------------------------------------------* - * force a vga card to behave like an ega for debugging - *---------------------------------------------------------------------------*/ -#if FORCE_EGA -void -force_ega(void) -{ - unsigned char vgareg; - - if(adaptor_type == VGA_ADAPTOR) - { - adaptor_type = EGA_ADAPTOR; - totalfonts = 4; - vgareg = inb(GN_MISCOUTR); /* Miscellaneous Output Register */ - vgareg |= 128; /* Set 350 scanline mode */ - vgareg &= ~64; - outb(GN_MISCOUTW,vgareg); - } -} -#endif /* FORCE_EGA */ - -/*---------------------------------------------------------------------------* - * disconnect attribute bit 3 from generating intensity - * (and use it for a second character set !) - *---------------------------------------------------------------------------*/ -void -set_2ndcharset(void) -{ - if(color) /* prepare to access index register! */ - inb(GN_INPSTAT1C); - else - inb(GN_INPSTAT1M); - - /* select color plane enable reg, caution: set ATC access bit ! */ - - outb(ATC_INDEX, (ATC_COLPLEN | ATC_ACCESS)); - outb(ATC_DATAW, 0x07); /* disable plane 3 */ -} - -#if PCVT_SCREENSAVER -#if PCVT_PRETTYSCRNS - -static struct callout scrnsv_blink_ch = CALLOUT_INITIALIZER; - -/*---------------------------------------------------------------------------* - * produce some kinda random number, had a look into the system library... - *---------------------------------------------------------------------------*/ -static u_short -getrand(void) -{ - extern struct timeval time; /* time-of-day register */ - - static unsigned long seed = 1; - register u_short res = (u_short)seed; - seed = seed * 1103515245L + time.tv_sec; - return res; -} - -/*---------------------------------------------------------------------------* - * produce "nice" screensaving .... - *---------------------------------------------------------------------------*/ -static void -scrnsv_blink(void) -{ - static struct rgb blink_rgb[8] = - { - {63, 63, 63}, /* white */ - {0, 63, 42}, /* pale green */ - {63, 63, 0}, /* yellow */ - {63, 21, 63}, /* violet */ - {42, 63, 0}, /* yellow-green */ - {63, 42, 0}, /* amber */ - {63, 42, 42}, /* rose */ - {21, 42, 42} /* cyan */ - }; - register u_short r = getrand(); - unsigned pos = (r % (scrnsv_size / 2)); - - *scrnsv_current = /* (0 << 8) + */ ' '; - scrnsv_current = vsp->Crtat + pos; - *scrnsv_current = (7 /* LIGHTGRAY */ << 8) + '*'; - if(adaptor_type == VGA_ADAPTOR) - vgapaletteio(7 /* LIGHTGRAY */, &blink_rgb[(r >> 4) & 7], 1); - callout_reset(&scrnsv_blink_ch, hz, (TIMEOUT_FUNC_T)scrnsv_blink, NULL); -} - -#endif /* PCVT_PRETTYSCRNS */ - -/*---------------------------------------------------------------------------* - * set timeout time - *---------------------------------------------------------------------------*/ -void -pcvt_set_scrnsv_tmo(int timeout) -{ - int x = splhigh(); - - if(scrnsv_timeout) - callout_stop(&scrnsv_timedout_ch); - - scrnsv_timeout = timeout; - pcvt_scrnsv_reset(); /* sanity */ - splx(x); - if(timeout == 0 && savedscreen) - { - /* release buffer when screen saver turned off */ - free(savedscreen, M_TEMP); - savedscreen = (u_short *)0; - } -} - -/*---------------------------------------------------------------------------* - * we were timed out - *---------------------------------------------------------------------------*/ -static void -scrnsv_timedout(void *arg) -{ - /* this function is called by timeout() */ - /* raise priority to avoid conflicts with kbd intr */ - int x = spltty(); - - /* - * due to some undefined problems with video adaptor RAM - * access timing, the following has been splitted into - * two pieces called subsequently with a time difference - * of 100 millisec - */ - - if(++scrnsv_active == 1) - { - register size_t s; - /* - * first, allocate a buffer - * do only if none allocated yet or another size required - * this reduces malloc() overhead by avoiding successive - * calls to malloc() and free() if they would have requested - * the same buffer - * - * XXX This is inherited from old days where no buffering - * happened at all. Meanwhile we should use the standard - * screen buffer instead. Any volunteers? :-) [At least, - * this code proved to work...] - */ - - s = sizeof(u_short) * vsp->screen_rowsize * vsp->maxcol; - - if(savedscreen == (u_short *)0 || s != scrnsv_size) - { - /* really need to allocate */ - if(savedscreen) - free(savedscreen, M_TEMP); - scrnsv_size = s; - if((savedscreen = - (u_short *)malloc(s, M_TEMP, M_NOWAIT)) - == (u_short *)0) - { - /* - * didn't get the buffer memory, - * turn off screen saver - */ - scrnsv_timeout = scrnsv_active = 0; - splx(x); - return; - } - } - /* save current screen */ - bcopy(vsp->Crtat, savedscreen, scrnsv_size); - - /* on VGA's, make sure palette is set to blank screen */ - if(adaptor_type == VGA_ADAPTOR) - { - struct rgb black = {0, 0, 0}; - vgapaletteio(0 /* BLACK */, &black, 1); - } - /* prepare for next time... */ - callout_reset(&scrnsv_timedout_ch, hz / 10, - (TIMEOUT_FUNC_T)scrnsv_timedout, NULL); - } - else - { - /* second call, now blank the screen */ - /* fill screen with blanks */ - fillw(/* (BLACK<<8) + */ ' ', vsp->Crtat, scrnsv_size / 2); - -#if PCVT_PRETTYSCRNS - scrnsv_current = vsp->Crtat; - callout_reset(scrnsv_blink_ch, hz, - (TIMEOUT_FUNC_T)scrnsv_blink, NULL); -#endif /* PCVT_PRETTYSCRNS */ - - sw_cursor(0); /* cursor off on mda/cga */ - } - splx(x); -} - -/*---------------------------------------------------------------------------* - * interface to screensaver "subsystem" - *---------------------------------------------------------------------------*/ -void -pcvt_scrnsv_reset(void) -{ - /* - * to save lotta time with superfluous timeout()/untimeout() calls - * when having massive output operations, we remember the last - * second of kernel timer we've rescheduled scrnsv_timedout() - */ - static long last_schedule = 0L; - register int x = splhigh(); - int reschedule = 0; - - if((scrnsv_active == 1 || scrnsv_timeout) && - last_schedule != time.tv_sec) - { - last_schedule = time.tv_sec; - reschedule = 1; - callout_stop(&scrnsv_timedout_ch); - } - if(scrnsv_active) - { - -#if PCVT_PRETTYSCRNS - if(scrnsv_active > 1) - callout_stop(&scrnsv_blink_ch); -#endif /* PCVT_PRETTYSCRNS */ - - bcopy(savedscreen, vsp->Crtat, scrnsv_size); - if(adaptor_type == VGA_ADAPTOR) - { - /* back up VGA palette info */ - vgapaletteio(0 /* BLACK */, &vsp->palette[0], 1); - -#if PCVT_PRETTYSCRNS - vgapaletteio(7 /* LIGHTGRAY */, &vsp->palette[7], 1); -#endif /* PCVT_PRETTYSCRNS */ - - } - scrnsv_active = 0; - - if(vsp->cursor_on) - sw_cursor(1); /* cursor on */ - } - - if(reschedule) - { - /* mark next timeout */ - callout_reset(&scrnsv_timedout_ch, scrnsv_timeout * hz, - (TIMEOUT_FUNC_T)scrnsv_timedout, NULL); - } - splx(x); -} - -#endif /* PCVT_SCREENSAVER */ - -/*---------------------------------------------------------------------------* - * switch cursor on/off - *---------------------------------------------------------------------------*/ -void -sw_cursor(int onoff) -{ - if(adaptor_type == EGA_ADAPTOR) - { - int start, end; - if(onoff) - { - start = vsp->cursor_start; - end = vsp->cursor_end; - } - else - { - int cs = vs[current_video_screen].vga_charset; - - cs = (cs < 0) ? 0 : ((cs < totalfonts) ? - cs : totalfonts-1); - - start = (vgacs[cs].char_scanlines & 0x1F) + 1; - end = 0; - } - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - outb(addr_6845+1, start); - outb(addr_6845,CRTC_CUREND); /* cursor end reg */ - outb(addr_6845+1, end); - } - else /* mda, cga, vga */ - { - outb(addr_6845,CRTC_CURSTART); /* cursor start reg */ - if(onoff) - outb(addr_6845+1, vsp->cursor_start); - else - outb(addr_6845+1, CURSOR_ON_BIT); - } -} - -/*---------------------------------------------------------------------------* - * cold init support, if a mono monitor is attached to a - * vga or ega, it comes up with a mda emulation. switch - * board to generic ega/vga mode in this case. - *---------------------------------------------------------------------------*/ -void -mda2egaorvga(void) -{ - /* - * program sequencer to access - * video ram - */ - - /* synchronous reset */ - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x01); - - /* write to map 0 & 1 */ - outb(TS_INDEX, TS_WRPLMASK); - outb(TS_DATA, 0x03); - - /* odd-even addressing */ - outb(TS_INDEX, TS_MEMMODE); - outb(TS_DATA, 0x03); - - /* clear synchronous reset */ - outb(TS_INDEX, TS_SYNCRESET); - outb(TS_DATA, 0x03); - - /* - * program graphics controller - * to access character - * generator - */ - - /* select map 0 for cpu reads */ - outb(GDC_INDEX, GDC_RDPLANESEL); - outb(GDC_DATA, 0x00); - - /* enable odd-even addressing */ - outb(GDC_INDEX, GDC_MODE); - outb(GDC_DATA, 0x10); - - /* map starts at 0xb000 */ - outb(GDC_INDEX, GDC_MISC); - outb(GDC_DATA, 0x0a); -} - -/* ------------------------- E O F ------------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/pcvt_tbl.h b/sys/arch/i386/isa/pcvt/pcvt_tbl.h deleted file mode 100644 index 3635c19bab30..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_tbl.h +++ /dev/null @@ -1,476 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis. - * - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_tbl.h, 3.32, Last Edit-Date: [Tue Oct 3 11:19:49 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_tbl.h VT220 Driver Character Set Conversion Tables - * ------------------------------------------------------------ - * -hm splitting off pccons_out.c - * -hm default tables for pure mda/hcg/cga - * -hm ---------------- Release 3.32 ----------------------- - * - * in pcvt_out.c, hooks are provided for the following charactersets: - * - * HAVECS_BRITISH - * HAVECS_ASCII - * HAVECS_FINNISH - * HAVECS_NORWEGIANDANISH - * HAVECS_SWEDISH - * HAVECS_GERMAN - * HAVECS_FRENCHCANADA - * HAVECS_FRENCH - * HAVECS_ITALIAN - * HAVECS_SPANISH - * HAVECS_SPECIAL - * HAVECS_ALTERNATEROM1 - * HAVECS_ALTERNATEROM2 - * HAVECS_ROMAN8 - * HAVECS_DUTCH - * HAVECS_SUPPLEMENTAL - * HAVECS_SWISS - * HAVECS_TECHNICAL - * HAVECS_ISOLATIN - * - * to add support for a new charcterset, you have to provide the - * table named "cs_",define the according "HAVECS_" - * and recompile everything. ref: pcvt_out.c, vt_designate() - * - *---------------------------------------------------------------------------*/ - -/*===========================================================================* - * DEFAULT TABLES FOR MDA/HCG/CGA - *===========================================================================*/ - -/*---------------------------------------------------------------------------* - * ASCII Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSD_ASCII -u_short csd_ascii[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0x21 | CSL, 0x22 | CSL, 0x23 | CSL, -/* 24 */ 0x24 | CSL, 0x25 | CSL, 0x26 | CSL, 0x27 | CSL, -/* 28 */ 0x28 | CSL, 0x29 | CSL, 0x2A | CSL, 0x2B | CSL, -/* 2C */ 0x2C | CSL, 0x2D | CSL, 0x2E | CSL, 0x2F | CSL, - -/* 30 */ 0x30 | CSL, 0x31 | CSL, 0x32 | CSL, 0x33 | CSL, -/* 34 */ 0x34 | CSL, 0x35 | CSL, 0x36 | CSL, 0x37 | CSL, -/* 38 */ 0x38 | CSL, 0x39 | CSL, 0x3A | CSL, 0x3B | CSL, -/* 3C */ 0x3C | CSL, 0x3D | CSL, 0x3E | CSL, 0x3F | CSL, - -/* 40 */ 0x40 | CSL, 0x41 | CSL, 0x42 | CSL, 0x43 | CSL, -/* 44 */ 0x44 | CSL, 0x45 | CSL, 0x46 | CSL, 0x47 | CSL, -/* 48 */ 0x48 | CSL, 0x49 | CSL, 0x4A | CSL, 0x4B | CSL, -/* 4C */ 0x4C | CSL, 0x4D | CSL, 0x4E | CSL, 0x4F | CSL, - -/* 50 */ 0x50 | CSL, 0x51 | CSL, 0x52 | CSL, 0x53 | CSL, -/* 54 */ 0x54 | CSL, 0x55 | CSL, 0x56 | CSL, 0x57 | CSL, -/* 58 */ 0x58 | CSL, 0x59 | CSL, 0x5A | CSL, 0x5B | CSL, -/* 5C */ 0x5C | CSL, 0x5D | CSL, 0x5E | CSL, 0x5F | CSL, - -/* 60 */ 0x60 | CSL, 0x61 | CSL, 0x62 | CSL, 0x63 | CSL, -/* 64 */ 0x64 | CSL, 0x65 | CSL, 0x66 | CSL, 0x67 | CSL, -/* 68 */ 0x68 | CSL, 0x69 | CSL, 0x6A | CSL, 0x6B | CSL, -/* 6C */ 0x6C | CSL, 0x6D | CSL, 0x6E | CSL, 0x6F | CSL, - -/* 70 */ 0x70 | CSL, 0x71 | CSL, 0x72 | CSL, 0x73 | CSL, -/* 74 */ 0x74 | CSL, 0x75 | CSL, 0x76 | CSL, 0x77 | CSL, -/* 78 */ 0x78 | CSL, 0x79 | CSL, 0x7A | CSL, 0x7B | CSL, -/* 7C */ 0x7C | CSL, 0x7D | CSL, 0x7E | CSL, 0x7F | CSL, -}; - -/*---------------------------------------------------------------------------* - * DEC Supplemental Graphic Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSD_SUPPLEMENTAL -u_short csd_supplemental[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0xAD | CSL, 0x9B | CSL, 0x9C | CSL, -/* 24 */ 0x20 | CSL, 0x9D | CSL, 0x20 | CSL, 0x20 | CSL, -/* 28 */ 0x20 | CSL, 0x20 | CSL, 0xA6 | CSL, 0xAE | CSL, -/* 2C */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, - -/* 30 */ 0xF8 | CSL, 0xF1 | CSL, 0xFD | CSL, 0x20 | CSL, -/* 34 */ 0x20 | CSL, 0xE6 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 38 */ 0x20 | CSL, 0x20 | CSL, 0xA7 | CSL, 0xAF | CSL, -/* 3C */ 0xAC | CSL, 0xAB | CSL, 0x20 | CSL, 0xA8 | CSL, - -/* 40 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 44 */ 0x8E | CSL, 0x8F | CSL, 0x92 | CSL, 0x80 | CSL, -/* 48 */ 0x20 | CSL, 0x90 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 4C */ 0x8D | CSL, 0xA1 | CSL, 0x8C | CSL, 0x8B | CSL, - -/* 50 */ 0x20 | CSL, 0xA5 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 54 */ 0x20 | CSL, 0x20 | CSL, 0x99 | CSL, 0x20 | CSL, -/* 58 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 5C */ 0x9A | CSL, 0x20 | CSL, 0x20 | CSL, 0xE1 | CSL, - -/* 60 */ 0x85 | CSL, 0xA0 | CSL, 0x83 | CSL, 0x20 | CSL, -/* 64 */ 0x84 | CSL, 0x86 | CSL, 0x91 | CSL, 0x87 | CSL, -/* 68 */ 0x8A | CSL, 0x82 | CSL, 0x88 | CSL, 0x89 | CSL, -/* 6C */ 0x8D | CSL, 0xA1 | CSL, 0x8C | CSL, 0x8B | CSL, - -/* 70 */ 0x20 | CSL, 0xA4 | CSL, 0x95 | CSL, 0xA2 | CSL, -/* 74 */ 0x93 | CSL, 0x20 | CSL, 0x94 | CSL, 0x20 | CSL, -/* 78 */ 0x20 | CSL, 0x97 | CSL, 0xA3 | CSL, 0x96 | CSL, -/* 7C */ 0x81 | CSL, 0x98 | CSL, 0x20 | CSL, 0x20 | CSL -}; - -/*---------------------------------------------------------------------------* - * DEC Special Graphic Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSD_SPECIAL -u_short csd_special[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0x21 | CSL, 0x22 | CSL, 0x23 | CSL, -/* 24 */ 0x24 | CSL, 0x25 | CSL, 0x26 | CSL, 0x27 | CSL, -/* 28 */ 0x28 | CSL, 0x29 | CSL, 0x2A | CSL, 0x2B | CSL, -/* 2C */ 0x2C | CSL, 0x2D | CSL, 0x2E | CSL, 0x2F | CSL, - -/* 30 */ 0x30 | CSL, 0x31 | CSL, 0x32 | CSL, 0x33 | CSL, -/* 34 */ 0x34 | CSL, 0x35 | CSL, 0x36 | CSL, 0x37 | CSL, -/* 38 */ 0x38 | CSL, 0x39 | CSL, 0x3A | CSL, 0x3B | CSL, -/* 3C */ 0x3C | CSL, 0x3D | CSL, 0x3E | CSL, 0x3F | CSL, - -/* 40 */ 0x40 | CSL, 0x41 | CSL, 0x42 | CSL, 0x43 | CSL, -/* 44 */ 0x44 | CSL, 0x45 | CSL, 0x46 | CSL, 0x47 | CSL, -/* 48 */ 0x48 | CSL, 0x49 | CSL, 0x4A | CSL, 0x4B | CSL, -/* 4C */ 0x4C | CSL, 0x4D | CSL, 0x4E | CSL, 0x4F | CSL, - -/* 50 */ 0x50 | CSL, 0x51 | CSL, 0x52 | CSL, 0x53 | CSL, -/* 54 */ 0x54 | CSL, 0x55 | CSL, 0x56 | CSL, 0x57 | CSL, -/* 58 */ 0x58 | CSL, 0x59 | CSL, 0x5A | CSL, 0x5B | CSL, -/* 5C */ 0x5C | CSL, 0x5D | CSL, 0x5E | CSL, 0x20 | CSL, - -/* 60 */ 0x20 | CSL, 0xB0 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 64 */ 0x20 | CSL, 0x20 | CSL, 0xF8 | CSL, 0xF1 | CSL, -/* 68 */ 0x20 | CSL, 0x20 | CSL, 0xD9 | CSL, 0xBF | CSL, -/* 6C */ 0xDA | CSL, 0xC0 | CSL, 0xC5 | CSL, 0x20 | CSL, - -/* 70 */ 0x20 | CSL, 0xC4 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 74 */ 0xC3 | CSL, 0xB4 | CSL, 0xC1 | CSL, 0xC2 | CSL, -/* 78 */ 0xB3 | CSL, 0xF3 | CSL, 0xF2 | CSL, 0xE3 | CSL, -/* 7C */ 0x20 | CSL, 0x9C | CSL, 0x20 | CSL, 0x20 | CSL -}; - -/*---------------------------------------------------------------------------* - * DEC Technical Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSD_TECHNICAL -u_short csd_technical[CSSIZE] = { -/* 20 */ 0xFE | CSH, 0xFB | CSL, 0xDA | CSL, 0xC4 | CSL, -/* 24 */ 0xF4 | CSL, 0xF5 | CSL, 0xB3 | CSL, 0xDA | CSL, -/* 28 */ 0xC0 | CSL, 0xBF | CSL, 0xD9 | CSL, 0x20 | CSL, -/* 2C */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, - -/* 30 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 34 */ 0x20 | CSL, 0xAA | CSL, 0xA9 | CSL, 0x3E | CSL, -/* 38 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 3C */ 0xF3 | CSL, 0x20 | CSL, 0xF2 | CSL, 0x20 | CSL, - -/* 40 */ 0x20 | CSL, 0x20 | CSL, 0xEC | CSL, 0xF6 | CSL, -/* 44 */ 0x20 | CSL, 0x20 | CSL, 0xE8 | CSL, 0xE2 | CSL, -/* 48 */ 0x20 | CSL, 0xF7 | CSL, 0xE9 | CSL, 0x78 | CSL, -/* 4C */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0xF0 | CSL, - -/* 50 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0xE4 | CSL, -/* 54 */ 0x20 | CSL, 0x20 | CSL, 0xFB | CSL, 0xEA | CSL, -/* 58 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 5C */ 0xEF | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, - -/* 60 */ 0xAA | CSL, 0xE0 | CSL, 0xE1 | CSL, 0x20 | CSL, -/* 64 */ 0xEB | CSL, 0x20 | CSL, 0xED | CSL, 0x59 | CSL, -/* 68 */ 0x20 | CSL, 0x20 | CSL, 0xE9 | CSL, 0x20 | CSL, -/* 6C */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, - -/* 70 */ 0xE3 | CSL, 0x20 | CSL, 0x20 | CSL, 0xE5 | CSL, -/* 74 */ 0xE7 | CSL, 0x20 | CSL, 0x9F | CSL, 0x20 | CSL, -/* 78 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 7C */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL -}; - -/*---------------------------------------------------------------------------* - * ISO Latin-1 Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSD_ISOLATIN -u_short csd_isolatin[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0xAD | CSL, 0x9B | CSL, 0x9C | CSL, -/* 24 */ 0x20 | CSL, 0x9D | CSL, 0x7C | CSL, 0x20 | CSL, -/* 28 */ 0x22 | CSL, 0x20 | CSL, 0xA6 | CSL, 0xAE | CSL, -/* 2C */ 0xAA | CSL, 0x2D | CSL, 0x20 | CSL, 0x2D | CSL, - -/* 30 */ 0xF8 | CSL, 0xF1 | CSL, 0xFD | CSL, 0x20 | CSL, -/* 34 */ 0x27 | CSL, 0xE6 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 38 */ 0x20 | CSL, 0x20 | CSL, 0xA7 | CSL, 0xAF | CSL, -/* 3C */ 0xAC | CSL, 0xAB | CSL, 0x20 | CSL, 0xA8 | CSL, - -/* 40 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 44 */ 0x8E | CSL, 0x8F | CSL, 0x92 | CSL, 0x80 | CSL, -/* 48 */ 0x20 | CSL, 0x90 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 4C */ 0x8D | CSL, 0xA1 | CSL, 0x8C | CSL, 0x8B | CSL, - -/* 50 */ 0x20 | CSL, 0xA5 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 54 */ 0x20 | CSL, 0x20 | CSL, 0x99 | CSL, 0x78 | CSL, -/* 58 */ 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, 0x20 | CSL, -/* 5C */ 0x9A | CSL, 0x20 | CSL, 0x20 | CSL, 0xE1 | CSL, - -/* 60 */ 0x85 | CSL, 0xA0 | CSL, 0x83 | CSL, 0x20 | CSL, -/* 64 */ 0x84 | CSL, 0x86 | CSL, 0x91 | CSL, 0x87 | CSL, -/* 68 */ 0x8A | CSL, 0x82 | CSL, 0x88 | CSL, 0x89 | CSL, -/* 6C */ 0x8D | CSL, 0xA1 | CSL, 0x8C | CSL, 0x8B | CSL, - -/* 70 */ 0x20 | CSL, 0xA4 | CSL, 0x95 | CSL, 0xA2 | CSL, -/* 74 */ 0x93 | CSL, 0x20 | CSL, 0x94 | CSL, 0xF6 | CSL, -/* 78 */ 0x20 | CSL, 0x97 | CSL, 0xA3 | CSL, 0x96 | CSL, -/* 7C */ 0x81 | CSL, 0x20 | CSL, 0x20 | CSL, 0x98 | CSL -}; - -/*===========================================================================* - * EXTENDED TABLES FOR EGA/VGA - *===========================================================================*/ - -/*---------------------------------------------------------------------------* - * ASCII Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSE_ASCII -u_short cse_ascii[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0x21 | CSL, 0x22 | CSL, 0x23 | CSL, -/* 24 */ 0x24 | CSL, 0x25 | CSL, 0x26 | CSL, 0x27 | CSL, -/* 28 */ 0x28 | CSL, 0x29 | CSL, 0x2A | CSL, 0x2B | CSL, -/* 2C */ 0x2C | CSL, 0x2D | CSL, 0x2E | CSL, 0x2F | CSL, - -/* 30 */ 0x30 | CSL, 0x31 | CSL, 0x32 | CSL, 0x33 | CSL, -/* 34 */ 0x34 | CSL, 0x35 | CSL, 0x36 | CSL, 0x37 | CSL, -/* 38 */ 0x38 | CSL, 0x39 | CSL, 0x3A | CSL, 0x3B | CSL, -/* 3C */ 0x3C | CSL, 0x3D | CSL, 0x3E | CSL, 0x3F | CSL, - -/* 40 */ 0x40 | CSL, 0x41 | CSL, 0x42 | CSL, 0x43 | CSL, -/* 44 */ 0x44 | CSL, 0x45 | CSL, 0x46 | CSL, 0x47 | CSL, -/* 48 */ 0x48 | CSL, 0x49 | CSL, 0x4A | CSL, 0x4B | CSL, -/* 4C */ 0x4C | CSL, 0x4D | CSL, 0x4E | CSL, 0x4F | CSL, - -/* 50 */ 0x50 | CSL, 0x51 | CSL, 0x52 | CSL, 0x53 | CSL, -/* 54 */ 0x54 | CSL, 0x55 | CSL, 0x56 | CSL, 0x57 | CSL, -/* 58 */ 0x58 | CSL, 0x59 | CSL, 0x5A | CSL, 0x5B | CSL, -/* 5C */ 0x5C | CSL, 0x5D | CSL, 0x5E | CSL, 0x5F | CSL, - -/* 60 */ 0x60 | CSL, 0x61 | CSL, 0x62 | CSL, 0x63 | CSL, -/* 64 */ 0x64 | CSL, 0x65 | CSL, 0x66 | CSL, 0x67 | CSL, -/* 68 */ 0x68 | CSL, 0x69 | CSL, 0x6A | CSL, 0x6B | CSL, -/* 6C */ 0x6C | CSL, 0x6D | CSL, 0x6E | CSL, 0x6F | CSL, - -/* 70 */ 0x70 | CSL, 0x71 | CSL, 0x72 | CSL, 0x73 | CSL, -/* 74 */ 0x74 | CSL, 0x75 | CSL, 0x76 | CSL, 0x77 | CSL, -/* 78 */ 0x78 | CSL, 0x79 | CSL, 0x7A | CSL, 0x7B | CSL, -/* 7C */ 0x7C | CSL, 0x7D | CSL, 0x7E | CSL, 0xB0 | CSL, -}; - -/*---------------------------------------------------------------------------* - * DEC Supplemental Graphic Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSE_SUPPLEMENTAL -u_short cse_supplemental[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0xAD | CSL, 0x9B | CSL, 0x9C | CSL, -/* 24 */ 0x9F | CSH, 0x67 | CSH, 0x9F | CSH, 0x15 | CSL, -/* 28 */ 0x9D | CSH, 0x9C | CSH, 0xA6 | CSL, 0xAE | CSL, -/* 2C */ 0x9F | CSH, 0x9F | CSH, 0x9F | CSH, 0x9F | CSH, - -/* 30 */ 0xF8 | CSL, 0xF1 | CSL, 0xFD | CSL, 0x9B | CSH, -/* 34 */ 0x9F | CSH, 0xE6 | CSL, 0x14 | CSL, 0x99 | CSH, -/* 38 */ 0x9F | CSH, 0x98 | CSH, 0xA7 | CSL, 0xAF | CSL, -/* 3C */ 0xAC | CSL, 0xAB | CSL, 0x9F | CSH, 0xA8 | CSL, - -/* 40 */ 0x97 | CSH, 0x96 | CSH, 0x95 | CSH, 0x94 | CSH, -/* 44 */ 0x8E | CSL, 0x8F | CSL, 0x92 | CSL, 0x80 | CSL, -/* 48 */ 0x93 | CSH, 0x90 | CSL, 0x92 | CSH, 0x91 | CSH, -/* 4C */ 0x90 | CSH, 0x8F | CSH, 0x8E | CSH, 0x8D | CSH, - -/* 50 */ 0x9F | CSH, 0xA5 | CSL, 0x8C | CSH, 0x8B | CSH, -/* 54 */ 0x8A | CSH, 0x89 | CSH, 0x99 | CSL, 0x88 | CSH, -/* 58 */ 0x87 | CSH, 0x86 | CSH, 0x85 | CSH, 0x84 | CSH, -/* 5C */ 0x9A | CSL, 0x83 | CSH, 0x9F | CSH, 0xE1 | CSL, - -/* 60 */ 0x85 | CSL, 0xA0 | CSL, 0x83 | CSL, 0x82 | CSH, -/* 64 */ 0x84 | CSL, 0x86 | CSL, 0x91 | CSL, 0x87 | CSL, -/* 68 */ 0x8A | CSL, 0x82 | CSL, 0x88 | CSL, 0x89 | CSL, -/* 6C */ 0x8D | CSL, 0xA1 | CSL, 0x8C | CSL, 0x8B | CSL, - -/* 70 */ 0x9F | CSH, 0xA4 | CSL, 0x95 | CSL, 0xA2 | CSL, -/* 74 */ 0x93 | CSL, 0x81 | CSH, 0x94 | CSL, 0x80 | CSH, -/* 78 */ 0x7F | CSH, 0x97 | CSL, 0xA3 | CSL, 0x96 | CSL, -/* 7C */ 0x81 | CSL, 0x98 | CSL, 0x9F | CSH, 0x20 | CSL -}; - -/*---------------------------------------------------------------------------* - * DEC Special Graphic Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSE_SPECIAL -u_short cse_special[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0x21 | CSL, 0x22 | CSL, 0x23 | CSL, -/* 24 */ 0x24 | CSL, 0x25 | CSL, 0x26 | CSL, 0x27 | CSL, -/* 28 */ 0x28 | CSL, 0x29 | CSL, 0x2A | CSL, 0x2B | CSL, -/* 2C */ 0x2C | CSL, 0x2D | CSL, 0x2E | CSL, 0x2F | CSL, - -/* 30 */ 0x30 | CSL, 0x31 | CSL, 0x32 | CSL, 0x33 | CSL, -/* 34 */ 0x34 | CSL, 0x35 | CSL, 0x36 | CSL, 0x37 | CSL, -/* 38 */ 0x38 | CSL, 0x39 | CSL, 0x3A | CSL, 0x3B | CSL, -/* 3C */ 0x3C | CSL, 0x3D | CSL, 0x3E | CSL, 0x3F | CSL, - -/* 40 */ 0x40 | CSL, 0x41 | CSL, 0x42 | CSL, 0x43 | CSL, -/* 44 */ 0x44 | CSL, 0x45 | CSL, 0x46 | CSL, 0x47 | CSL, -/* 48 */ 0x48 | CSL, 0x49 | CSL, 0x4A | CSL, 0x4B | CSL, -/* 4C */ 0x4C | CSL, 0x4D | CSL, 0x4E | CSL, 0x4F | CSL, - -/* 50 */ 0x50 | CSL, 0x51 | CSL, 0x52 | CSL, 0x53 | CSL, -/* 54 */ 0x54 | CSL, 0x55 | CSL, 0x56 | CSL, 0x57 | CSL, -/* 58 */ 0x58 | CSL, 0x59 | CSL, 0x5A | CSL, 0x5B | CSL, -/* 5C */ 0x5C | CSL, 0x5D | CSL, 0x5E | CSL, 0x20 | CSL, - -/* 60 */ 0x04 | CSL, 0xB0 | CSL, 0x09 | CSH, 0x0C | CSH, -/* 64 */ 0x0D | CSH, 0x0A | CSH, 0xF8 | CSL, 0xF1 | CSL, -/* 68 */ 0x00 | CSH, 0x0B | CSH, 0xD9 | CSL, 0xBF | CSL, -/* 6C */ 0xDA | CSL, 0xC0 | CSL, 0xC5 | CSL, 0x7D | CSH, - -/* 70 */ 0x7C | CSH, 0x7B | CSH, 0x7A | CSH, 0x79 | CSH, -/* 74 */ 0xC3 | CSL, 0xB4 | CSL, 0xC1 | CSL, 0xC2 | CSL, -/* 78 */ 0xB3 | CSL, 0xF3 | CSL, 0xF2 | CSL, 0xE3 | CSL, -/* 7C */ 0x78 | CSH, 0x9C | CSL, 0x99 | CSH, 0x20 | CSL -}; - -/*---------------------------------------------------------------------------* - * DEC Technical Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSE_TECHNICAL -u_short cse_technical[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0x65 | CSH, 0xDA | CSL, 0xC4 | CSL, -/* 24 */ 0xF4 | CSL, 0xF5 | CSL, 0xB3 | CSL, 0xDA | CSL, -/* 28 */ 0xC0 | CSL, 0xBF | CSL, 0xD9 | CSL, 0x61 | CSH, -/* 2C */ 0x62 | CSH, 0x63 | CSH, 0x64 | CSH, 0x5F | CSH, - -/* 30 */ 0x60 | CSH, 0x5E | CSH, 0x5D | CSH, 0x5C | CSH, -/* 34 */ 0x5B | CSH, 0xAA | CSL, 0xA9 | CSL, 0x3E | CSL, -/* 38 */ 0x9F | CSH, 0x9F | CSH, 0x9F | CSH, 0x9F | CSH, -/* 3C */ 0xF3 | CSL, 0x78 | CSH, 0xF2 | CSL, 0x5A | CSH, - -/* 40 */ 0x59 | CSH, 0x58 | CSH, 0xEC | CSL, 0xF6 | CSL, -/* 44 */ 0x57 | CSH, 0x56 | CSH, 0xE8 | CSL, 0xE2 | CSL, -/* 48 */ 0x77 | CSH, 0x55 | CSH, 0x54 | CSH, 0x6E | CSH, -/* 4C */ 0x53 | CSH, 0x52 | CSH, 0x51 | CSH, 0xF0 | CSL, - -/* 50 */ 0x50 | CSH, 0x4F | CSH, 0x9F | CSH, 0xE4 | CSL, -/* 54 */ 0x9F | CSH, 0x9F | CSH, 0xFB | CSL, 0xEA | CSL, -/* 58 */ 0x4E | CSH, 0x4D | CSH, 0x4C | CSH, 0x4B | CSH, -/* 5C */ 0xEF | CSL, 0x4A | CSH, 0x49 | CSH, 0x48 | CSH, - -/* 60 */ 0xAA | CSL, 0xE0 | CSL, 0xE1 | CSL, 0x47 | CSH, -/* 64 */ 0xEB | CSL, 0x46 | CSH, 0xED | CSL, 0x59 | CSL, -/* 68 */ 0x45 | CSH, 0x44 | CSH, 0xE9 | CSL, 0x9E | CSH, -/* 6C */ 0x43 | CSH, 0x9F | CSH, 0x76 | CSL, 0x42 | CSH, - -/* 70 */ 0xE3 | CSL, 0x41 | CSH, 0x40 | CSH, 0xE5 | CSL, -/* 74 */ 0xE7 | CSL, 0x9F | CSH, 0x9F | CSL, 0x66 | CSH, -/* 78 */ 0x68 | CSH, 0x7E | CSH, 0x9A | CSH, 0x1B | CSL, -/* 7C */ 0x18 | CSL, 0x1A | CSL, 0x19 | CSL, 0x20 | CSL -}; - -/*---------------------------------------------------------------------------* - * ISO Latin-1 Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSE_ISOLATIN -u_short cse_isolatin[CSSIZE] = { -/* 20 */ 0x20 | CSL, 0xAD | CSL, 0x9B | CSL, 0x9C | CSL, -/* 24 */ 0x9D | CSH, 0x9D | CSL, 0x7C | CSL, 0x15 | CSL, -/* 28 */ 0x77 | CSH, 0x9C | CSH, 0xA6 | CSL, 0xAE | CSL, -/* 2C */ 0x76 | CSH, 0x75 | CSH, 0x74 | CSH, 0x73 | CSH, - -/* 30 */ 0xF8 | CSL, 0xF1 | CSL, 0xFD | CSL, 0x9B | CSH, -/* 34 */ 0x72 | CSH, 0xE6 | CSL, 0x14 | CSL, 0x99 | CSH, -/* 38 */ 0x71 | CSH, 0x98 | CSH, 0xA7 | CSL, 0xAF | CSL, -/* 3C */ 0xAC | CSL, 0xAB | CSL, 0x70 | CSH, 0xA8 | CSL, - -/* 40 */ 0x97 | CSH, 0x96 | CSH, 0x95 | CSH, 0x94 | CSH, -/* 44 */ 0x8E | CSL, 0x8F | CSL, 0x92 | CSL, 0x80 | CSL, -/* 48 */ 0x93 | CSH, 0x90 | CSL, 0x92 | CSH, 0x91 | CSH, -/* 4C */ 0x90 | CSH, 0x8F | CSH, 0x8E | CSH, 0x8D | CSH, - -/* 50 */ 0x6F | CSH, 0xA5 | CSL, 0x8C | CSH, 0x8B | CSH, -/* 54 */ 0x8A | CSH, 0x89 | CSH, 0x99 | CSL, 0x6E | CSH, -/* 58 */ 0x87 | CSH, 0x86 | CSH, 0x85 | CSH, 0x84 | CSH, -/* 5C */ 0x9A | CSL, 0x6D | CSH, 0x6C | CSH, 0xE1 | CSL, - -/* 60 */ 0x85 | CSL, 0xA0 | CSL, 0x83 | CSL, 0x82 | CSH, -/* 64 */ 0x84 | CSL, 0x86 | CSL, 0x91 | CSL, 0x87 | CSL, -/* 68 */ 0x8A | CSL, 0x82 | CSL, 0x88 | CSL, 0x89 | CSL, -/* 6C */ 0x8D | CSL, 0xA1 | CSL, 0x8C | CSL, 0x8B | CSL, - -/* 70 */ 0x6B | CSH, 0xA4 | CSL, 0x95 | CSL, 0xA2 | CSL, -/* 74 */ 0x93 | CSL, 0x81 | CSH, 0x94 | CSL, 0xF6 | CSL, -/* 78 */ 0x7F | CSH, 0x97 | CSL, 0xA3 | CSL, 0x96 | CSL, -/* 7C */ 0x81 | CSL, 0x69 | CSL, 0x6A | CSH, 0x98 | CSL -}; - -/*---------------------------------------------------------------------------* - * Downloadable Characterset - *---------------------------------------------------------------------------*/ -#define HAVECSE_DOWNLOADABLE -u_short cse_downloadable[CSSIZE] = { -/* 20 */ 0xA0 | CSH, 0xA1 | CSH, 0xA2 | CSH, 0xA3 | CSH, -/* 24 */ 0xA4 | CSH, 0xA5 | CSH, 0xA6 | CSH, 0xA7 | CSH, -/* 28 */ 0xA8 | CSH, 0xA9 | CSH, 0xAA | CSH, 0xAB | CSH, -/* 2C */ 0xAC | CSH, 0xAD | CSH, 0xAE | CSH, 0xAF | CSH, - -/* 30 */ 0xB0 | CSH, 0xB1 | CSH, 0xB2 | CSH, 0xB3 | CSH, -/* 34 */ 0xB4 | CSH, 0xB5 | CSH, 0xB6 | CSH, 0xB7 | CSH, -/* 38 */ 0xB8 | CSH, 0xB9 | CSH, 0xBA | CSH, 0xBB | CSH, -/* 3C */ 0xBC | CSH, 0xBD | CSH, 0xBE | CSH, 0xBF | CSH, - -/* 40 */ 0xC0 | CSH, 0xC1 | CSH, 0xC2 | CSH, 0xC3 | CSH, -/* 44 */ 0xC4 | CSH, 0xC5 | CSH, 0xC6 | CSH, 0xC7 | CSH, -/* 48 */ 0xC8 | CSH, 0xC9 | CSH, 0xCA | CSH, 0xCB | CSH, -/* 4C */ 0xCC | CSH, 0xCD | CSH, 0xCE | CSH, 0xCF | CSH, - -/* 50 */ 0xD0 | CSH, 0xD1 | CSH, 0xD2 | CSH, 0xD3 | CSH, -/* 54 */ 0xD4 | CSH, 0xD5 | CSH, 0xD6 | CSH, 0xD7 | CSH, -/* 58 */ 0xD8 | CSH, 0xD9 | CSH, 0xDA | CSH, 0xDB | CSH, -/* 5C */ 0xDC | CSH, 0xDD | CSH, 0xDE | CSH, 0xDF | CSH, - -/* 60 */ 0xE0 | CSH, 0xE1 | CSH, 0xE2 | CSH, 0xE3 | CSH, -/* 64 */ 0xE4 | CSH, 0xE5 | CSH, 0xE6 | CSH, 0xE7 | CSH, -/* 68 */ 0xE8 | CSH, 0xE9 | CSH, 0xEA | CSH, 0xEB | CSH, -/* 6C */ 0xEC | CSH, 0xED | CSH, 0xEE | CSH, 0xEF | CSH, - -/* 70 */ 0xF0 | CSH, 0xF1 | CSH, 0xF2 | CSH, 0xF3 | CSH, -/* 74 */ 0xF4 | CSH, 0xF5 | CSH, 0xF6 | CSH, 0xF7 | CSH, -/* 78 */ 0xF8 | CSH, 0xF9 | CSH, 0xFA | CSH, 0xFB | CSH, -/* 7C */ 0xFC | CSH, 0xFD | CSH, 0xFE | CSH, 0xFF | CSH, -}; - -/* ------------------------- E O F ------------------------------------------*/ diff --git a/sys/arch/i386/isa/pcvt/pcvt_vtf.c b/sys/arch/i386/isa/pcvt/pcvt_vtf.c deleted file mode 100644 index 8fda597d24d6..000000000000 --- a/sys/arch/i386/isa/pcvt/pcvt_vtf.c +++ /dev/null @@ -1,2216 +0,0 @@ -/* - * Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch. - * - * Copyright (c) 1992, 1993 Brian Dunford-Shore. - * - * All rights reserved. - * - * This code is derived from software contributed to Berkeley by - * William Jolitz and Don Ahn. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * This product includes software developed by Hellmuth Michaelis, - * Brian Dunford-Shore and Joerg Wunsch. - * 4. The name authors may not be used to endorse or promote products - * derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES - * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, - * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF - * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * - * @(#)pcvt_vtf.c, 3.32, Last Edit-Date: [Tue Oct 3 11:19:49 1995] - * - */ - -/*---------------------------------------------------------------------------* - * - * pcvt_vtf.c VT220 Terminal Emulator Functions - * ------------------------------------------------- - * -hm ------------ Release 3.00 -------------- - * -hm integrating NetBSD-current patches - * -hm integrating patch from Thomas Gellekum - * -hm fixed bug fkey labels not properly (re)set after ris - * -hm Michael Havemester fixed NOFASTSCROLL define bug - * -hm set caps/scroll/num_lock in vt_str() and made led_update() - * -hm applying patch from Joerg fixing Crtat bug - * -hm fixing NOFASTSCROLL operation for MDA/Hercules - * -jw/hm fixing bug in roll_up() and roll_down() - * -hm fastscroll/Crtat bugfix from Lon Willett - * -hm patch for non-XSERVER/UCONSOLE compiles from Rafal Boni - * -hm bugfix: PCVT_USL_COMPAT renamed to PCVT_USL_VT_COMPAT ... - * -hm ---------------- Release 3.30 ----------------------- - * -hm patch from Thomas Gellekum fixes scroll region bug in vt_stbm() - * -hm patch from Thomas Gellekum to support C1 controls - * -hm patch from Thomas Gellekum re updating GL and GR - * -hm ---------------- Release 3.32 ----------------------- - * - *---------------------------------------------------------------------------*/ - -#define PCVT_INCLUDE_VT_SELATTR /* get inline function from pcvt_hdr.h */ - -#include "pcvt_hdr.h" /* global include */ -#include "pcvt_tbl.h" /* character set conversion tables */ - -static void clear_dld ( struct video_state *svsp ); -static void init_dld ( struct video_state *svsp ); -static void init_udk ( struct video_state *svsp ); -static void respond ( struct video_state *svsp ); -static void roll_down ( struct video_state *svsp, int n ); -static void selective_erase ( struct video_state *svsp, u_short *pcrtat, - int length ); -static void swcsp ( struct video_state *svsp, u_short *ctp ); - -/*---------------------------------------------------------------------------* - * DECSTBM - set top and bottom margins - *---------------------------------------------------------------------------*/ -void -vt_stbm(struct video_state *svsp) -{ - /* both 0 => scrolling region = entire screen */ - - if((svsp->parms[0] == 0) && (svsp->parms[1] == 0)) - { - svsp->cur_offset = 0; - svsp->scrr_beg = 0; - svsp->scrr_len = svsp->screen_rows; - svsp->scrr_end = svsp->scrr_len - 1; - svsp->col = 0; - return; - } - - if(svsp->parms[1] <= svsp->parms[0]) - return; - - /* range parm 1 */ - - if(svsp->parms[0] < 1) - svsp->parms[0] = 1; - else if(svsp->parms[0] > svsp->screen_rows-1) - svsp->parms[0] = svsp->screen_rows-1; - - /* range parm 2 */ - - if(svsp->parms[1] < 2) - svsp->parms[1] = 2; - else if(svsp->parms[1] > svsp->screen_rows) - svsp->parms[1] = svsp->screen_rows; - - svsp->scrr_beg = svsp->parms[0]-1; /* begin of scrolling region */ - svsp->scrr_len = svsp->parms[1] - svsp->parms[0] + 1; /* no of lines */ - svsp->scrr_end = svsp->parms[1]-1; - - /* cursor to first pos */ - if(svsp->m_om) - svsp->cur_offset = svsp->scrr_beg * svsp->maxcol; - else - svsp->cur_offset = 0; - - svsp->abs_write = 0; - svsp->col = 0; -} - -/*---------------------------------------------------------------------------* - * SGR - set graphic rendition - *---------------------------------------------------------------------------*/ -void -vt_sgr(struct video_state *svsp) -{ - register int i = 0; - u_short setcolor = 0; - char colortouched = 0; - - do - { - switch(svsp->parms[i++]) - { - case 0: /* reset to normal attributes */ - svsp->vtsgr = VT_NORMAL; - break; - - case 1: /* bold */ - svsp->vtsgr |= VT_BOLD; - break; - - case 4: /* underline */ - svsp->vtsgr |= VT_UNDER; - break; - - case 5: /* blinking */ - svsp->vtsgr |= VT_BLINK; - break; - - case 7: /* reverse */ - svsp->vtsgr |= VT_INVERSE; - break; - - case 22: /* not bold */ - svsp->vtsgr &= ~VT_BOLD; - break; - - case 24: /* not underlined */ - svsp->vtsgr &= ~VT_UNDER; - break; - - case 25: /* not blinking */ - svsp->vtsgr &= ~VT_BLINK; - break; - - case 27: /* not reverse */ - svsp->vtsgr &= ~VT_INVERSE; - break; - - case 30: /* foreground colors */ - case 31: - case 32: - case 33: - case 34: - case 35: - case 36: - case 37: - if(color) - { - colortouched = 1; - setcolor |= ((fgansitopc[(svsp->parms[i-1]-30) & 7]) << 8); - } - break; - - case 40: /* background colors */ - case 41: - case 42: - case 43: - case 44: - case 45: - case 46: - case 47: - if(color) - { - colortouched = 1; - setcolor |= ((bgansitopc[(svsp->parms[i-1]-40) & 7]) << 8); - } - break; - } - } - while(i <= svsp->parmi); - if(color) - { - if(colortouched) - svsp->c_attr = setcolor; - else - svsp->c_attr = ((sgr_tab_color[svsp->vtsgr]) << 8); - } - else - { - if(adaptor_type == MDA_ADAPTOR) - svsp->c_attr = ((sgr_tab_imono[svsp->vtsgr]) << 8); - else - svsp->c_attr = ((sgr_tab_mono[svsp->vtsgr]) << 8); - } -} - -/*---------------------------------------------------------------------------* - * CUU - cursor up - *---------------------------------------------------------------------------*/ -void -vt_cuu(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if (p <= 0) /* parameter min */ - p = 1; - - p = min(p, svsp->row - svsp->scrr_beg); - - if (p <= 0) - return; - - svsp->cur_offset -= (svsp->maxcol * p); -} - -/*---------------------------------------------------------------------------* - * CUD - cursor down - *---------------------------------------------------------------------------*/ -void -vt_cud(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if (p <= 0) - p = 1; - - p = min(p, svsp->scrr_end - svsp->row); - - if (p <= 0) - return; - - svsp->cur_offset += (svsp->maxcol * p); -} - -/*---------------------------------------------------------------------------* - * CUF - cursor forward - *---------------------------------------------------------------------------*/ -void -vt_cuf(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(svsp->col == ((svsp->maxcol)-1)) /* already at right margin */ - return; - - if(p <= 0) /* parameter min = 1 */ - p = 1; - else if(p > ((svsp->maxcol)-1)) /* parameter max = 79 */ - p = ((svsp->maxcol)-1); - - if((svsp->col + p) > ((svsp->maxcol)-1))/* not more than right margin */ - p = ((svsp->maxcol)-1) - svsp->col; - - svsp->cur_offset += p; - svsp->col += p; -} - -/*---------------------------------------------------------------------------* - * CUB - cursor backward - *---------------------------------------------------------------------------*/ -void -vt_cub(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(svsp->col == 0) /* already at left margin ? */ - return; - - if(p <= 0) /* parameter min = 1 */ - p = 1; - else if(p > ((svsp->maxcol)-1)) /* parameter max = 79 */ - p = ((svsp->maxcol)-1); - - if((svsp->col - p) <= 0) /* not more than left margin */ - p = svsp->col; - - svsp->cur_offset -= p; - svsp->col -= p; -} - -/*---------------------------------------------------------------------------* - * ED - erase in display - *---------------------------------------------------------------------------*/ -void -vt_clreos(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: - fillw(user_attr | ' ', svsp->Crtat + svsp->cur_offset, - svsp->Crtat + - (svsp->maxcol * svsp->screen_rows) - - (svsp->Crtat + svsp->cur_offset)); - break; - - case 1: - fillw(user_attr | ' ', svsp->Crtat, - svsp->Crtat + svsp->cur_offset - - svsp->Crtat + 1 ); - break; - - case 2: - fillw(user_attr | ' ', svsp->Crtat, - svsp->maxcol * svsp->screen_rows); - break; - } -} - -/*---------------------------------------------------------------------------* - * EL - erase in line - *---------------------------------------------------------------------------*/ -void -vt_clreol(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: - fillw(user_attr | ' ', - svsp->Crtat + svsp->cur_offset, - svsp->maxcol-svsp->col); - break; - - case 1: - fillw(user_attr | ' ', - svsp->Crtat + svsp->cur_offset - svsp->col, - svsp->col + 1); - break; - - case 2: - fillw(user_attr | ' ', - svsp->Crtat + svsp->cur_offset - svsp->col, - svsp->maxcol); - break; - } -} - -/*---------------------------------------------------------------------------* - * CUP - cursor position / HVP - horizontal & vertical position - *---------------------------------------------------------------------------*/ -void -vt_curadr(struct video_state *svsp) -{ - if(svsp->m_om) /* relative to scrolling region */ - { - if((svsp->parms[0] == 0) && (svsp->parms[1] == 0)) - { - svsp->cur_offset = svsp->scrr_beg * svsp->maxcol; - svsp->col = 0; - svsp->abs_write = 0; - return; - } - - if(svsp->parms[0] <= 0) - svsp->parms[0] = 1; - else if(svsp->parms[0] > svsp->scrr_len) - svsp->parms[0] = svsp->scrr_len; - - if(svsp->parms[1] <= 0 ) - svsp->parms[1] = 1; - if(svsp->parms[1] > svsp->maxcol) - svsp->parms[1] = svsp->maxcol; - - svsp->cur_offset = (svsp->scrr_beg * svsp->maxcol) + - ((svsp->parms[0] - 1) * svsp->maxcol) + - svsp->parms[1] - 1; - svsp->col = svsp->parms[1] - 1; - svsp->abs_write = 0; - } - else /* relative to screen start */ - { - if((svsp->parms[0] == 0) && (svsp->parms[1] == 0)) - { - svsp->cur_offset = 0; - svsp->col = 0; - svsp->abs_write = 0; - return; - } - - if(svsp->parms[0] <= 0) - svsp->parms[0] = 1; - else if(svsp->parms[0] > svsp->screen_rows) - svsp->parms[0] = svsp->screen_rows; - - if(svsp->parms[1] <= 0 ) - svsp->parms[1] = 1; - if(svsp->parms[1] > svsp->maxcol) /* col */ - svsp->parms[1] = svsp->maxcol; - - svsp->cur_offset = (((svsp->parms[0]-1)*svsp->maxcol) + - (svsp->parms[1]-1)); - svsp->col = svsp->parms[1]-1; - - if (svsp->cur_offset >= - ((svsp->scrr_beg + svsp->scrr_len + 1) * svsp->maxcol)) - - svsp->abs_write = 1; - else - svsp->abs_write = 0; - } -} - -/*---------------------------------------------------------------------------* - * RIS - reset to initial state (hard emulator runtime reset) - *---------------------------------------------------------------------------*/ -void -vt_ris(struct video_state *svsp) -{ - fillw(user_attr | ' ', svsp->Crtat, svsp->maxcol * svsp->screen_rows); - svsp->cur_offset = 0; /* cursor upper left corner */ - svsp->col = 0; - svsp->row = 0; - svsp->lnm = 0; /* CR only */ - clear_dld(svsp); /* clear download charset */ - vt_clearudk(svsp); /* clear user defined keys */ - svsp->selchar = 0; /* selective attribute off */ - vt_str(svsp); /* and soft terminal reset */ -} - -/*---------------------------------------------------------------------------* - * DECSTR - soft terminal reset (SOFT emulator runtime reset) - *---------------------------------------------------------------------------*/ -void -vt_str(struct video_state *svsp) -{ - int i; - - clr_parms(svsp); /* escape parameter init */ - svsp->state = STATE_INIT; /* initial state */ - - svsp->dis_fnc = 0; /* display functions reset */ - - svsp->sc_flag = 0; /* save cursor position */ - svsp->transparent = 0; /* enable control code processing */ - svsp->C1_ctls = 0; /* but only for C0 codes */ - svsp->sevenbit = 0; /* data path 8 bits wide */ - - for(i = 0; i < MAXTAB; i++) /* setup tabstops */ - { - if(!(i % 8)) - svsp->tab_stops[i] = 1; - else - svsp->tab_stops[i] = 0; - } - - svsp->irm = 0; /* replace mode */ - svsp->m_om = 0; /* origin mode */ - svsp->m_awm = 1; /* auto wrap mode */ - -#if PCVT_INHIBIT_NUMLOCK - svsp->num_lock = 0; /* keypad application mode */ -#else - svsp->num_lock = 1; /* keypad numeric mode */ -#endif - - svsp->scroll_lock = 0; /* reset keyboard modes */ - svsp->caps_lock = 0; - - svsp->ckm = 1; /* cursor key mode = "normal" ... */ - svsp->scrr_beg = 0; /* start of scrolling region */ - svsp->scrr_len = svsp->screen_rows; /* no. of lines in scrolling region */ - svsp->abs_write = 0; /* scrr is complete screen */ - svsp->scrr_end = svsp->scrr_len - 1; - - if(adaptor_type == EGA_ADAPTOR || adaptor_type == VGA_ADAPTOR) - { - svsp->G0 = cse_ascii; /* G0 = ascii */ - svsp->G1 = cse_ascii; /* G1 = ascii */ - svsp->G2 = cse_supplemental; /* G2 = supplemental */ - svsp->G3 = cse_supplemental; /* G3 = supplemental */ - svsp->GL = svsp->G0; /* GL = G0 */ - svsp->GR = svsp->G2; /* GR = G2 */ - } - else - { - svsp->G0 = csd_ascii; /* G0 = ascii */ - svsp->G1 = csd_ascii; /* G1 = ascii */ - svsp->G2 = csd_supplemental; /* G2 = supplemental */ - svsp->G3 = csd_supplemental; /* G3 = supplemental */ - svsp->GL = svsp->G0; /* GL = G0 */ - svsp->GR = svsp->G2; /* GR = G2 */ - } - - svsp->vtsgr = VT_NORMAL; /* no attributes */ - svsp->c_attr = user_attr; /* reset sgr to normal */ - - svsp->selchar = 0; /* selective attribute off */ - vt_initsel(svsp); - - init_ufkl(svsp); /* init user fkey labels */ - init_sfkl(svsp); /* init system fkey labels */ - - update_led(); /* update keyboard LED's */ -} - -/*---------------------------------------------------------------------------* - * RI - reverse index, move cursor up - *---------------------------------------------------------------------------*/ -void -vt_ri(struct video_state *svsp) -{ - if(svsp->cur_offset >= ((svsp->scrr_beg * svsp->maxcol) + svsp->maxcol)) - svsp->cur_offset -= svsp->maxcol; - else - roll_down(svsp, 1); -} - -/*---------------------------------------------------------------------------* - * IND - index, move cursor down - *---------------------------------------------------------------------------*/ -void -vt_ind(struct video_state *svsp) -{ - if(svsp->cur_offset < (svsp->scrr_end * svsp->maxcol)) - svsp->cur_offset += svsp->maxcol; - else - roll_up(svsp, 1); -} - -/*---------------------------------------------------------------------------* - * NEL - next line, first pos of next line - *---------------------------------------------------------------------------*/ -void -vt_nel(struct video_state *svsp) -{ - if(svsp->cur_offset < (svsp->scrr_end * svsp->maxcol)) - { - svsp->cur_offset += (svsp->maxcol-svsp->col); - svsp->col = 0; - } - else - { - roll_up(svsp, 1); - svsp->cur_offset -= svsp->col; - svsp->col = 0; - } -} - -/*---------------------------------------------------------------------------* - * set dec private modes, esc [ ? x h - *---------------------------------------------------------------------------*/ -void -vt_set_dec_priv_qm(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: /* error, ignored */ - case 1: /* CKM - cursor key mode */ - svsp->ckm = 1; - break; - - case 2: /* ANM - ansi/vt52 mode */ - break; - - case 3: /* COLM - column mode */ - vt_col(svsp, SCR_COL132); - break; - - case 4: /* SCLM - scrolling mode */ - case 5: /* SCNM - screen mode */ - break; - - case 6: /* OM - origin mode */ - svsp->m_om = 1; - break; - - case 7: /* AWM - auto wrap mode */ - svsp->m_awm = 1; - swritefkl(7,(u_char *)"AUTOWRAPENABLE *",svsp); - break; - - case 8: /* ARM - auto repeat mode */ - kbrepflag = 1; - break; - - case 9: /* INLM - interlace mode */ - case 10: /* EDM - edit mode */ - case 11: /* LTM - line transmit mode */ - case 12: /* */ - case 13: /* SCFDM - space compression / field delimiting */ - case 14: /* TEM - transmit execution mode */ - case 15: /* */ - case 16: /* EKEM - edit key execution mode */ - break; - - case 25: /* TCEM - text cursor enable mode */ - if(vsp == svsp) - sw_cursor(1); /* cursor on */ - svsp->cursor_on = 1; - break; - - case 42: /* NRCM - 7bit NRC characters */ - break; - } -} - -/*---------------------------------------------------------------------------* - * reset dec private modes, esc [ ? x l - *---------------------------------------------------------------------------*/ -void -vt_reset_dec_priv_qm(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: /* error, ignored */ - case 1: /* CKM - cursor key mode */ - svsp->ckm = 0; - break; - - case 2: /* ANM - ansi/vt52 mode */ - break; - - case 3: /* COLM - column mode */ - vt_col(svsp, SCR_COL80); - break; - - case 4: /* SCLM - scrolling mode */ - case 5: /* SCNM - screen mode */ - break; - - case 6: /* OM - origin mode */ - svsp->m_om = 0; - break; - - case 7: /* AWM - auto wrap mode */ - svsp->m_awm = 0; - swritefkl(7,(u_char *)"AUTOWRAPENABLE ",svsp); - break; - - case 8: /* ARM - auto repeat mode */ - kbrepflag = 0; - break; - - case 9: /* INLM - interlace mode */ - case 10: /* EDM - edit mode */ - case 11: /* LTM - line transmit mode */ - case 12: /* */ - case 13: /* SCFDM - space compression / field delimiting */ - case 14: /* TEM - transmit execution mode */ - case 15: /* */ - case 16: /* EKEM - edit key execution mode */ - break; - - case 25: /* TCEM - text cursor enable mode */ - if(vsp == svsp) - sw_cursor(0); /* cursor off */ - svsp->cursor_on = 0; - break; - - case 42: /* NRCM - 7bit NRC characters */ - break; - } -} - -/*---------------------------------------------------------------------------* - * set ansi modes, esc [ x - *---------------------------------------------------------------------------*/ -void -vt_set_ansi(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: /* error, ignored */ - case 1: /* GATM - guarded area transfer mode */ - case 2: /* KAM - keyboard action mode */ - case 3: /* CRM - Control Representation mode */ - break; - - case 4: /* IRM - insert replacement mode */ - svsp->irm = 1; /* Insert mode */ - break; - - case 5: /* SRTM - status report transfer mode */ - case 6: /* ERM - erasue mode */ - case 7: /* VEM - vertical editing mode */ - case 10: /* HEM - horizontal editing mode */ - case 11: /* PUM - position unit mode */ - case 12: /* SRM - send-receive mode */ - case 13: /* FEAM - format effector action mode */ - case 14: /* FETM - format effector transfer mode */ - case 15: /* MATM - multiple area transfer mode */ - case 16: /* TTM - transfer termination */ - case 17: /* SATM - selected area transfer mode */ - case 18: /* TSM - tabulation stop mode */ - case 19: /* EBM - editing boundary mode */ - break; - - case 20: /* LNM - line feed / newline mode */ - svsp->lnm = 1; - break; - } -} - -/*---------------------------------------------------------------------------* - * reset ansi modes, esc [ x - *---------------------------------------------------------------------------*/ -void -vt_reset_ansi(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: /* error, ignored */ - case 1: /* GATM - guarded area transfer mode */ - case 2: /* KAM - keyboard action mode */ - case 3: /* CRM - Control Representation mode */ - break; - - case 4: /* IRM - insert replacement mode */ - svsp->irm = 0; /* Replace mode */ - break; - - case 5: /* SRTM - status report transfer mode */ - case 6: /* ERM - erasue mode */ - case 7: /* VEM - vertical editing mode */ - case 10: /* HEM - horizontal editing mode */ - case 11: /* PUM - position unit mode */ - case 12: /* SRM - send-receive mode */ - case 13: /* FEAM - format effector action mode */ - case 14: /* FETM - format effector transfer mode */ - case 15: /* MATM - multiple area transfer mode */ - case 16: /* TTM - transfer termination */ - case 17: /* SATM - selected area transfer mode */ - case 18: /* TSM - tabulation stop mode */ - case 19: /* EBM - editing boundary mode */ - break; - - case 20: /* LNM - line feed / newline mode */ - svsp->lnm = 0; - break; - } -} - -/*---------------------------------------------------------------------------* - * clear tab stop(s) - *---------------------------------------------------------------------------*/ -void -vt_clrtab(struct video_state *svsp) -{ - int i; - - if(svsp->parms[0] == 0) - svsp->tab_stops[svsp->col] = 0; - else if(svsp->parms[0] == 3) - { - for(i=0; itab_stops[i] = 0; - } -} - -/*---------------------------------------------------------------------------* - * DECSC - save cursor & attributes - *---------------------------------------------------------------------------*/ -void -vt_sc(struct video_state *svsp) -{ - svsp->sc_flag = 1; - svsp->sc_row = svsp->row; - svsp->sc_col = svsp->col; - svsp->sc_cur_offset = svsp->cur_offset; - svsp->sc_attr = svsp->c_attr; - svsp->sc_awm = svsp->m_awm; - svsp->sc_om = svsp->m_om; - svsp->sc_G0 = svsp->G0; - svsp->sc_G1 = svsp->G1; - svsp->sc_G2 = svsp->G2; - svsp->sc_G3 = svsp->G3; - svsp->sc_GL = svsp->GL; - svsp->sc_GR = svsp->GR; - svsp->sc_sel = svsp->selchar; - svsp->sc_vtsgr = svsp->vtsgr; -} - -/*---------------------------------------------------------------------------* - * DECRC - restore cursor & attributes - *---------------------------------------------------------------------------*/ -void -vt_rc(struct video_state *svsp) -{ - if(svsp->sc_flag == 1) - { - svsp->sc_flag = 0; - svsp->row = svsp->sc_row; - svsp->col = svsp->sc_col; - svsp->cur_offset = svsp->sc_cur_offset; - svsp->c_attr = svsp->sc_attr; - svsp->m_awm = svsp->sc_awm; - svsp->m_om = svsp->sc_om; - svsp->G0 = svsp->sc_G0; - svsp->G1 = svsp->sc_G1; - svsp->G2 = svsp->sc_G2; - svsp->G3 = svsp->sc_G3; - svsp->GL = svsp->sc_GL; - svsp->GR = svsp->sc_GR; - svsp->selchar = svsp->sc_sel; - svsp->vtsgr = svsp->sc_vtsgr; - } -} - -/*---------------------------------------------------------------------------* - * designate a character set as G0, G1, G2 or G3 for 94/96 char sets - *---------------------------------------------------------------------------*/ -void -vt_designate(struct video_state *svsp) -{ - u_short *ctp = NULL; - u_char ch; - - if(svsp->whichi == 1) - ch = svsp->which[0]; - else - { - int i; - - if(svsp->dld_id[0] == '\0') - return; - - if(!(((adaptor_type == EGA_ADAPTOR) || - (adaptor_type == VGA_ADAPTOR)) && - (vgacs[svsp->vga_charset].secondloaded))) - { - return; - } - - for(i = (svsp->whichi)-1; i >= 0; i--) - { - if(svsp->which[i] != svsp->dld_id[i]) - return; - } -#ifdef HAVECSE_DOWNLOADABLE - ctp = cse_downloadable; - swcsp(svsp, ctp); -#endif - return; - } - - if(((adaptor_type == EGA_ADAPTOR) || (adaptor_type == VGA_ADAPTOR)) && - (vgacs[svsp->vga_charset].secondloaded)) - { - if((ch == svsp->dld_id[0]) && (svsp->dld_id[1] == '\0')) - { -#ifdef HAVECSE_DOWNLOADABLE - ctp = cse_downloadable; - swcsp(svsp, ctp); -#endif - return; - } - - switch(ch) - { - case 'A': /* British or ISO-Latin-1 */ - switch(svsp->state) - { - case STATE_BROPN: /* designate G0 */ - case STATE_BRCLO: /* designate G1 */ - case STATE_STAR: /* designate G2 */ - case STATE_PLUS: /* designate G3 */ -#ifdef HAVECSE_BRITISH - ctp = cse_british; -#endif - break; - - case STATE_MINUS: /* designate G1 (96)*/ - case STATE_DOT: /* designate G2 (96)*/ - case STATE_SLASH: /* designate G3 (96)*/ -#ifdef HAVECSE_ISOLATIN - ctp = cse_isolatin; -#endif - break; - } - break; - - case 'B': /* USASCII */ -#ifdef HAVECSE_ASCII - ctp = cse_ascii; -#endif - break; - - case 'C': /* Finnish */ - case '5': /* Finnish */ -#ifdef HAVECSE_FINNISH - ctp = cse_finnish; -#endif - break; - - case 'E': /* Norwegian/Danish */ - case '6': /* Norwegian/Danish */ -#ifdef HAVECSE_NORWEGIANDANISH - ctp = cse_norwegiandanish; -#endif - break; - - case 'H': /* Swedish */ - case '7': /* Swedish */ -#ifdef HAVECSE_SWEDISH - ctp = cse_swedish; -#endif - break; - - case 'K': /* German */ -#ifdef HAVECSE_GERMAN - ctp = cse_german; -#endif - break; - - case 'Q': /* French Canadien */ -#ifdef HAVECSE_FRENCHCANADA - ctp = cse_frenchcanada; -#endif - break; - - case 'R': /* French */ -#ifdef HAVECSE_FRENCH - ctp = cse_french; -#endif - break; - - case 'Y': /* Italian */ -#ifdef HAVECSE_ITALIAN - ctp = cse_italian; -#endif - break; - - case 'Z': /* Spanish */ -#ifdef HAVECSE_SPANISH - ctp = cse_spanish; -#endif - break; - - case '0': /* special graphics */ -#ifdef HAVECSE_SPECIAL - ctp = cse_special; -#endif - break; - - case '1': /* alternate ROM */ -#ifdef HAVECSE_ALTERNATEROM1 - ctp = cse_alternaterom1; -#endif - break; - - case '2': /* alt ROM, spec graphics */ -#ifdef HAVECSE_ALTERNATEROM2 - ctp = cse_alternaterom2; -#endif - break; - - case '3': /* HP Roman 8, upper 128 chars*/ -#ifdef HAVECSE_ROMAN8 - ctp = cse_roman8; -#endif - break; - - case '4': /* Dutch */ -#ifdef HAVECSE_DUTCH - ctp = cse_dutch; -#endif - break; - - case '<': /* DEC Supplemental */ -#ifdef HAVECSE_SUPPLEMENTAL - ctp = cse_supplemental; -#endif - break; - - case '=': /* Swiss */ -#ifdef HAVECSE_SWISS - ctp = cse_swiss; -#endif - break; - - case '>': /* DEC Technical */ -#ifdef HAVECSE_TECHNICAL - ctp = cse_technical; -#endif - break; - - default: - break; - } - } - else - { - switch(ch) - { - case 'A': /* British or ISO-Latin-1 */ - switch(svsp->state) - { - case STATE_BROPN: /* designate G0 */ - case STATE_BRCLO: /* designate G1 */ - case STATE_STAR: /* designate G2 */ - case STATE_PLUS: /* designate G3 */ -#ifdef HAVECSD_BRITISH - ctp = csd_british; -#endif - break; - - case STATE_MINUS: /* designate G1 (96)*/ - case STATE_DOT: /* designate G2 (96)*/ - case STATE_SLASH: /* designate G3 (96)*/ -#ifdef HAVECSD_ISOLATIN - ctp = csd_isolatin; -#endif - break; - } - break; - - case 'B': /* USASCII */ -#ifdef HAVECSD_ASCII - ctp = csd_ascii; -#endif - break; - - case 'C': /* Finnish */ - case '5': /* Finnish */ -#ifdef HAVECSD_FINNISH - ctp = csd_finnish; -#endif - break; - - case 'E': /* Norwegian/Danish */ - case '6': /* Norwegian/Danish */ -#ifdef HAVECSD_NORWEGIANDANISH - ctp = csd_norwegiandanish; -#endif - break; - - case 'H': /* Swedish */ - case '7': /* Swedish */ -#ifdef HAVECSD_SWEDISH - ctp = csd_swedish; -#endif - break; - - case 'K': /* German */ -#ifdef HAVECSD_GERMAN - ctp = csd_german; -#endif - break; - - case 'Q': /* French Canadien */ -#ifdef HAVECSD_FRENCHCANADA - ctp = csd_frenchcanada; -#endif - break; - - case 'R': /* French */ -#ifdef HAVECSD_FRENCH - ctp = csd_french; -#endif - break; - - case 'Y': /* Italian */ -#ifdef HAVECSD_ITALIAN - ctp = csd_italian; -#endif - break; - - case 'Z': /* Spanish */ -#ifdef HAVECSD_SPANISH - ctp = csd_spanish; -#endif - break; - - case '0': /* special graphics */ -#ifdef HAVECSD_SPECIAL - ctp = csd_special; -#endif - break; - - case '1': /* alternate ROM */ -#ifdef HAVECSD_ALTERNATEROM1 - ctp = csd_alternaterom1; -#endif - break; - - case '2': /* alt ROM, spec graphics */ -#ifdef HAVECSD_ALTERNATEROM2 - ctp = csd_alternaterom2; -#endif - break; - - case '3': /* HP Roman 8, upper 128 chars*/ -#ifdef HAVECSD_ROMAN8 - ctp = csd_roman8; -#endif - break; - - case '4': /* Dutch */ -#ifdef HAVECSD_DUTCH - ctp = csd_dutch; -#endif - break; - - case '<': /* DEC Supplemental */ -#ifdef HAVECSD_SUPPLEMENTAL - ctp = csd_supplemental; -#endif - break; - - case '=': /* Swiss */ -#ifdef HAVECSD_SWISS - ctp = csd_swiss; -#endif - break; - - case '>': /* DEC Technical */ -#ifdef HAVECSD_TECHNICAL - ctp = csd_technical; -#endif - break; - - default: - break; - } - } - swcsp(svsp, ctp); -} - -/*---------------------------------------------------------------------------* - * device attributes - *---------------------------------------------------------------------------*/ -void -vt_da(struct video_state *svsp) -{ - static u_char *response = (u_char *)DA_VT220; - - svsp->report_chars = response; - svsp->report_count = 18; - respond(svsp); -} - -/*---------------------------------------------------------------------------* - * screen alignment display - *---------------------------------------------------------------------------*/ -void -vt_aln(struct video_state *svsp) -{ - register int i; - - svsp->cur_offset = 0; - svsp->col = 0; - - for(i=0; i < (svsp->screen_rows*svsp->maxcol); i++) - { - *(svsp->Crtat + svsp->cur_offset) = user_attr | 'E'; - vt_selattr(svsp); - svsp->cur_offset++; - svsp->col++; - } - - svsp->cur_offset = 0; /* reset everything ! */ - svsp->col = 0; - svsp->row = 0; -} - -/*---------------------------------------------------------------------------* - * request terminal parameters - *---------------------------------------------------------------------------*/ -void -vt_reqtparm(struct video_state *svsp) -{ - static u_char *answr = (u_char *)"\033[3;1;1;120;120;1;0x"; - - svsp->report_chars = answr; - svsp->report_count = 20; - respond(svsp); -} - -/*---------------------------------------------------------------------------* - * invoke selftest - *---------------------------------------------------------------------------*/ -void -vt_tst(struct video_state *svsp) -{ - clear_dld(svsp); -} - -/*---------------------------------------------------------------------------* - * device status reports - *---------------------------------------------------------------------------*/ -void -vt_dsr(struct video_state *svsp) -{ - static u_char *answr = (u_char *)"\033[0n"; - static u_char *panswr = (u_char *)"\033[?13n"; /* Printer Unattached */ - static u_char *udkanswr = (u_char *)"\033[?21n"; /* UDK Locked */ - static u_char *langanswr = (u_char *)"\033[?27;1n"; /* North American*/ - static u_char buffer[16]; - int i = 0; - - switch(svsp->parms[0]) - { - case 5: /* return status */ - svsp->report_chars = answr; - svsp->report_count = 4; - respond(svsp); - break; - - case 6: /* return cursor position */ - buffer[i++] = 0x1b; - buffer[i++] = '['; - if((svsp->row+1) > 10) - buffer[i++] = ((svsp->row+1) / 10) + '0'; - buffer[i++] = ((svsp->row+1) % 10) + '0'; - buffer[i++] = ';'; - if((svsp->col+1) > 10) - buffer[i++] = ((svsp->col+1) / 10) + '0'; - buffer[i++] = ((svsp->col+1) % 10) + '0'; - buffer[i++] = 'R'; - buffer[i++] = '\0'; - - svsp->report_chars = buffer; - svsp->report_count = i; - respond(svsp); - break; - - case 15: /* return printer status */ - svsp->report_chars = panswr; - svsp->report_count = 6; - respond(svsp); - break; - - case 25: /* return udk status */ - svsp->report_chars = udkanswr; - svsp->report_count = 6; - respond(svsp); - break; - - case 26: /* return language status */ - svsp->report_chars = langanswr; - svsp->report_count = 8; - respond(svsp); - break; - - default: /* nothing else valid */ - break; - } -} - -/*---------------------------------------------------------------------------* - * IL - insert line - *---------------------------------------------------------------------------*/ -void -vt_il(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if((svsp->row >= svsp->scrr_beg) && (svsp->row <= svsp->scrr_end)) - { - if(p <= 0) - p = 1; - else if(p > svsp->scrr_end - svsp->row) - p = svsp->scrr_end - svsp->row; - - svsp->cur_offset -= svsp->col; - svsp->col = 0; - if(svsp->row == svsp->scrr_beg) - roll_down(svsp, p); - else - { - bcopy(svsp->Crtat + svsp->cur_offset, - svsp->Crtat + svsp->cur_offset + (p * svsp->maxcol), - svsp->maxcol * (svsp->scrr_end-svsp->row+1-p) * CHR ); - - fillw(user_attr | ' ', - svsp->Crtat + svsp->cur_offset, - p * svsp->maxcol); - } - } -} - -/*---------------------------------------------------------------------------* - * ICH - insert character - *---------------------------------------------------------------------------*/ -void -vt_ic(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(p <= 0) - p = 1; - else if(p > svsp->maxcol-svsp->col) - p = svsp->maxcol-svsp->col; - - while(p--) - { - bcopy((svsp->Crtat + svsp->cur_offset), - (svsp->Crtat + svsp->cur_offset) + 1, - (((svsp->maxcol)-1)-svsp->col) * CHR); - - *(svsp->Crtat + svsp->cur_offset) = user_attr | ' '; - vt_selattr(svsp); - } -} - -/*---------------------------------------------------------------------------* - * DL - delete line - *---------------------------------------------------------------------------*/ -void -vt_dl(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if((svsp->row >= svsp->scrr_beg) && (svsp->row <= svsp->scrr_end)) - { - if(p <= 0) - p = 1; - else if(p > svsp->scrr_end - svsp->row) - p = svsp->scrr_end - svsp->row; - - svsp->cur_offset -= svsp->col; - svsp->col = 0; - - if(svsp->row == svsp->scrr_beg) - roll_up(svsp, p); - else - { - bcopy(svsp->Crtat + svsp->cur_offset + (p * svsp->maxcol), - svsp->Crtat + svsp->cur_offset, - svsp->maxcol * (svsp->scrr_end-svsp->row+1-p) * CHR ); - - fillw(user_attr | ' ', - svsp->Crtat + ((svsp->scrr_end-p+1) * svsp->maxcol), - p * svsp->maxcol); - } - } -} - -/*---------------------------------------------------------------------------* - * DCH - delete character - *---------------------------------------------------------------------------*/ -void -vt_dch(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(p <= 0) - p = 1; - else if(p > svsp->maxcol-svsp->col) - p = svsp->maxcol-svsp->col; - - while(p--) - { - bcopy((svsp->Crtat + svsp->cur_offset)+1, - (svsp->Crtat + svsp->cur_offset), - (((svsp->maxcol)-1) - svsp->col)* CHR ); - - *((svsp->Crtat + svsp->cur_offset) + - ((svsp->maxcol)-1)-svsp->col) = user_attr | ' '; - } -} - -/*---------------------------------------------------------------------------* - * scroll up - *---------------------------------------------------------------------------*/ -void -vt_su(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(p <= 0) - p = 1; - else if(p > svsp->screen_rows-1) - p = svsp->screen_rows-1; - - roll_up(svsp, p); -} - -/*---------------------------------------------------------------------------* - * scroll down - *---------------------------------------------------------------------------*/ -void -vt_sd(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(p <= 0) - p = 1; - else if(p > svsp->screen_rows-1) - p = svsp->screen_rows-1; - - roll_down(svsp, p); -} - -/*---------------------------------------------------------------------------* - * ECH - erase character - *---------------------------------------------------------------------------*/ -void -vt_ech(struct video_state *svsp) -{ - register int p = svsp->parms[0]; - - if(p <= 0) - p = 1; - else if(p > svsp->maxcol-svsp->col) - p = svsp->maxcol-svsp->col; - - fillw(user_attr | ' ', (svsp->Crtat + svsp->cur_offset), p); -} - -/*---------------------------------------------------------------------------* - * media copy (NO PRINTER AVAILABLE IN KERNEL ...) - *---------------------------------------------------------------------------*/ -void -vt_mc(struct video_state *svsp) -{ -} - -/*---------------------------------------------------------------------------* - * Device Control String State Machine Entry for: - * - * DECUDK - user-defined keys and - * DECDLD - downloadable charset - * - *---------------------------------------------------------------------------*/ -void -vt_dcsentry(U_char ch, struct video_state *svsp) -{ - switch(svsp->dcs_state) - { - case DCS_INIT: - switch(ch) - { - case '0': - case '1': - case '2': - case '3': - case '4': - case '5': - case '6': - case '7': - case '8': - case '9': /* parameters */ - svsp->parms[svsp->parmi] *= 10; - svsp->parms[svsp->parmi] += (ch -'0'); - break; - - case ';': /* next parameter */ - svsp->parmi = - (svsp->parmi+1 < MAXPARMS) ? - svsp->parmi+1 : svsp->parmi; - break; - - case '|': /* DECUDK */ - svsp->transparent = 1; - init_udk(svsp); - svsp->dcs_state = DCS_AND_UDK; - break; - - case '{': /* DECDLD */ - svsp->transparent = 1; - init_dld(svsp); - svsp->dcs_state = DCS_DLD_DSCS; - break; - - default: /* failsafe */ - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - } - break; - - case DCS_AND_UDK: /* DCS ... | */ - switch(ch) - { - case '0': - case '1': - case '2': - case '3': - case '4': - case '5': - case '6': - case '7': - case '8': - case '9': /* fkey number */ - svsp->udk_fnckey *= 10; - svsp->udk_fnckey += (ch -'0'); - break; - - case '/': /* Key */ - svsp->dcs_state = DCS_UDK_DEF; - break; - - case 0x1b: /* ESC */ - svsp->dcs_state = DCS_UDK_ESC; - break; - - default: - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - } - break; - - case DCS_UDK_DEF: /* DCS ... | fnckey / */ - switch(ch) - { - case '0': - case '1': - case '2': - case '3': - case '4': - case '5': - case '6': - case '7': - case '8': - case '9': - if(svsp->udk_deflow) /* low nibble */ - { - svsp->udk_def[svsp->udk_defi] |= (ch -'0'); - svsp->udk_deflow = 0; - svsp->udk_defi = (svsp->udk_defi+1 >= MAXUDKDEF) ? - svsp->udk_defi : svsp->udk_defi+1; - } - else /* high nibble */ - { - svsp->udk_def[svsp->udk_defi] = ((ch -'0') << 4); - svsp->udk_deflow = 1; - } - break; - - case 'a': - case 'b': - case 'c': - case 'd': - case 'e': - case 'f': - if(svsp->udk_deflow) /* low nibble */ - { - svsp->udk_def[svsp->udk_defi] |= (ch - 'a' + 10); - svsp->udk_deflow = 0; - svsp->udk_defi = (svsp->udk_defi+1 >= MAXUDKDEF) ? - svsp->udk_defi : svsp->udk_defi+1; - } - else /* high nibble */ - { - svsp->udk_def[svsp->udk_defi] = ((ch - 'a' + 10) << 4); - svsp->udk_deflow = 1; - } - break; - - - - case 'A': - case 'B': - case 'C': - case 'D': - case 'E': - case 'F': - if(svsp->udk_deflow) /* low nibble */ - { - svsp->udk_def[svsp->udk_defi] |= (ch - 'A' + 10); - svsp->udk_deflow = 0; - svsp->udk_defi = (svsp->udk_defi+1 >= MAXUDKDEF) ? - svsp->udk_defi : svsp->udk_defi+1; - } - else /* high nibble */ - { - svsp->udk_def[svsp->udk_defi] = ((ch - 'A' + 10) << 4); - svsp->udk_deflow = 1; - } - break; - - case ';': /* next function key */ - vt_udk(svsp); - svsp->dcs_state = DCS_AND_UDK; - break; - - case 0x1b: /* ESC */ - svsp->dcs_state = DCS_UDK_ESC; - break; - - default: - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - } - break; - - case DCS_UDK_ESC: /* DCS ... | fkey/def ... ESC */ - switch(ch) - { - case '\\': /* ST */ - vt_udk(svsp); - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - - default: - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - } - break; - - - case DCS_DLD_DSCS: /* got DCS ... { */ - if(ch >= ' ' && ch <= '/') /* intermediates ... */ - { - svsp->dld_dscs[svsp->dld_dscsi] = ch; - svsp->dld_id[svsp->dld_dscsi] = ch; - if(svsp->dld_dscsi >= DSCS_LENGTH) - { - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - svsp->dld_id[0] = '\0'; - } - else - { - svsp->dld_dscsi++; - } - } - else if(ch >= '0' && ch <= '~') /* final .... */ - { - svsp->dld_dscs[svsp->dld_dscsi] = ch; - svsp->dld_id[svsp->dld_dscsi++] = ch; - svsp->dld_id[svsp->dld_dscsi] = '\0'; - svsp->dcs_state = DCS_DLD_DEF; - } - else - { - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - svsp->dld_id[0] = '\0'; - } - break; - - case DCS_DLD_DEF: /* DCS ... { dscs */ - switch(ch) - { - case 0x1b: /* ESC */ - svsp->dcs_state = DCS_DLD_ESC; - break; - - case '/': /* sixel upper / lower divider */ - svsp->dld_sixel_lower = 1; - break; - - case ';': /* character divider */ - vt_dld(svsp); - svsp->parms[1]++; /* next char */ - break; - - default: - if (svsp->dld_sixel_lower) - { - if(ch >= '?' && ch <= '~') - svsp->sixel.lower[svsp->dld_sixelli] = ch - '?'; - svsp->dld_sixelli = - (svsp->dld_sixelli+1 < MAXSIXEL) ? - svsp->dld_sixelli+1 : svsp->dld_sixelli; - } - else - { - if(ch >= '?' && ch <= '~') - svsp->sixel.upper[svsp->dld_sixelui] = ch - '?'; - svsp->dld_sixelui = - (svsp->dld_sixelui+1 < MAXSIXEL) ? - svsp->dld_sixelui+1 : svsp->dld_sixelui; - } - break; - } - break; - - case DCS_DLD_ESC: /* DCS ... { dscs ... / ... ESC */ - switch(ch) - { - case '\\': /* String Terminator ST */ - vt_dld(svsp); - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - - default: - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - svsp->dld_id[0] = '\0'; - break; - } - break; - - default: - svsp->transparent = 0; - svsp->state = STATE_INIT; - svsp->dcs_state = DCS_INIT; - break; - } -} - -/*---------------------------------------------------------------------------* - * User Defineable Keys - *---------------------------------------------------------------------------*/ -void -vt_udk(struct video_state *svsp) -{ - int key, start, max, i; - int usedff = 0; - - if(svsp->parms[0] != 1) /* clear all ? */ - { - vt_clearudk(svsp); - svsp->parms[0] = 1; - } - - if(svsp->udk_fnckey < 17 || svsp->udk_fnckey > 34) - { - init_udk(svsp); - return; - } - - key = svsp->udk_fnckey - 17; /* index into table */ - - if(svsp->ukt.length[key] == 0) /* never used ? */ - { - if(svsp->udkff < MAXUDKDEF-2) /* space available ? */ - { - start = svsp->udkff; /* next sequential */ - max = MAXUDKDEF - svsp->udkff; /* space available */ - svsp->ukt.first[key] = start; /* start entry */ - usedff = 1; /* flag to update later */ - } - else /* no space */ - { - init_udk(svsp); - return; - } - } - else /* in use, redefine */ - { - start = svsp->ukt.first[key]; /* start entry */ - max = svsp->ukt.length[key]; /* space available */ - } - - if(max < 2) /* hmmm .. */ - { - init_udk(svsp); - return; - } - - max--; /* adjust for tailing '\0' */ - - for(i = 0; i < max && i < svsp->udk_defi; i++) - svsp->udkbuf[start++] = svsp->udk_def[i]; - - svsp->udkbuf[start] = '\0'; /* make it a string, see pcvt_kbd.c */ - svsp->ukt.length[key] = i+1; /* count for tailing '\0' */ - if(usedff) - svsp->udkff += (i+2); /* new start location */ - - init_udk(svsp); -} - -/*---------------------------------------------------------------------------* - * clear all User Defineable Keys - *---------------------------------------------------------------------------*/ -void -vt_clearudk(struct video_state *svsp) -{ - register int i; - - for(i = 0; i < MAXUDKEYS; i++) - { - svsp->ukt.first[i] = 0; - svsp->ukt.length[i] = 0; - } - svsp->udkff = 0; -} - -/*---------------------------------------------------------------------------* - * Down line LoaDable Fonts - *---------------------------------------------------------------------------*/ -void -vt_dld(struct video_state *svsp) -{ - unsigned char vgacharset; - unsigned char vgachar[16]; - unsigned char vgacharb[16]; - - if(vgacs[svsp->vga_charset].secondloaded) - vgacharset = vgacs[svsp->vga_charset].secondloaded; - else - return; - - svsp->parms[1] = (svsp->parms[1] < 1) ? 1 : - ((svsp->parms[1] > 0x7E) ? 0x7E : svsp->parms[1]); - - if(svsp->parms[2] != 1) /* Erase all characters ? */ - { - clear_dld(svsp); - svsp->parms[2] = 1; /* Only erase all characters once per sequence */ - } - - sixel_vga(&(svsp->sixel),vgachar); - - switch(vgacs[vgacharset].char_scanlines & 0x1F) - { - case 7: - vga10_vga8(vgachar,vgacharb); - break; - - case 9: - default: - vga10_vga10(vgachar,vgacharb); - break; - - case 13: - vga10_vga14(vgachar,vgacharb); - break; - - case 15: - vga10_vga16(vgachar,vgacharb); - break; - } - - loadchar(vgacharset, svsp->parms[1] + 0xA0, 16, vgacharb); - - init_dld(svsp); -} - -/*---------------------------------------------------------------------------* - * select compatibility level - *---------------------------------------------------------------------------*/ -void -vt_scl(struct video_state *svsp) -{ - /* poor man's scl. normally this also enables/disables the editing - * keypad and the available character sets. we only enable/disable - * support for C1 control codes. - */ - - register int p0, p1; - - p0 = svsp->parms[0]; - p1 = svsp->parms[1]; - - vt_str(svsp); - - switch(p0) - { - case 61: - svsp->sevenbit = 1; - break; - case 62: - /* case 63: vt320 */ - default: - if(p1 != 1) - svsp->C1_ctls = 1; - break; - } -} - -/*---------------------------------------------------------------------------* - * select character attributes - *---------------------------------------------------------------------------*/ -void -vt_sca(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 1: - svsp->selchar = 1; - break; - case 0: - case 2: - default: - svsp->selchar = 0; - break; - } -} - -/*---------------------------------------------------------------------------* - * initalize selective attribute bit array - *---------------------------------------------------------------------------*/ -void -vt_initsel(struct video_state *svsp) -{ - register int i; - - for(i = 0;i < MAXDECSCA;i++) - svsp->decsca[i] = 0; -} - -/*---------------------------------------------------------------------------* - * DECSEL - selective erase in line - *---------------------------------------------------------------------------*/ -void -vt_sel(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: - selective_erase(svsp, (svsp->Crtat + svsp->cur_offset), - svsp->maxcol-svsp->col); - break; - - case 1: - selective_erase(svsp, (svsp->Crtat + svsp->cur_offset)- - svsp->col, svsp->col + 1); - break; - - case 2: - selective_erase(svsp, (svsp->Crtat + svsp->cur_offset)- - svsp->col, svsp->maxcol); - break; - } -} - -/*---------------------------------------------------------------------------* - * DECSED - selective erase in display - *---------------------------------------------------------------------------*/ -void -vt_sed(struct video_state *svsp) -{ - switch(svsp->parms[0]) - { - case 0: - selective_erase(svsp, (svsp->Crtat + svsp->cur_offset), - svsp->Crtat + (svsp->maxcol * svsp->screen_rows) - - (svsp->Crtat + svsp->cur_offset)); - break; - - case 1: - selective_erase(svsp, svsp->Crtat, - (svsp->Crtat + svsp->cur_offset) - svsp->Crtat + 1 ); - break; - - case 2: - selective_erase(svsp, svsp->Crtat, - svsp->maxcol * svsp->screen_rows); - break; - } -} - -/*---------------------------------------------------------------------------* - * scroll screen n lines up - *---------------------------------------------------------------------------*/ -void -roll_up(struct video_state *svsp, int n) -{ - -#if (PCVT_NOFASTSCROLL==0) - - if(svsp->scrr_beg == 0 && /* if scroll region is whole screen */ - svsp->scrr_len == svsp->screen_rows && - (svsp != vsp || /* and either running in memory */ - (svsp->screen_rows == svsp->screen_rowsize /* or no fkeys */ - -#if (PCVT_MDAFASTSCROLL==0) - && adaptor_type != MDA_ADAPTOR /* and not on MDA/Hercules */ -#endif - - ))) - - { - u_short *Memory = - (vsp != svsp || (vsp->vt_status & VT_GRAFX)) ? - svsp->Memory : Crtat; - - if(svsp->Crtat > (Memory + (svsp->screen_rows - n) * - svsp->maxcol)) - { - bcopy(svsp->Crtat + svsp->maxcol * n, Memory, - svsp->maxcol * (svsp->screen_rows - n) * CHR); - - svsp->Crtat = Memory; - } - else - { - svsp->Crtat += n * svsp->maxcol; - } - } - else -#endif - { - bcopy( svsp->Crtat + ((svsp->scrr_beg + n) * svsp->maxcol), - svsp->Crtat + (svsp->scrr_beg * svsp->maxcol), - svsp->maxcol * (svsp->scrr_len - n) * CHR ); - } - - fillw( user_attr | ' ', - svsp->Crtat + ((svsp->scrr_end - n + 1) * svsp->maxcol), - n * svsp->maxcol); - -/*XXX*/ if(svsp->scroll_lock && svsp->openf && curproc) - tsleep((caddr_t)&(svsp->scroll_lock), PUSER, "scrlck", 0); -} - -/*---------------------------------------------------------------------------* - * scroll screen n lines down - *---------------------------------------------------------------------------*/ -static void -roll_down(struct video_state *svsp, int n) -{ - -#if (PCVT_NOFASTSCROLL==0) - - if(svsp->scrr_beg == 0 && /* if scroll region is whole screen */ - svsp->scrr_len == svsp->screen_rows && - (svsp != vsp || /* and either running in memory */ - (svsp->screen_rows == svsp->screen_rowsize /* or no fkeys */ - -#if (PCVT_MDAFASTSCROLL==0) - && adaptor_type != MDA_ADAPTOR /* and not on MDA/Hercules */ -#endif - - ))) - - { - u_short *Memory = - (vsp != svsp || (vsp->vt_status & VT_GRAFX)) ? - svsp->Memory : Crtat; - - if (svsp->Crtat < (Memory + n * svsp->maxcol)) - { - bcopy(svsp->Crtat, - Memory + svsp->maxcol * (svsp->screen_rows + n), - svsp->maxcol * (svsp->screen_rows - n) * CHR); - - svsp->Crtat = Memory + svsp->maxcol * svsp->screen_rows; - } - else - { - svsp->Crtat -= n * svsp->maxcol; - } - } - else -#endif - { - bcopy( svsp->Crtat + (svsp->scrr_beg * svsp->maxcol), - svsp->Crtat + ((svsp->scrr_beg + n) * svsp->maxcol), - svsp->maxcol * (svsp->scrr_len - n) * CHR ); - } - - fillw( user_attr | ' ', - svsp->Crtat + (svsp->scrr_beg * svsp->maxcol), - n * svsp->maxcol); - -/*XXX*/ if(svsp->scroll_lock && svsp->openf && curproc) - tsleep((caddr_t)&(svsp->scroll_lock), PUSER, "scrlck", 0); -} - -/*---------------------------------------------------------------------------* - * switch charset pointers - *---------------------------------------------------------------------------*/ -static void -swcsp(struct video_state *svsp, u_short *ctp) -{ - if(ctp == NULL) - return; - - /* update GL or GR if the designated charset is currently displayed */ - - switch(svsp->state) - { - case STATE_BROPN: /* designate G0 */ - if (svsp->GL == svsp->G0) - svsp->GL = ctp; - if (svsp->GR == svsp->G0) - svsp->GR = ctp; - svsp->G0 = ctp; - break; - - case STATE_BRCLO: /* designate G1 */ - case STATE_MINUS: /* designate G1 (96) */ - if (svsp->GL == svsp->G1) - svsp->GL = ctp; - if (svsp->GR == svsp->G1) - svsp->GR = ctp; - svsp->G1 = ctp; - break; - - case STATE_STAR: /* designate G2 */ - case STATE_DOT: /* designate G2 (96) */ - if (svsp->GL == svsp->G2) - svsp->GL = ctp; - if (svsp->GR == svsp->G2) - svsp->GR = ctp; - svsp->G2 = ctp; - break; - - case STATE_PLUS: /* designate G3 */ - case STATE_SLASH: /* designate G3 (96) */ - if (svsp->GL == svsp->G3) - svsp->GL = ctp; - if (svsp->GR == svsp->G3) - svsp->GR = ctp; - svsp->G3 = ctp; - break; - } -} - -/*---------------------------------------------------------------------------* - * process terminal responses - *---------------------------------------------------------------------------*/ -static void -respond(struct video_state *svsp) -{ - if(!(svsp->openf)) /* are we opened ? */ - return; - - while (*svsp->report_chars && svsp->report_count > 0) - { - (*linesw[svsp->vs_tty->t_line].l_rint) - (*svsp->report_chars++ & 0xff, svsp->vs_tty); - svsp->report_count--; - } -} - -/*---------------------------------------------------------------------------* - * Initialization for User Defineable Keys - *---------------------------------------------------------------------------*/ -static void -init_udk(struct video_state *svsp) -{ - svsp->udk_defi = 0; - svsp->udk_deflow = 0; - svsp->udk_fnckey = 0; -} - -/*---------------------------------------------------------------------------* - * Clear loaded downloadable (DLD) character set - *---------------------------------------------------------------------------*/ -static void -clear_dld(struct video_state *svsp) -{ - register int i; - unsigned char vgacharset; - unsigned char vgachar[16]; - - if(vgacs[svsp->vga_charset].secondloaded) - vgacharset = vgacs[svsp->vga_charset].secondloaded; - else - return; - - for(i=0;i < 16;i++) /* A zeroed character, vt220 has inverted '?' */ - vgachar[i] = 0x00; - - for(i=1;i <= 94;i++) /* Load (erase) all characters */ - loadchar(vgacharset, i + 0xA0, 16, vgachar); -} - -/*---------------------------------------------------------------------------* - * Initialization for Down line LoaDable Fonts - *---------------------------------------------------------------------------*/ -static void -init_dld(struct video_state *svsp) -{ - register int i; - - svsp->dld_dscsi = 0; - svsp->dld_sixel_lower = 0; - svsp->dld_sixelli = 0; - svsp->dld_sixelui = 0; - - for(i = 0;i < MAXSIXEL;i++) - svsp->sixel.lower[i] = svsp->sixel.upper[i] = 0; -} - -/*---------------------------------------------------------------------------* - * selective erase a region - *---------------------------------------------------------------------------*/ -static void -selective_erase(struct video_state *svsp, u_short *pcrtat, int length) -{ - register int i, j; - - for(j = pcrtat - svsp->Crtat, i = 0;i < length;i++,pcrtat++) - { - if(!(svsp->decsca[INT_INDEX(j+i)] & (1 << BIT_INDEX(j+i)))) - { - *pcrtat &= 0xFF00; /* Keep the video character attributes */ - *pcrtat += ' '; /* Erase the character */ - } - } -} - -/* ------------------------- E O F ------------------------------------------*/ -