2 .\" Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH WSCONS 7D "May 26, 2006"
8 wscons \- workstation console
12 \fB#include <sys/strredir.h>\fR
17 \fBioctl\fR(\fIfd\fR, SRIOCSREDIR, \fItarget\fR);
22 \fBioctl\fR(\fIfd\fR, SRIOCISREDIR, \fItarget\fR);
28 The \fBwscons\fR workstation console consists of a workstation keyboard and
29 frame buffer that act together to emulate an \fBASCII\fR terminal. It includes
30 a redirection facility that allows I/O issued to the workstation console to be
31 diverted to a STREAMS device, enabling window systems to redirect output that
32 would otherwise appear directly on the frame buffer in corrupted form.
36 The \fBwscons\fR redirection facility maintains a list of devices that are
37 designated as redirection targets through the \fBSRIOCSREDIR\fR ioctl described
38 below. Only the current entry is active; when the active entry is closed, the
39 most recent remaining entry becomes active. The active entry acts as a proxy
40 for the device being redirected and handles all \fBread\fR(2), \fBwrite\fR(2),
41 \fBioctl\fR(2), and \fBpoll\fR(2) calls issued against the redirectee.
44 The ioctls described below control the redirection facility. In both cases,
45 \fIfd\fR is a descriptor for the device being redirected (or workstation
46 console) and \fItarget\fR is a descriptor for a STREAMS device.
50 \fB\fBSRIOCSREDIR\fR\fR
53 Designates \fItarget\fR as the source and destination of I/O ostensibly
54 directed to the device denoted by \fIfd\fR.
60 \fB\fBSRIOCISREDIR\fR\fR
63 Returns 1 if \fItarget\fR names the device currently acting as proxy for the
64 device denoted by \fIfd\fR, and 0 if it is not.
67 .SS "ANSI Standard Terminal Emulation"
70 The Solaris kernel terminal emulator provides ANSI X3.64 emulation both on
71 SPARC and x86 systems.
74 On SPARC systems, the PROM monitor is used to emulate an ANSI X3.64 terminal
75 if the kernel terminal emulator is not available for emulation. See
76 \fBvisual_io\fR(7I) for more details.
79 Note: The \fBVT100\fR adheres the \fBANSI\fR X3.64 standard. However, because
80 the \fBVT100\fR features nonstandard extensions to \fBANSI\fR X3.64, it is
81 incompatible with Sun terminal emulators.
84 The SPARC console displays 34 lines of 80 ASCII characters per line. The x86
85 console displays 25 lines of 80 ASCII characters per line. Devices with
86 smaller text capacities may display less. On SPARC systems, the \fBscreen-#rows
87 screen-#columns\fR should be set to 34 or 80 respectively or text capacities
88 will vary from those described above. On SPARC systems, the \fBscreen-#rows and
89 screen-#columns\fR fields are stored in \fBNVRAM/EEPROM\fR. See
90 \fBeeprom\fR(1M) for more information. Both SPARC and x86 consoles offer
91 scrolling, (x, y) cursor addressing ability and a number of other control
95 The console cursor marks the current line and character position on the screen.
96 \fBASCII\fR characters between \fB0x20 \fR(space) and \fB0x7E\fR (tilde)
97 inclusive are printing characters. When a print character is written to the
98 console (and is not part of an escape sequence), it is displayed at the current
99 cursor position and the cursor moves one position to the right on the current
103 On SPARC based systems, later \fBPROM\fR revisions have the full 8-bit ISO
104 Latin-1 (\fIISO 8859-1\fR) character set. Earlier \fBPROM\fR revisions display
105 characters in the range \fB0xA0 \fRthrough \fB0xFE \fRas spaces.
108 When the cursor is at the right edge of the screen, it moves to the first
109 character position on the next line. When the cursor is at the screen's
110 right-bottom edge, the line-feed function is performed (see \fBCTRL-J\fR
111 below). The line-feed function scrolls the screen up by one or more lines
112 before moving the cursor to the first character position on the next line.
113 .SS "Control Sequence Syntax"
116 The \fBwscons\fR console defines a number of control sequences that may occur
117 during input. When a control sequence is written to the console, it affects
118 one of the control functions described below. Control sequences are not
122 A number of control sequences (or control character functions) are of the form:
128 where \fIx\fR represents a singe character., such as \fBCNTRL-J\fR for a line
132 Other \fBANSI\fR control sequences are of the form:
136 ESC [ \fIparams char\fR
144 Spaces are included only for readability; these characters must occur in the
145 given sequence without the intervening spaces.
153 \fBASCII\fR escape character (\fBESC, CTRL-[, 0x1B\fR).
162 Left square bracket `[' (\fB0x5B)\fR.
171 Sequence of zero or more decimal numbers made up of digits between 0 and 9,
172 separated by semicolons. Parameters are represented by \fIn\fR in the syntax
173 descriptions for escape sequence functions.
182 Function character, which is different for each control sequence and it
183 represented by \fIx\fR in the syntax descriptions for control character
189 In the following examples of syntactically valid escape sequences, \fBESC
190 \fRrepresent the single \fBASCII\fR character, Escape:
197 Select graphic rendition with default parameter
206 Select graphic rendition with reverse image
221 \fBESC[123;456;0;;3;B\fR
229 Syntactically valid control characters and \fBANSI\fR escape sequences that are
230 not currently interpreted by the console are ignored.
233 Each control function requires a specified number of parameters. If fewer
234 parameters are supplied, the remaining parameters (with certain exceptions
235 noted below) default to 1. If more parameters are supplied, the first \fIn\fR
236 parameters are used by kernel terminal emulator. In contrast, only the last
237 \fIn\fR parameters are used by PROM based emulator, where \fIn\fR is the number
238 required by that particular command character.
241 Parameters which are omitted or set to 0 are reset to the default value of 1
242 (with certain exceptions). For example, the command character \fBM\fR requires
243 one parameter. \fBESC[;M\fR, \fBESC[0M\fR, \fBESC[M\fR and
244 \fBESC[23;15;32;1M\fR are all equivalent to \fBESC[1M\fR and provide a
245 parameter value of 1. Note that \fBESC[;5M\fR (interpreted as \fB`ESC[5M\fR')
246 is \fInot\fR equivalent to \fBESC[5;M\fR (interpreted as `\fBESC[5;1M\fR')
247 which is ultimately interpreted as `\fBESC[1M\fR').
248 .SS "ANSI Control Functions"
251 The following paragraphs specify the \fBANSI\fR control functions implemented
252 by the console. Each description provides:
257 Control sequence syntax
263 Hexadecimal equivalent of control characters where applicable
269 Control function name and \fBANSI\fR or Sun abbreviation (if any).
275 Description of parameters required, if any
281 Description of the control function
287 Initial setting of the mode for functions that set a mode. To restore the
288 initial settings, use the \fBSUNRESET\fR escape sequence.
290 .SS "Control Character Functions"
293 The \fBwscons \fRcontrol character functions are:
308 Used for consoles that are not equipped with an audible bell. Current Sun
309 workstation models also flash the screen if the keyboard is not the console
316 \fBBackspace (BS),\fR
327 The cursor moves one position to the left on the current line. If it is
328 already at the left edge of the screen, no change takes place.
345 The cursor moves right on the current line to the next tab stop. The tab stops
346 are fixed at every multiple of eight columns. If the cursor is already at the
347 right edge of the screen, nothing change takes place. Otherwise, the cursor
348 moves right a minimum of one and a maximum of eight character positions.
354 \fBLine-feed (LF),\fR
365 The cursor, while remaining at the same character position on the line, moves
366 down one line. If the cursor is at the bottom line, the screen either scrolls
367 up or wraps around depending on the setting of an internal variable \fIn\fR
368 (initially 1) . The internal variable can be changed using the \fBESC[r\fR
369 control sequence. If \fIn\fR is greater than zero, the entire screen
370 (including the cursor) is scrolled up by \fIn\fR lines before executing the
371 line-feed. The top \fIn\fR lines scroll off the screen and are lost. New blank
372 lines \fIn\fR scroll onto the bottom of the screen. After scrolling, move the
373 cursor down one line to execute the line feed.
375 If \fIn\fR is zero, wrap-around mode is entered. The \fBESC [ 1 r\fR exits back
376 to scroll mode. If a line-feed occurs on the bottom line in wrap mode, the
377 cursor goes to the same character position in the top line of the screen.
378 During line-feeds, the line that the cursor moves to is cleared and no
379 scrolling occurs. Wrap-around mode is not implemented in the window system.
381 On SPARC based systems, the speed at which the screen scrolls is dependent on
382 the amount of data waiting to be printed. Whenever a scroll occurs and the
383 console is in normal scroll mode (\fBESC [ 1 r\fR), it scans the rest of the
384 data awaiting printing to see how many line-feeds occur in it. This scan stops
385 when the console finds a control character from the set {\fBVT\fR, \fBFF\fR,
386 \fBSO\fR, \fBSI\fR, \fBDLE\fR, \fBDC1\fR, \fBDC2\fR, \fBDC3\fR, \fBDC4\fR,
387 \fBNAK\fR, \fBSYN\fR, \fBETB\fR, \fBCAN\fR, \fBEM\fR, \fBSUB\fR, \fBESC\fR,
388 \fBFS\fR, \fBGS\fR, \fBRS\fR, \fBUS\fR} . At that point, the screen is
389 scrolled by \fIn\fR lines (\fIn\fR \(>= 1) and processing continues. The
390 scanned text is processed normally and fills in the newly created lines. As
391 long as escape codes or other control characters are not intermixed with the
392 text, this results in faster scrolling
398 \fBReverse Line-feed,\fR
409 With kernel terminal emulator (while remaining at the same character position
410 on the line), the cursor moves down one line. However, with PROM based
411 emulator (while remaining at the same character position on the line), the
412 cursor moves up one line. If the cursor is already at the top line, no
430 The cursor is positioned to the home position (upper-left corner) and the
431 entire screen is cleared.
448 The cursor moves to the leftmost character position on the current line.
451 .SS "Escape Sequence Functions"
454 The \fBwscons \fRescape sequence functions are:
470 The escape character. Escape initiates a multi-character control sequence.
476 \fBInsert Character (ICH)\fR
484 Takes one parameter, \fIn\fR (default 1). Inserts \fIn\fR spaces at the
485 current cursor position. The current line, starting at the current cursor
486 position inclusive, is shifted to the right by \fIn\fR character positions to
487 make room for the spaces. The rightmost \fIn\fR character positions shift off
488 the line and are lost. The position of the cursor is unchanged.
494 \fBCursor Up (CUU),\fR
502 Takes one parameter, \fIn\fR (default 1). Moves the cursor up \fIn\fR lines.
503 If the cursor is fewer than \fIn\fR lines from the top of the screen, moves
504 the cursor to the topmost line on the screen. The character position of the
505 cursor on the line is unchanged.
511 \fBCursor Down (CUD),\fR
519 Takes one parameter, (default 1). Moves the cursor down \fIn\fR lines. If
520 the cursor is fewer than \fIn\fR lines from the bottom of the screen, move the
521 cursor to the last line on the screen. The character position of the cursor on
522 the line is unchanged.
528 \fBCursor Forward (CUF),\fR
536 Takes one parameter, \fIn\fR (default 1). Moves the cursor to the right by
537 \fIn\fR character positions on the current line. If the cursor is fewer than
538 \fIn\fR positions from the right edge of the screen, moves the cursor to the
539 rightmost position on the current line.
545 \fBCursor Backward (CUB),\fR
553 Takes one parameter, \fIn\fR (default 1). Moves the cursor to the left by
554 \fIn\fR character positions on the current line. If the cursor is fewer than
555 \fIn\fR positions from the left edge of the screen, moves the cursor to the
556 leftmost position on the current line.
562 \fBCursor Next Line (CNL),\fR
570 Takes one parameter, \fIn\fR (default 1). Positions the cursor at the
571 leftmost character position on the \fIn\fR-th line below the current line. If
572 the current line is less than \fIn\fR lines from the bottom of the screen,
573 positions the cursor at the leftmost character position on the bottom line.
579 \fBHorizontal and Vertical Position (HVP),\fR
593 \fBCursor Position (CUP),\fR
601 Takes two parameters, \fIn\fR1 and \fIn\fR2 (default 1, 1). Moves the cursor
602 to the \fIn\fR2-th character position on the \fIn\fR1-th line. Character
603 positions are numbered from 1 at the left edge of the screen; line positions
604 are numbered from 1 at the top of the screen. Hence, if both parameters are
605 omitted, the default action moves the cursor to the home position (upper left
606 corner). If only one parameter is supplied, the cursor moves to column 1 of
613 \fBErase in Display (ED),\fR
621 Takes no parameters. Erases from the current cursor position inclusive to the
622 end of the screen, that is, to the end of the current line and all lines below
623 the current line. The cursor position is unchanged.
629 \fBErase in Line (EL),\fR
637 Takes no parameters. Erases from the current cursor position inclusive to the
638 end of the current line. The cursor position is unchanged.
644 \fBInsert Line (IL),\fR
652 Takes one parameter, \fIn\fR (default 1). Makes room for \fIn\fR new lines
653 starting at the current line by scrolling down by \fIn\fR lines the portion of
654 the screen from the current line inclusive to the bottom. The \fIn\fR new
655 lines at the cursor are filled with spaces; the bottom \fIn\fR lines shift off
656 the bottom of the screen and are lost. The position of the cursor on the
663 \fBDelete Line (DL),\fR
671 Takes one parameter, \fIn\fR (default 1). Deletes \fIn\fR lines beginning
672 with the current line. The portion of the screen from the current line
673 inclusive to the bottom is scrolled upward by \fIn\fR lines. The \fIn\fR new
674 lines scrolling onto the bottom of the screen are filled with spaces; the
675 \fIn\fR old lines beginning at the cursor line are deleted. The position of
676 the cursor on the screen is unchanged.
682 \fBDelete Character (DCH),\fR
690 Takes one parameter, \fIn\fR (default 1). Deletes \fIn\fR characters
691 starting with the current cursor position. Shifts the tail of the current line
692 to the left by \fIn\fR character positions from the current cursor position,
693 inclusive, to the end of the line. Blanks are shifted into the rightmost
694 \fIn\fR character positions. The position of the cursor on the screen is
701 \fBSelect Graphic Rendition (SGR),\fR
709 Takes one parameter, \fIn\fR (default 0). Note that unlike most escape
710 sequences, the parameter defaults to zero if omitted. Invokes the graphic
711 rendition specified by the parameter. All following printing characters in the
712 data stream are rendered according to the parameter until the next occurrence
713 of this escape sequence in the data stream. With PROM-based emulator, only two
714 graphic renditions are defined:
730 Negative (reverse) image
733 Negative image displays characters as white-on-black if the screen mode is
734 currently black-on white, and vice-versa. Any non-zero value of \fIn\fR is
735 currently equivalent to 7 and selects the negative image rendition.
737 In addition to the two renditions mentioned above, the following\fI ISO
738 6429-1983\fR graphic rendition values support color text with kernel terminal
889 \fBBlack On White (SUNBOW),\fR
897 Takes no parameters. On SPARC, sets the screen mode to black-on-white. If the
898 screen mode is already black-on-white, has no effect. In this mode, spaces
899 display as solid white, other characters as black-on-white. The cursor is a
900 solid black block. Characters displayed in negative image rendition (see
901 `Select Graphic Rendition' above) are white-on-black. This comprises the
902 initial setting of the screen mode on reset. On x86 systems, use \fBESC[q\fR to
909 \fBWhite On Black (SUNWOB),\fR
917 Takes no parameters. On SPARC, sets the screen mode to white-on-black. If the
918 screen mode is already white-on-black, has no effect. In this mode spaces
919 display as solid black, other characters as white-on-black. The cursor is a
920 solid white block. Characters displayed in negative image rendition (see
921 `Select Graphic Rendition' above) are black-on-white. Initial setting of the
922 screen mode on reset is black on white. On x86 systems, use \fBESC[p\fR to set
933 \fBSet Scrolling (SUNSCRL)\fR
937 Takes one parameter, \fIn\fR (default 0). Sets to \fIn\fR an internal
938 register which determines how many lines the screen scrolls up when a line-feed
939 function is performed with the cursor on the bottom line. A parameter of 2 or
940 3 introduces a small amount of jump when a scroll occurs. A parameter of 34
941 clears the screen rather than scrolling. The initial setting is 1 on reset.
943 A parameter of zero initiates wrap mode instead of scrolling. If a linefeed
944 occurs on the bottom line during wrap mode, the cursor goes to the same
945 character position in the top line of the screen. When a line feed occurs, the
946 line that the cursor moves to is cleared and no scrolling occurs. \fBESC [ 1
947 r\fR exits back to scroll mode.
949 For more information, see the description of the Line-feed (\fBCTRL-J\fR)
950 control function above.
960 \fBReset terminal emulator (SUNRESET)\fR
964 Takes no parameters. Resets all modes to default, restores current font from
965 \fBPROM.\fR Screen and cursor position are unchanged.
971 When there are no errors, the redirection ioctls have return values as
972 described above. Otherwise, they return \fB\(mi1\fR and set \fBerrno\fR to
973 indicate the error. If the target stream is in an error state, \fBerrno \fRis
977 If the \fItarget\fR stream is in an error state, \fBerrno\fR is set
986 \fItarget\fR does not denote an open file.
995 \fItarget\fR does not denote a \fBSTREAMS\fR device.
1002 \fB\fB/dev/wscons\fR\fR
1005 Workstation console, accessed via the redirection facility
1011 \fB\fB/dev/systty\fR\fR
1014 Devices that must be opened for the \fBSRIOCSREDIR\fR and \fBSRIOCISREDIR\fR
1021 \fB\fB/dev/syscon\fR\fR
1024 Access system console
1030 \fB\fB/dev/console\fR\fR
1033 Access system console
1039 See \fBattributes\fR(5) for descriptions of the following attributes:
1047 ATTRIBUTE TYPE ATTRIBUTE VALUE
1049 Interface Stability Stable
1055 \fBcvcd\fR(1M), \fBeeprom\fR(1M), \fBioctl\fR(2), \fBpoll\fR(2), \fBread\fR(2),
1056 \fBwrite\fR(2), \fBcvc\fR(7D), \fBconsole\fR(7D), \fBvisual_io\fR(7I)
1060 The redirection ioctls block while there is I/O outstanding on the device
1061 instance being redirected. If you try to redirect the workstation console while
1062 there is a outstanding read, the workstation console will hang until the read
1067 The \fBcvc \fRfacility supersedes the SunOS \fBwscons \fRfacility and should
1068 not be used with \fBwscons\fR.