rasops.h revision 1.5 1 /* $NetBSD: rasops.h,v 1.5 1999/04/29 02:49:40 ad Exp $ */
2
3 /*
4 * Copyright (c) 1999 Andy Doran <ad (at) NetBSD.org>
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 *
28 */
29
30 #ifndef _RASOPS_H_
31 #define _RASOPS_H_ 1
32
33 /* Avoid dragging in dev/wscons/wsconsio.h */
34 struct wsdisplay_font;
35
36 struct rasops_info {
37 /* These must be filled in by the caller */
38 int ri_depth; /* depth in bits */
39 u_char *ri_bits; /* ptr to bits */
40 int ri_width; /* width (pels) */
41 int ri_height; /* height (pels) */
42 int ri_stride; /* stride in bytes */
43
44 /*
45 * These can optionally be left empty. If you fill ri_font,
46 * but aren't using wsfont, set ri_wsfcookie to -1.
47 */
48 struct wsdisplay_font *ri_font;
49 int ri_wsfcookie;
50 void *ri_priv; /* driver private data */
51 u_char ri_forcemono; /* force monochrome operation */
52 u_char ri_swab; /* swap bytes for 15/16/32 bit depths? */
53
54 /*
55 * These are optional and will default if zero. Meaningless
56 * on depths other than 15, 16, 24 and 32 bits per pel. On
57 * 24 bit displays, ri_{r,g,b}num must be 8.
58 */
59 u_char ri_rnum; /* number of bits for red */
60 u_char ri_gnum; /* number of bits for green */
61 u_char ri_bnum; /* number of bits for blue */
62 u_char ri_rpos; /* which bit red starts at */
63 u_char ri_gpos; /* which bit green starts at */
64 u_char ri_bpos; /* which bit blue starts at */
65
66 /* These are filled in by rasops_init() */
67 int ri_emuwidth; /* width we actually care about */
68 int ri_emuheight; /* height we actually care about */
69 int ri_emustride; /* bytes per row we actually care about */
70 int ri_rows; /* number of rows (characters, not pels) */
71 int ri_cols; /* number of columns (characters, not pels) */
72 int ri_delta; /* row delta in bytes */
73 int ri_flg; /* flags */
74 int ri_crow; /* cursor row */
75 int ri_ccol; /* cursor column */
76 int ri_pelbytes; /* bytes per pel (may be zero) */
77 int ri_fontscale; /* fontheight * fontstride */
78 int ri_xscale; /* fontwidth * pelbytes */
79 int ri_yscale; /* fontheight * stride */
80 u_char *ri_origbits; /* where screen bits actually start */
81 int ri_xorigin; /* where ri_bits begins (x) */
82 int ri_yorigin; /* where ri_bits begins (y) */
83
84 /* For 15, 16, 24, 32 bits */
85 int32_t ri_devcmap[16]; /* device colormap (WSCOL_*) */
86
87 /* The emulops you need to use, and the screen caps for wscons */
88 struct wsdisplay_emulops ri_ops;
89 int ri_caps;
90
91 /* Callbacks so we can share some code */
92 void (*ri_do_cursor) __P((struct rasops_info *));
93 };
94
95 #define RASOPS_CURSOR (0x01) /* cursor is on */
96 #define RASOPS_INITTED (0x02) /* struct is initialized */
97 #define RASOPS_CURSOR_CLIPPED (0x04) /* cursor is clipped */
98
99 #define DELTA(p, d, cast) ((p) = (cast)((caddr_t)(p) + (d)))
100
101 /*
102 * rasops_init().
103 *
104 * Integer parameters are: number of rows we'd like, number of columns we'd
105 * like, whether we should clear the display and whether we should center
106 * the output. Remember that what you'd like is always not what you get.
107 *
108 * In terms of optimization, fonts that are a multiple of 8 pixels wide
109 * work the best: this is important, and will cost you if you don't use 'em.
110 *
111 * rasops_init() takes care of rasops_setfont(). You only need to use this
112 * when you want to switch fonts later on. The integer parameters to both
113 * are the same. Before calling rasops_setfont(), set ri.ri_font. This
114 * should happen at _splhigh_. If (ri_wsfcookie >= 0), you must call
115 * wsfont_unlock() on it first.
116 */
117
118 /* rasops.c */
119 int rasops_init __P((struct rasops_info *, int, int, int, int));
120 int rasops_setfont __P((struct rasops_info *, int, int, int, int));
121 void rasops_unpack_attr __P((long, int *, int *, int *));
122
123 /* These should _not_ be called outside rasops */
124 void rasops_eraserows __P((void *, int, int, long));
125 void rasops_erasecols __P((void *, int, int, int, long));
126 void rasops_copycols __P((void *, int, int, int, int));
127
128 extern u_char rasops_isgray[16];
129 extern u_char rasops_cmap[256*3];
130
131 #endif /* _RASOPS_H_ */
132