.\" Copyright (c) 1990, 1991, 1993
.\" The Regents of the University of California. All rights reserved.
.\" This code is derived from software contributed to Berkeley by
.\" the Systems Programming Group of the University of Utah Computer
.\" %sccs.include.redist.man%
.\" @(#)tc.4 8.1 (Berkeley) %G%
98550 ``Topcat'' and ``Catseye'' device interface
98545 and 98547 ``Topcat''
98549, and 98550 ``Catseye'' display cards.
This driver merely checks for the existence of the device
and does minimal set up, as it is expected the applications will initialize
the device to their requirements.
The Topcat and Catseye are nearly identical in common usage and only the
Topcat will be referred to from now on.
The Topcat display cards are not user configurable. If one is present on a
system, it will always have a frame buffer address of 0x200000 and a control
register address of 0x560000. These are the
Terminal Emulator) defaults. The device can also be used as a graphics output
system for the Topcat are:
.Bl -tag -width GRFIOCGINFO
Get info about device, setting the entries in the
.Aq Pa hpdev/grfioctl.h .
the number of planes should be 1, as they are monochrome devices.
The number of planes for a 98545 is 4, translating to 15 colors,
The 98547 and 98548 cards have 6 planes, yielding 63 colors and black.
The 98550 has 8 planes, yielding 255 colors and black.
The displayed frame buffer size for the 98549 and 98550 is 2048 x 1024,
for the others it is 1024 x 768.
Turn graphics on by enabling
output. The screen will come on, displaying
whatever is in the frame buffer, using whatever colormap is in place.
Turn graphics off by disabling output to the
The frame buffer contents
Map in control registers and framebuffer space. Once the device file is
mapped, the frame buffer structure is accessible. The frame buffer structure
describing Topcat/Catseye devices is defined in
.Aq Pa hpdev/grf_tcreg.h .
For further information about the use of
A small example of opening, mapping and using the device is given below.
For more examples of the details on the behavior of the device, see the device
dependent source files for the X Window System, in the
u_char *Addr, frame_buffer;
disp_fd = open("/dev/grf0",1);
if (ioctl (disp_fd, GRFIOCGINFO, &gi) < 0) return -1;
(void) ioctl (disp_fd, GRFIOCON, 0);
if (ioctl (disp_fd, GRFIOCMAP, &Addr) < 0) {
(void) ioctl (disp_fd, GRFIOCOFF, 0);
tc = (tcboxfb *) Addr; /* Control Registers */
frame_buffer = (u_char *) Addr + gi.gd_regsize; /* Frame buffer memory */
.Bl -tag -width /dev/MAKEDEV.hpux -compact
.Tn /usr/CE.utilities/Crtadjust
Another process has the device open.