Implement support to dynamically change wscons console and kernel colors.
Two new ioctls are added to the wsdisplay device, named WSDISPLAY_GMSGATTRS
and WSDISPLAY_SMSGATTRS, used to retrieve the actual values and set them,
respectively (the name, if you are wondering, comes from "message attributes").
A new emulop is added to the underlying display driver (only vga, for now)
which sets the new attribute for the whole screen, without having to clear
it. This is optional, which means that this also works with other drivers
that don't have this new operation.
Five new kernel options have been added, although only documented in
i386 kernels (for now):
- WSDISPLAY_CUSTOM_OUTPUT, which enables the ioctls described above to
change the colors dynamically from userland. This is enabled by default
in the GENERIC kernel (as well as others) but disabled on all INSTALL*
kernels (as this feature is useless there).
- WS_DEFAULT_COLATTR, WS_DEFAULT_MONOATTR, WS_DEFAULT_BG and WS_DEFAULT_FG,
which specify the default colors for the console at boot time. These have
the same meaning as the (already existing) WS_KERNEL_* variables.
wsconsctl is modified to add msg.default.{attrs,bg,fg} and
msg.kernel.{attrs,bg,fg} to the display part, so that colors can be changed
after boot.
Tested on NetBSD/i386 with vga (and vga in mono mode), and on NetBSD/mac68k.
No objections in tech-kern@.
2004-07-28 16:34:02 +04:00
|
|
|
/* $NetBSD: wsemul_vt100var.h,v 1.9 2004/07/28 12:34:05 jmmv Exp $ */
|
1998-06-20 23:17:47 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 1998
|
|
|
|
* Matthias Drochner. 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.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define VT100_EMUL_NARGS 10 /* max # of args to a command */
|
|
|
|
|
|
|
|
struct wsemul_vt100_emuldata {
|
|
|
|
const struct wsdisplay_emulops *emulops;
|
|
|
|
void *emulcookie;
|
|
|
|
int scrcapabilities;
|
|
|
|
u_int nrows, ncols, crow, ccol;
|
Implement support to dynamically change wscons console and kernel colors.
Two new ioctls are added to the wsdisplay device, named WSDISPLAY_GMSGATTRS
and WSDISPLAY_SMSGATTRS, used to retrieve the actual values and set them,
respectively (the name, if you are wondering, comes from "message attributes").
A new emulop is added to the underlying display driver (only vga, for now)
which sets the new attribute for the whole screen, without having to clear
it. This is optional, which means that this also works with other drivers
that don't have this new operation.
Five new kernel options have been added, although only documented in
i386 kernels (for now):
- WSDISPLAY_CUSTOM_OUTPUT, which enables the ioctls described above to
change the colors dynamically from userland. This is enabled by default
in the GENERIC kernel (as well as others) but disabled on all INSTALL*
kernels (as this feature is useless there).
- WS_DEFAULT_COLATTR, WS_DEFAULT_MONOATTR, WS_DEFAULT_BG and WS_DEFAULT_FG,
which specify the default colors for the console at boot time. These have
the same meaning as the (already existing) WS_KERNEL_* variables.
wsconsctl is modified to add msg.default.{attrs,bg,fg} and
msg.kernel.{attrs,bg,fg} to the display part, so that colors can be changed
after boot.
Tested on NetBSD/i386 with vga (and vga in mono mode), and on NetBSD/mac68k.
No objections in tech-kern@.
2004-07-28 16:34:02 +04:00
|
|
|
struct wsdisplay_msgattrs msgattrs;
|
1998-06-20 23:17:47 +04:00
|
|
|
long defattr; /* default attribute */
|
|
|
|
|
|
|
|
long kernattr; /* attribute for kernel output */
|
|
|
|
void *cbcookie;
|
|
|
|
#ifdef DIAGNOSTIC
|
|
|
|
int console;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
u_int state; /* processing state */
|
|
|
|
int flags;
|
1998-06-27 01:20:34 +04:00
|
|
|
#define VTFL_LASTCHAR 0x001 /* printed last char on line (below cursor) */
|
|
|
|
#define VTFL_INSERTMODE 0x002
|
|
|
|
#define VTFL_APPLKEYPAD 0x004
|
|
|
|
#define VTFL_APPLCURSOR 0x008
|
|
|
|
#define VTFL_DECOM 0x010 /* origin mode */
|
|
|
|
#define VTFL_DECAWM 0x020 /* auto wrap */
|
|
|
|
#define VTFL_CURSORON 0x040
|
|
|
|
#define VTFL_NATCHARSET 0x080 /* national replacement charset mode */
|
2003-04-20 03:28:46 +04:00
|
|
|
#define VTFL_SAVEDCURS 0x100 /* we have a saved cursor state */
|
2000-04-29 01:56:16 +04:00
|
|
|
long curattr, bkgdattr; /* currently used attribute */
|
1998-06-20 23:17:47 +04:00
|
|
|
int attrflags, fgcol, bgcol; /* properties of curattr */
|
1998-12-04 23:48:04 +03:00
|
|
|
u_int scrreg_startrow;
|
|
|
|
u_int scrreg_nrows;
|
1998-06-20 23:17:47 +04:00
|
|
|
char *tabs;
|
1998-06-27 01:20:34 +04:00
|
|
|
char *dblwid;
|
|
|
|
int dw;
|
|
|
|
|
|
|
|
int chartab0, chartab1;
|
|
|
|
u_int *chartab_G[4];
|
|
|
|
u_int *isolatin1tab, *decgraphtab, *dectechtab;
|
|
|
|
u_int *nrctab;
|
|
|
|
int sschartab; /* single shift */
|
1998-06-20 23:17:47 +04:00
|
|
|
|
|
|
|
int nargs;
|
1998-12-04 23:48:04 +03:00
|
|
|
u_int args[VT100_EMUL_NARGS]; /* numeric command args (CSI/DCS) */
|
1998-06-20 23:17:47 +04:00
|
|
|
|
1998-06-27 01:20:34 +04:00
|
|
|
char modif1; /* {>?} in VT100_EMUL_STATE_CSI */
|
|
|
|
char modif2; /* {!"$&} in VT100_EMUL_STATE_CSI */
|
|
|
|
|
1998-12-04 23:48:04 +03:00
|
|
|
int designating; /* substate in VT100_EMUL_STATE_SCS* */
|
1998-06-20 23:17:47 +04:00
|
|
|
|
|
|
|
int dcstype; /* substate in VT100_EMUL_STATE_STRING */
|
|
|
|
char *dcsarg;
|
|
|
|
int dcspos;
|
|
|
|
#define DCS_MAXLEN 256 /* ??? */
|
|
|
|
#define DCSTYPE_TABRESTORE 1 /* DCS2$t */
|
|
|
|
|
1998-12-04 23:48:04 +03:00
|
|
|
u_int savedcursor_row, savedcursor_col;
|
2000-04-29 01:56:16 +04:00
|
|
|
long savedattr, savedbkgdattr;
|
1998-06-27 01:20:34 +04:00
|
|
|
int savedattrflags, savedfgcol, savedbgcol;
|
|
|
|
int savedchartab0, savedchartab1;
|
|
|
|
u_int *savedchartab_G[4];
|
1998-06-20 23:17:47 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
/* some useful utility macros */
|
|
|
|
#define ARG(n) (edp->args[(n)])
|
1998-06-27 01:20:34 +04:00
|
|
|
#define DEF1_ARG(n) (ARG(n) ? ARG(n) : 1)
|
1998-08-13 00:04:12 +04:00
|
|
|
#define DEFx_ARG(n, x) (ARG(n) ? ARG(n) : (x))
|
1998-12-04 23:48:04 +03:00
|
|
|
/* the following two can be negative if we are outside the scrolling region */
|
|
|
|
#define ROWS_ABOVE ((int)edp->crow - (int)edp->scrreg_startrow)
|
|
|
|
#define ROWS_BELOW ((int)(edp->scrreg_startrow + edp->scrreg_nrows) \
|
|
|
|
- (int)edp->crow - 1)
|
1998-06-27 01:20:34 +04:00
|
|
|
#define CHECK_DW do { \
|
|
|
|
if (edp->dblwid && edp->dblwid[edp->crow]) { \
|
|
|
|
edp->dw = 1; \
|
|
|
|
if (edp->ccol > (edp->ncols >> 1) - 1) \
|
|
|
|
edp->ccol = (edp->ncols >> 1) - 1; \
|
|
|
|
} else \
|
|
|
|
edp->dw = 0; \
|
|
|
|
} while (0)
|
|
|
|
#define NCOLS (edp->ncols >> edp->dw)
|
|
|
|
#define COLS_LEFT (NCOLS - edp->ccol - 1)
|
|
|
|
#define COPYCOLS(f, t, n) (*edp->emulops->copycols)(edp->emulcookie, \
|
|
|
|
edp->crow, (f) << edp->dw, (t) << edp->dw, (n) << edp->dw)
|
|
|
|
#define ERASECOLS(f, n, a) (*edp->emulops->erasecols)(edp->emulcookie, \
|
|
|
|
edp->crow, (f) << edp->dw, (n) << edp->dw, a)
|
1998-06-20 23:17:47 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* response to primary DA request
|
|
|
|
* operating level: 61 = VT100, 62 = VT200, 63 = VT300
|
|
|
|
* extensions: 1 = 132 cols, 2 = printer port, 6 = selective erase,
|
|
|
|
* 7 = soft charset, 8 = UDKs, 9 = NRC sets
|
|
|
|
* VT100 = "033[?1;2c"
|
|
|
|
*/
|
|
|
|
#define WSEMUL_VT_ID1 "\033[?62;6c"
|
|
|
|
/*
|
|
|
|
* response to secondary DA request
|
|
|
|
* ident code: 24 = VT320
|
|
|
|
* firmware version
|
|
|
|
* hardware options: 0 = no options
|
|
|
|
*/
|
|
|
|
#define WSEMUL_VT_ID2 "\033[>24;20;0c"
|
|
|
|
|
2001-10-13 19:56:15 +04:00
|
|
|
void wsemul_vt100_reset(struct wsemul_vt100_emuldata *);
|
|
|
|
void wsemul_vt100_scrollup(struct wsemul_vt100_emuldata *, int);
|
|
|
|
void wsemul_vt100_scrolldown(struct wsemul_vt100_emuldata *, int);
|
|
|
|
void wsemul_vt100_ed(struct wsemul_vt100_emuldata *, int);
|
|
|
|
void wsemul_vt100_el(struct wsemul_vt100_emuldata *, int);
|
|
|
|
void wsemul_vt100_handle_csi(struct wsemul_vt100_emuldata *, u_char);
|
|
|
|
void wsemul_vt100_handle_dcs(struct wsemul_vt100_emuldata *);
|
1998-06-20 23:17:47 +04:00
|
|
|
|
2001-10-13 19:56:15 +04:00
|
|
|
int wsemul_vt100_translate(void *cookie, keysym_t, char **);
|
1998-06-27 01:20:34 +04:00
|
|
|
|
2001-10-13 19:56:15 +04:00
|
|
|
void vt100_initchartables(struct wsemul_vt100_emuldata *);
|
|
|
|
void vt100_setnrc(struct wsemul_vt100_emuldata *, int);
|