display.c revision 1.10 1 1.10 uwe /* $NetBSD: display.c,v 1.10 2005/02/27 15:26:16 uwe Exp $ */
2 1.1 hannken
3 1.1 hannken /*-
4 1.8 jmmv * Copyright (c) 1998, 2004 The NetBSD Foundation, Inc.
5 1.1 hannken * All rights reserved.
6 1.1 hannken *
7 1.1 hannken * This code is derived from software contributed to The NetBSD Foundation
8 1.1 hannken * by Juergen Hannken-Illjes.
9 1.1 hannken *
10 1.1 hannken * Redistribution and use in source and binary forms, with or without
11 1.1 hannken * modification, are permitted provided that the following conditions
12 1.1 hannken * are met:
13 1.1 hannken * 1. Redistributions of source code must retain the above copyright
14 1.1 hannken * notice, this list of conditions and the following disclaimer.
15 1.1 hannken * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 hannken * notice, this list of conditions and the following disclaimer in the
17 1.1 hannken * documentation and/or other materials provided with the distribution.
18 1.1 hannken * 3. All advertising materials mentioning features or use of this software
19 1.1 hannken * must display the following acknowledgement:
20 1.1 hannken * This product includes software developed by the NetBSD
21 1.1 hannken * Foundation, Inc. and its contributors.
22 1.1 hannken * 4. Neither the name of The NetBSD Foundation nor the names of its
23 1.1 hannken * contributors may be used to endorse or promote products derived
24 1.1 hannken * from this software without specific prior written permission.
25 1.1 hannken *
26 1.1 hannken * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
27 1.1 hannken * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
28 1.1 hannken * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29 1.1 hannken * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
30 1.1 hannken * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31 1.1 hannken * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32 1.1 hannken * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33 1.1 hannken * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34 1.1 hannken * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35 1.1 hannken * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36 1.1 hannken * POSSIBILITY OF SUCH DAMAGE.
37 1.1 hannken */
38 1.1 hannken
39 1.1 hannken #include <sys/ioctl.h>
40 1.4 christos #include <sys/time.h>
41 1.4 christos
42 1.3 christos #include <stdio.h>
43 1.4 christos #include <string.h>
44 1.4 christos #include <errno.h>
45 1.4 christos #include <err.h>
46 1.4 christos
47 1.1 hannken #include <dev/wscons/wsconsio.h>
48 1.4 christos
49 1.1 hannken #include "wsconsctl.h"
50 1.1 hannken
51 1.6 jmmv static int border;
52 1.1 hannken static int dpytype;
53 1.2 hannken static struct wsdisplay_usefontdata font;
54 1.10 uwe static struct wsdisplay_param backlight;
55 1.10 uwe static struct wsdisplay_param brightness;
56 1.10 uwe static struct wsdisplay_param contrast;
57 1.3 christos static struct wsdisplay_scroll_data scroll_l;
58 1.5 jmmv static int msg_default_attrs, msg_default_bg, msg_default_fg;
59 1.5 jmmv static int msg_kernel_attrs, msg_kernel_bg, msg_kernel_fg;
60 1.1 hannken
61 1.1 hannken struct field display_field_tab[] = {
62 1.6 jmmv { "border", &border, FMT_COLOR, FLG_MODIFY },
63 1.1 hannken { "type", &dpytype, FMT_DPYTYPE, FLG_RDONLY },
64 1.2 hannken { "font", &font.name, FMT_STRING, FLG_WRONLY },
65 1.10 uwe { "backlight", &backlight.curval, FMT_UINT, 0 },
66 1.10 uwe { "brightness", &brightness.curval, FMT_UINT, FLG_MODIFY },
67 1.10 uwe { "contrast", &contrast.curval, FMT_UINT, FLG_MODIFY },
68 1.3 christos { "scroll.fastlines", &scroll_l.fastlines, FMT_UINT, FLG_MODIFY },
69 1.3 christos { "scroll.slowlines", &scroll_l.slowlines, FMT_UINT, FLG_MODIFY },
70 1.5 jmmv { "msg.default.attrs", &msg_default_attrs, FMT_ATTRS, FLG_MODIFY },
71 1.5 jmmv { "msg.default.bg", &msg_default_bg, FMT_COLOR, FLG_MODIFY },
72 1.5 jmmv { "msg.default.fg", &msg_default_fg, FMT_COLOR, FLG_MODIFY },
73 1.5 jmmv { "msg.kernel.attrs", &msg_kernel_attrs, FMT_ATTRS, FLG_MODIFY },
74 1.5 jmmv { "msg.kernel.bg", &msg_kernel_bg, FMT_COLOR, FLG_MODIFY },
75 1.5 jmmv { "msg.kernel.fg", &msg_kernel_fg, FMT_COLOR, FLG_MODIFY },
76 1.1 hannken };
77 1.1 hannken
78 1.1 hannken int display_field_tab_len = sizeof(display_field_tab)/
79 1.1 hannken sizeof(display_field_tab[0]);
80 1.1 hannken
81 1.1 hannken void
82 1.9 xtraeme display_get_values(int fd)
83 1.1 hannken {
84 1.1 hannken if (field_by_value(&dpytype)->flags & FLG_GET)
85 1.1 hannken if (ioctl(fd, WSDISPLAYIO_GTYPE, &dpytype) < 0)
86 1.1 hannken err(1, "WSDISPLAYIO_GTYPE");
87 1.3 christos
88 1.6 jmmv if (field_by_value(&border)->flags & FLG_GET)
89 1.6 jmmv if (ioctl(fd, WSDISPLAYIO_GBORDER, &border) < 0)
90 1.7 jmmv field_disable_by_value(&border);
91 1.6 jmmv
92 1.10 uwe if (field_by_value(&backlight.curval)->flags & FLG_GET) {
93 1.10 uwe backlight.param = WSDISPLAYIO_PARAM_BACKLIGHT;
94 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &backlight) < 0)
95 1.10 uwe field_disable_by_value(&backlight.curval);
96 1.10 uwe }
97 1.10 uwe
98 1.10 uwe if (field_by_value(&brightness.curval)->flags & FLG_GET) {
99 1.10 uwe brightness.param = WSDISPLAYIO_PARAM_BRIGHTNESS;
100 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &brightness))
101 1.10 uwe field_disable_by_value(&brightness.curval);
102 1.10 uwe }
103 1.10 uwe
104 1.10 uwe if (field_by_value(&contrast.curval)->flags & FLG_GET) {
105 1.10 uwe contrast.param = WSDISPLAYIO_PARAM_CONTRAST;
106 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &contrast))
107 1.10 uwe field_disable_by_value(&contrast.curval);
108 1.10 uwe }
109 1.10 uwe
110 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_GET ||
111 1.5 jmmv field_by_value(&msg_default_bg)->flags & FLG_GET ||
112 1.5 jmmv field_by_value(&msg_default_fg)->flags & FLG_GET ||
113 1.5 jmmv field_by_value(&msg_kernel_attrs)->flags & FLG_GET ||
114 1.5 jmmv field_by_value(&msg_kernel_bg)->flags & FLG_GET ||
115 1.5 jmmv field_by_value(&msg_kernel_fg)->flags & FLG_GET) {
116 1.5 jmmv struct wsdisplay_msgattrs ma;
117 1.5 jmmv
118 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_GMSGATTRS, &ma) < 0) {
119 1.7 jmmv field_disable_by_value(&msg_default_attrs);
120 1.7 jmmv field_disable_by_value(&msg_default_bg);
121 1.7 jmmv field_disable_by_value(&msg_default_fg);
122 1.7 jmmv field_disable_by_value(&msg_kernel_attrs);
123 1.7 jmmv field_disable_by_value(&msg_kernel_bg);
124 1.7 jmmv field_disable_by_value(&msg_kernel_fg);
125 1.7 jmmv } else {
126 1.7 jmmv msg_default_attrs = ma.default_attrs;
127 1.7 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
128 1.7 jmmv msg_default_bg = ma.default_bg;
129 1.7 jmmv msg_default_fg = ma.default_fg;
130 1.7 jmmv } else
131 1.7 jmmv msg_default_bg = msg_default_fg = -1;
132 1.7 jmmv
133 1.7 jmmv msg_kernel_attrs = ma.kernel_attrs;
134 1.7 jmmv if (ma.kernel_attrs & WSATTR_WSCOLORS) {
135 1.7 jmmv msg_kernel_bg = ma.kernel_bg;
136 1.7 jmmv msg_kernel_fg = ma.kernel_fg;
137 1.7 jmmv } else
138 1.7 jmmv msg_kernel_bg = msg_kernel_fg = -1;
139 1.5 jmmv }
140 1.5 jmmv }
141 1.5 jmmv
142 1.7 jmmv if (field_by_value(&scroll_l.fastlines)->flags & FLG_GET ||
143 1.7 jmmv field_by_value(&scroll_l.slowlines)->flags & FLG_GET) {
144 1.7 jmmv if (ioctl(fd, WSDISPLAYIO_DGSCROLL, &scroll_l) < 0) {
145 1.7 jmmv field_disable_by_value(&scroll_l.fastlines);
146 1.7 jmmv field_disable_by_value(&scroll_l.slowlines);
147 1.7 jmmv }
148 1.4 christos }
149 1.1 hannken }
150 1.1 hannken
151 1.1 hannken void
152 1.1 hannken display_put_values(fd)
153 1.1 hannken int fd;
154 1.1 hannken {
155 1.2 hannken if (field_by_value(&font.name)->flags & FLG_SET) {
156 1.2 hannken if (ioctl(fd, WSDISPLAYIO_SFONT, &font) < 0)
157 1.2 hannken err(1, "WSDISPLAYIO_SFONT");
158 1.2 hannken pr_field(field_by_value(&font.name), " -> ");
159 1.2 hannken }
160 1.5 jmmv
161 1.6 jmmv if (field_by_value(&border)->flags & FLG_SET) {
162 1.6 jmmv if (ioctl(fd, WSDISPLAYIO_SBORDER, &border) < 0)
163 1.6 jmmv err(1, "WSDISPLAYIO_SBORDER");
164 1.6 jmmv pr_field(field_by_value(&border), " -> ");
165 1.6 jmmv }
166 1.6 jmmv
167 1.10 uwe if (field_by_value(&backlight.curval)->flags & FLG_SET) {
168 1.10 uwe backlight.param = WSDISPLAYIO_PARAM_BACKLIGHT;
169 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &backlight) < 0)
170 1.10 uwe err(1, "WSDISPLAYIO_PARAM_BACKLIGHT");
171 1.10 uwe pr_field(field_by_value(&backlight.curval), " -> ");
172 1.10 uwe }
173 1.10 uwe
174 1.10 uwe if (field_by_value(&brightness.curval)->flags & FLG_SET) {
175 1.10 uwe brightness.param = WSDISPLAYIO_PARAM_BRIGHTNESS;
176 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &brightness) < 0)
177 1.10 uwe err(1, "WSDISPLAYIO_PARAM_BRIGHTNESS");
178 1.10 uwe pr_field(field_by_value(&brightness.curval), " -> ");
179 1.10 uwe }
180 1.10 uwe
181 1.10 uwe if (field_by_value(&contrast.curval)->flags & FLG_SET) {
182 1.10 uwe contrast.param = WSDISPLAYIO_PARAM_CONTRAST;
183 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &contrast) < 0)
184 1.10 uwe err(1, "WSDISPLAYIO_PARAM_CONTRAST");
185 1.10 uwe pr_field(field_by_value(&contrast.curval), " -> ");
186 1.10 uwe }
187 1.10 uwe
188 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_SET ||
189 1.5 jmmv field_by_value(&msg_default_bg)->flags & FLG_SET ||
190 1.5 jmmv field_by_value(&msg_default_fg)->flags & FLG_SET ||
191 1.5 jmmv field_by_value(&msg_kernel_attrs)->flags & FLG_SET ||
192 1.5 jmmv field_by_value(&msg_kernel_bg)->flags & FLG_SET ||
193 1.5 jmmv field_by_value(&msg_kernel_fg)->flags & FLG_SET) {
194 1.5 jmmv struct wsdisplay_msgattrs ma;
195 1.5 jmmv
196 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_GMSGATTRS, &ma) < 0)
197 1.5 jmmv err(1, "WSDISPLAYIO_GMSGATTRS");
198 1.5 jmmv
199 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_SET) {
200 1.5 jmmv ma.default_attrs = msg_default_attrs;
201 1.5 jmmv pr_field(field_by_value(&msg_default_attrs), " -> ");
202 1.5 jmmv }
203 1.5 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
204 1.5 jmmv if (field_by_value(&msg_default_bg)->flags & FLG_SET) {
205 1.5 jmmv ma.default_bg = msg_default_bg;
206 1.5 jmmv pr_field(field_by_value(&msg_default_bg),
207 1.5 jmmv " -> ");
208 1.5 jmmv }
209 1.5 jmmv if (field_by_value(&msg_default_fg)->flags & FLG_SET) {
210 1.5 jmmv ma.default_fg = msg_default_fg;
211 1.5 jmmv pr_field(field_by_value(&msg_default_fg),
212 1.5 jmmv " -> ");
213 1.5 jmmv }
214 1.5 jmmv }
215 1.5 jmmv
216 1.5 jmmv if (field_by_value(&msg_kernel_attrs)->flags & FLG_SET) {
217 1.5 jmmv ma.kernel_attrs = msg_kernel_attrs;
218 1.5 jmmv pr_field(field_by_value(&msg_kernel_attrs), " -> ");
219 1.5 jmmv }
220 1.5 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
221 1.5 jmmv if (field_by_value(&msg_kernel_bg)->flags & FLG_SET) {
222 1.5 jmmv ma.kernel_bg = msg_kernel_bg;
223 1.5 jmmv pr_field(field_by_value(&msg_kernel_bg),
224 1.5 jmmv " -> ");
225 1.5 jmmv }
226 1.5 jmmv if (field_by_value(&msg_kernel_fg)->flags & FLG_SET) {
227 1.5 jmmv ma.kernel_fg = msg_kernel_fg;
228 1.5 jmmv pr_field(field_by_value(&msg_kernel_fg),
229 1.5 jmmv " -> ");
230 1.5 jmmv }
231 1.5 jmmv }
232 1.5 jmmv
233 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_SMSGATTRS, &ma) < 0)
234 1.5 jmmv err(1, "WSDISPLAYIO_SMSGATTRS");
235 1.5 jmmv }
236 1.5 jmmv
237 1.7 jmmv scroll_l.which = 0;
238 1.7 jmmv if (field_by_value(&scroll_l.fastlines)->flags & FLG_SET)
239 1.7 jmmv scroll_l.which |= WSDISPLAY_SCROLL_DOFASTLINES;
240 1.7 jmmv if (field_by_value(&scroll_l.slowlines)->flags & FLG_SET)
241 1.7 jmmv scroll_l.which |= WSDISPLAY_SCROLL_DOSLOWLINES;
242 1.7 jmmv if (scroll_l.which != 0 &&
243 1.7 jmmv ioctl(fd, WSDISPLAYIO_DSSCROLL, &scroll_l) < 0)
244 1.7 jmmv err (1, "WSDISPLAYIO_DSSCROLL");
245 1.3 christos if (scroll_l.which & WSDISPLAY_SCROLL_DOFASTLINES)
246 1.3 christos pr_field(field_by_value(&scroll_l.fastlines), " -> ");
247 1.3 christos if (scroll_l.which & WSDISPLAY_SCROLL_DOSLOWLINES)
248 1.3 christos pr_field(field_by_value(&scroll_l.slowlines), " -> ");
249 1.1 hannken }
250