diff options
author | sos <sos@FreeBSD.org> | 1998-09-15 18:16:39 +0000 |
---|---|---|
committer | sos <sos@FreeBSD.org> | 1998-09-15 18:16:39 +0000 |
commit | 653c2af6aea50955f84c98c164cfd99edb197426 (patch) | |
tree | 0a8dfaf5cfe4668ea247fe425c8b3d1a87f595d6 /usr.sbin/vidcontrol | |
parent | 9a318dd66f83207c7abcee476e380d062939ea19 (diff) | |
download | FreeBSD-src-653c2af6aea50955f84c98c164cfd99edb197426.zip FreeBSD-src-653c2af6aea50955f84c98c164cfd99edb197426.tar.gz |
Add VESA support to syscons.
Kazu writes:
The VESA support code requires vm86 support. Make sure your kernel
configuration file has the following line.
options "VM86"
If you want to statically link the VESA support code to the kernel,
add the following option to the kernel configuration file.
options "VESA"
The vidcontrol command now accepts the following video mode names:
VESA_132x25, VESA_132x43, VESA_132x50, VESA_132x60, VESA_800x600
The VESA_800x600 mode is a raster display mode. The 80x25 text will
be displayed on the 800x600 screen. Useful for some laptop computers.
vidcontrol accepts the new `-i <info>' option, where <info> must be
either `adapter' or `mode'. When the `-i adapter' option is given,
vidcontrol will print basic information (not much) on the video
adapter. When the `-i mode' option is specified, vidcontrol will
list video modes which are actually supported by the video adapter.
Submitted by: Kazutaka YOKOTA yokota@FreeBSD.ORG
Diffstat (limited to 'usr.sbin/vidcontrol')
-rw-r--r-- | usr.sbin/vidcontrol/vidcontrol.1 | 7 | ||||
-rw-r--r-- | usr.sbin/vidcontrol/vidcontrol.c | 122 |
2 files changed, 126 insertions, 3 deletions
diff --git a/usr.sbin/vidcontrol/vidcontrol.1 b/usr.sbin/vidcontrol/vidcontrol.1 index aea5467..f4c9d21 100644 --- a/usr.sbin/vidcontrol/vidcontrol.1 +++ b/usr.sbin/vidcontrol/vidcontrol.1 @@ -11,7 +11,7 @@ .\" documentation and/or other materials provided with the distribution. .\" .\" @(#)vidcontrol.1 -.\" $Id: vidcontrol.1,v 1.11 1997/07/24 23:46:35 wosch Exp $ +.\" $Id: vidcontrol.1,v 1.12 1997/10/27 07:52:08 charnier Exp $ .\" .Dd May 22, 1994 .Dt VIDCONTROL 1 @@ -25,6 +25,7 @@ .Op Fl b Ar color .Op Fl c Ar appearance .Op Fl d +.Op Fl i Ar adapter|mode .Op Fl l Ar scrmap .Op Fl L .Op Fl m Ar on|off @@ -84,6 +85,10 @@ Install screen output map file from .Ar scrmap .It Fl L Install default screen output map. +.It Fl i Ar adapter +Shows info about the current videoadapter. +.It Fl i Ar mode +Shows the possible videomodes with the current video hardware. .It Fl m Ar on|off Switch the mousepointer .Ar on diff --git a/usr.sbin/vidcontrol/vidcontrol.c b/usr.sbin/vidcontrol/vidcontrol.c index 81f13da..4c97cab 100644 --- a/usr.sbin/vidcontrol/vidcontrol.c +++ b/usr.sbin/vidcontrol/vidcontrol.c @@ -28,7 +28,7 @@ #ifndef lint static const char rcsid[] = - "$Id: vidcontrol.c,v 1.18 1997/10/27 07:52:10 charnier Exp $"; + "$Id: vidcontrol.c,v 1.19 1998/07/14 10:32:27 bde Exp $"; #endif /* not lint */ #include <ctype.h> @@ -259,6 +259,7 @@ void video_mode(int argc, char **argv, int *index) { unsigned long mode; + int size[3]; if (*index < argc) { if (!strcmp(argv[*index], "VGA_40x25")) @@ -277,10 +278,27 @@ video_mode(int argc, char **argv, int *index) mode = SW_ENH_C80x25; else if (!strcmp(argv[*index], "EGA_80x43")) mode = SW_ENH_C80x43; + else if (!strcmp(argv[*index], "VESA_132x25")) + mode = SW_VESA_C132x25; + else if (!strcmp(argv[*index], "VESA_132x43")) + mode = SW_VESA_C132x43; + else if (!strcmp(argv[*index], "VESA_132x50")) + mode = SW_VESA_C132x50; + else if (!strcmp(argv[*index], "VESA_132x60")) + mode = SW_VESA_C132x60; + else if (!strcmp(argv[*index], "VESA_800x600")) + mode = SW_VESA_800x600; else return; if (ioctl(0, mode, NULL) < 0) warn("cannot set videomode"); + if (mode == SW_VESA_800x600) { + size[0] = 80; /* columns */ + size[1] = 25; /* rows */ + size[2] = 16; /* font size */ + if (ioctl(0, KDRASTER, size)) + warn("cannot activate raster display"); + } (*index)++; } return; @@ -375,6 +393,103 @@ set_mouse(char *arg) ioctl(0, CONS_MOUSECTL, &mouse); } +static char +*adapter_name(int type) +{ + static struct { + int type; + char *name; + } names[] = { + { KD_MONO, "MDA" }, + { KD_HERCULES, "Hercules" }, + { KD_CGA, "CGA" }, + { KD_EGA, "EGA" }, + { KD_VGA, "VGA" }, + { KD_PC98, "PC-98xx" }, + { -1, "Unknown" }, + }; + int i; + + for (i = 0; names[i].type != -1; ++i) + if (names[i].type == type) + break; + return names[i].name; +} + +void +show_adapter_info(void) +{ + struct video_adapter ad; + + ad.va_index = 0; + if (ioctl(0, CONS_ADPINFO, &ad)) { + warn("failed to obtain adapter information"); + return; + } + + printf("adapter %d:\n", ad.va_index); + printf(" type:%s%s (%d), flags:0x%08x, CRTC:0x%x\n", + (ad.va_flags & V_ADP_VESA) ? "VESA " : "", + adapter_name(ad.va_type), ad.va_type, + ad.va_flags, ad.va_crtc_addr); + printf(" initial mode:%d, current mode:%d, BIOS mode:%d\n", + ad.va_initial_mode, ad.va_mode, ad.va_initial_bios_mode); +} + +void +show_mode_info(void) +{ + struct video_info info; + char buf[80]; + int mode; + int c; + + printf(" mode# flags type size " + "font window linear buffer\n"); + printf("---------------------------------------" + "---------------------------------------\n"); + for (mode = 0; mode < M_VESA_MODE_MAX; ++mode) { + info.vi_mode = mode; + if (ioctl(0, CONS_MODEINFO, &info)) + continue; + + printf("%3d (0x%03x)", mode, mode); + printf(" 0x%08x", info.vi_flags); + if (info.vi_flags & V_INFO_GRAPHICS) { + c = 'G'; + snprintf(buf, sizeof(buf), "%dx%dx%d %d", + info.vi_width, info.vi_height, + info.vi_depth, info.vi_planes); + } else { + c = 'T'; + snprintf(buf, sizeof(buf), "%dx%d", + info.vi_width, info.vi_height); + } + printf(" %c %-15s", c, buf); + snprintf(buf, sizeof(buf), "%dx%d", + info.vi_cwidth, info.vi_cheight); + printf(" %-5s", buf); + printf(" 0x%05x %2dk %2dk", + info.vi_window, info.vi_window_size, + info.vi_window_gran); + printf(" 0x%08x %2dk\n", + info.vi_buffer, info.vi_buffer_size); + } +} + +void +show_info(char *arg) +{ + if (!strcmp(arg, "adapter")) + show_adapter_info(); + else if (!strcmp(arg, "mode")) + show_mode_info(); + else { + warnx("argument to -i must either adapter or mode"); + return; + } +} + void test_frame() { @@ -402,7 +517,7 @@ main(int argc, char **argv) info.size = sizeof(info); if (ioctl(0, CONS_GETINFO, &info) < 0) err(1, "must be on a virtual console"); - while((opt = getopt(argc, argv, "b:c:df:l:Lm:r:s:t:x")) != -1) + while((opt = getopt(argc, argv, "b:c:df:i:l:Lm:r:s:t:x")) != -1) switch(opt) { case 'b': set_border_color(optarg); @@ -417,6 +532,9 @@ main(int argc, char **argv) load_font(optarg, nextarg(argc, argv, &optind, 'f')); break; + case 'i': + show_info(optarg); + break; case 'l': load_scrnmap(optarg); break; |