display.c revision 1.19 1 1.18 mlelstv /* $NetBSD: display.c,v 1.19 2024/10/20 13:49:41 mlelstv 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 *
19 1.1 hannken * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 hannken * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 hannken * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 hannken * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 hannken * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 hannken * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 hannken * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 hannken * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 hannken * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 hannken * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 hannken * POSSIBILITY OF SUCH DAMAGE.
30 1.1 hannken */
31 1.1 hannken
32 1.1 hannken #include <sys/ioctl.h>
33 1.4 christos #include <sys/time.h>
34 1.4 christos
35 1.12 jmmv #include <dev/wscons/wsconsio.h>
36 1.12 jmmv
37 1.12 jmmv #include <err.h>
38 1.12 jmmv #include <errno.h>
39 1.3 christos #include <stdio.h>
40 1.12 jmmv #include <stdlib.h>
41 1.4 christos #include <string.h>
42 1.4 christos
43 1.1 hannken #include "wsconsctl.h"
44 1.1 hannken
45 1.6 jmmv static int border;
46 1.1 hannken static int dpytype;
47 1.2 hannken static struct wsdisplay_usefontdata font;
48 1.18 mlelstv static struct wsdisplay_getfont gfont;
49 1.18 mlelstv static char fontname_buf[256];
50 1.10 uwe static struct wsdisplay_param backlight;
51 1.10 uwe static struct wsdisplay_param brightness;
52 1.10 uwe static struct wsdisplay_param contrast;
53 1.3 christos static struct wsdisplay_scroll_data scroll_l;
54 1.17 mlelstv static struct wsdisplayio_edid_info edid_info;
55 1.5 jmmv static int msg_default_attrs, msg_default_bg, msg_default_fg;
56 1.5 jmmv static int msg_kernel_attrs, msg_kernel_bg, msg_kernel_fg;
57 1.13 jmcneill static int splash_enable, splash_progress;
58 1.1 hannken
59 1.1 hannken struct field display_field_tab[] = {
60 1.11 jmmv { "border", &border, FMT_COLOR, 0 },
61 1.1 hannken { "type", &dpytype, FMT_DPYTYPE, FLG_RDONLY },
62 1.18 mlelstv { "font", &font.name, FMT_STRING, 0 },
63 1.10 uwe { "backlight", &backlight.curval, FMT_UINT, 0 },
64 1.10 uwe { "brightness", &brightness.curval, FMT_UINT, FLG_MODIFY },
65 1.10 uwe { "contrast", &contrast.curval, FMT_UINT, FLG_MODIFY },
66 1.12 jmmv { "scroll.fastlines", &scroll_l.fastlines, FMT_UINT, FLG_MODIFY },
67 1.12 jmmv { "scroll.slowlines", &scroll_l.slowlines, FMT_UINT, FLG_MODIFY },
68 1.17 mlelstv { "edid", &edid_info, FMT_EDID, FLG_RDONLY|FLG_NOAUTO },
69 1.11 jmmv { "msg.default.attrs", &msg_default_attrs, FMT_ATTRS, 0 },
70 1.11 jmmv { "msg.default.bg", &msg_default_bg, FMT_COLOR, 0 },
71 1.11 jmmv { "msg.default.fg", &msg_default_fg, FMT_COLOR, 0 },
72 1.11 jmmv { "msg.kernel.attrs", &msg_kernel_attrs, FMT_ATTRS, 0 },
73 1.11 jmmv { "msg.kernel.bg", &msg_kernel_bg, FMT_COLOR, 0 },
74 1.11 jmmv { "msg.kernel.fg", &msg_kernel_fg, FMT_COLOR, 0 },
75 1.14 uwe { "splash.enable", &splash_enable, FMT_UINT, FLG_WRONLY },
76 1.14 uwe { "splash.progress", &splash_progress, FMT_UINT, FLG_WRONLY },
77 1.1 hannken };
78 1.1 hannken
79 1.12 jmmv int display_field_tab_len = sizeof(display_field_tab) /
80 1.12 jmmv sizeof(display_field_tab[0]);
81 1.1 hannken
82 1.19 mlelstv static int
83 1.19 mlelstv display_get_edid(int fd, struct wsdisplayio_edid_info *ei)
84 1.19 mlelstv {
85 1.19 mlelstv size_t sz = 256;
86 1.19 mlelstv int res;
87 1.19 mlelstv
88 1.19 mlelstv while (sz <= 65536) {
89 1.19 mlelstv ei->buffer_size = sz;
90 1.19 mlelstv ei->edid_data = malloc(sz);
91 1.19 mlelstv if (ei->edid_data == NULL) {
92 1.19 mlelstv res = -1;
93 1.19 mlelstv break;
94 1.19 mlelstv }
95 1.19 mlelstv
96 1.19 mlelstv res = ioctl(fd, WSDISPLAYIO_GET_EDID, ei);
97 1.19 mlelstv if (res == 0 || errno != EAGAIN)
98 1.19 mlelstv break;
99 1.19 mlelstv
100 1.19 mlelstv free(ei->edid_data);
101 1.19 mlelstv ei->edid_data = NULL;
102 1.19 mlelstv sz *= 2;
103 1.19 mlelstv }
104 1.19 mlelstv
105 1.19 mlelstv return res;
106 1.19 mlelstv }
107 1.19 mlelstv
108 1.1 hannken void
109 1.9 xtraeme display_get_values(int fd)
110 1.1 hannken {
111 1.18 mlelstv if (field_by_value(&font.name)->flags & FLG_GET) {
112 1.18 mlelstv gfont.gf_name = fontname_buf;
113 1.18 mlelstv gfont.gf_size = sizeof(fontname_buf);
114 1.18 mlelstv font.name = gfont.gf_name;
115 1.18 mlelstv if (ioctl(fd, WSDISPLAYIO_GFONT, &gfont) < 0)
116 1.18 mlelstv field_disable_by_value(&font.name);
117 1.18 mlelstv }
118 1.12 jmmv
119 1.1 hannken if (field_by_value(&dpytype)->flags & FLG_GET)
120 1.1 hannken if (ioctl(fd, WSDISPLAYIO_GTYPE, &dpytype) < 0)
121 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_GTYPE");
122 1.3 christos
123 1.6 jmmv if (field_by_value(&border)->flags & FLG_GET)
124 1.6 jmmv if (ioctl(fd, WSDISPLAYIO_GBORDER, &border) < 0)
125 1.7 jmmv field_disable_by_value(&border);
126 1.6 jmmv
127 1.10 uwe if (field_by_value(&backlight.curval)->flags & FLG_GET) {
128 1.10 uwe backlight.param = WSDISPLAYIO_PARAM_BACKLIGHT;
129 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &backlight) < 0)
130 1.10 uwe field_disable_by_value(&backlight.curval);
131 1.10 uwe }
132 1.10 uwe
133 1.10 uwe if (field_by_value(&brightness.curval)->flags & FLG_GET) {
134 1.10 uwe brightness.param = WSDISPLAYIO_PARAM_BRIGHTNESS;
135 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &brightness))
136 1.10 uwe field_disable_by_value(&brightness.curval);
137 1.10 uwe }
138 1.10 uwe
139 1.10 uwe if (field_by_value(&contrast.curval)->flags & FLG_GET) {
140 1.10 uwe contrast.param = WSDISPLAYIO_PARAM_CONTRAST;
141 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &contrast))
142 1.10 uwe field_disable_by_value(&contrast.curval);
143 1.10 uwe }
144 1.10 uwe
145 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_GET ||
146 1.5 jmmv field_by_value(&msg_default_bg)->flags & FLG_GET ||
147 1.5 jmmv field_by_value(&msg_default_fg)->flags & FLG_GET ||
148 1.5 jmmv field_by_value(&msg_kernel_attrs)->flags & FLG_GET ||
149 1.5 jmmv field_by_value(&msg_kernel_bg)->flags & FLG_GET ||
150 1.5 jmmv field_by_value(&msg_kernel_fg)->flags & FLG_GET) {
151 1.5 jmmv struct wsdisplay_msgattrs ma;
152 1.5 jmmv
153 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_GMSGATTRS, &ma) < 0) {
154 1.7 jmmv field_disable_by_value(&msg_default_attrs);
155 1.7 jmmv field_disable_by_value(&msg_default_bg);
156 1.7 jmmv field_disable_by_value(&msg_default_fg);
157 1.7 jmmv field_disable_by_value(&msg_kernel_attrs);
158 1.7 jmmv field_disable_by_value(&msg_kernel_bg);
159 1.7 jmmv field_disable_by_value(&msg_kernel_fg);
160 1.7 jmmv } else {
161 1.7 jmmv msg_default_attrs = ma.default_attrs;
162 1.7 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
163 1.7 jmmv msg_default_bg = ma.default_bg;
164 1.7 jmmv msg_default_fg = ma.default_fg;
165 1.7 jmmv } else
166 1.7 jmmv msg_default_bg = msg_default_fg = -1;
167 1.7 jmmv
168 1.7 jmmv msg_kernel_attrs = ma.kernel_attrs;
169 1.7 jmmv if (ma.kernel_attrs & WSATTR_WSCOLORS) {
170 1.7 jmmv msg_kernel_bg = ma.kernel_bg;
171 1.7 jmmv msg_kernel_fg = ma.kernel_fg;
172 1.7 jmmv } else
173 1.7 jmmv msg_kernel_bg = msg_kernel_fg = -1;
174 1.5 jmmv }
175 1.5 jmmv }
176 1.5 jmmv
177 1.7 jmmv if (field_by_value(&scroll_l.fastlines)->flags & FLG_GET ||
178 1.7 jmmv field_by_value(&scroll_l.slowlines)->flags & FLG_GET) {
179 1.7 jmmv if (ioctl(fd, WSDISPLAYIO_DGSCROLL, &scroll_l) < 0) {
180 1.7 jmmv field_disable_by_value(&scroll_l.fastlines);
181 1.7 jmmv field_disable_by_value(&scroll_l.slowlines);
182 1.7 jmmv }
183 1.4 christos }
184 1.17 mlelstv
185 1.17 mlelstv if (field_by_value(&edid_info)->flags & FLG_GET) {
186 1.19 mlelstv if (display_get_edid(fd, &edid_info) < 0)
187 1.17 mlelstv field_disable_by_value(&edid_info);
188 1.17 mlelstv }
189 1.1 hannken }
190 1.1 hannken
191 1.1 hannken void
192 1.16 matt display_put_values(int fd)
193 1.1 hannken {
194 1.12 jmmv
195 1.2 hannken if (field_by_value(&font.name)->flags & FLG_SET) {
196 1.2 hannken if (ioctl(fd, WSDISPLAYIO_SFONT, &font) < 0)
197 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_SFONT");
198 1.2 hannken pr_field(field_by_value(&font.name), " -> ");
199 1.2 hannken }
200 1.5 jmmv
201 1.6 jmmv if (field_by_value(&border)->flags & FLG_SET) {
202 1.6 jmmv if (ioctl(fd, WSDISPLAYIO_SBORDER, &border) < 0)
203 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_SBORDER");
204 1.6 jmmv pr_field(field_by_value(&border), " -> ");
205 1.6 jmmv }
206 1.6 jmmv
207 1.10 uwe if (field_by_value(&backlight.curval)->flags & FLG_SET) {
208 1.10 uwe backlight.param = WSDISPLAYIO_PARAM_BACKLIGHT;
209 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &backlight) < 0)
210 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_PARAM_BACKLIGHT");
211 1.10 uwe pr_field(field_by_value(&backlight.curval), " -> ");
212 1.10 uwe }
213 1.10 uwe
214 1.10 uwe if (field_by_value(&brightness.curval)->flags & FLG_SET) {
215 1.10 uwe brightness.param = WSDISPLAYIO_PARAM_BRIGHTNESS;
216 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &brightness) < 0)
217 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_PARAM_BRIGHTNESS");
218 1.10 uwe pr_field(field_by_value(&brightness.curval), " -> ");
219 1.10 uwe }
220 1.10 uwe
221 1.10 uwe if (field_by_value(&contrast.curval)->flags & FLG_SET) {
222 1.10 uwe contrast.param = WSDISPLAYIO_PARAM_CONTRAST;
223 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &contrast) < 0)
224 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_PARAM_CONTRAST");
225 1.10 uwe pr_field(field_by_value(&contrast.curval), " -> ");
226 1.10 uwe }
227 1.10 uwe
228 1.13 jmcneill if (field_by_value(&splash_enable)->flags & FLG_SET) {
229 1.13 jmcneill if (ioctl(fd, WSDISPLAYIO_SSPLASH, &splash_enable) < 0)
230 1.13 jmcneill err(EXIT_FAILURE, "WSDISPLAYIO_SSPLASH");
231 1.13 jmcneill pr_field(field_by_value(&splash_enable), " -> ");
232 1.13 jmcneill }
233 1.13 jmcneill
234 1.13 jmcneill if (field_by_value(&splash_progress)->flags & FLG_SET) {
235 1.13 jmcneill if (ioctl(fd, WSDISPLAYIO_SPROGRESS, &splash_progress) < 0)
236 1.13 jmcneill err(EXIT_FAILURE, "WSDISPLAYIO_SPROGRESS");
237 1.13 jmcneill pr_field(field_by_value(&splash_progress), " -> ");
238 1.13 jmcneill }
239 1.13 jmcneill
240 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_SET ||
241 1.5 jmmv field_by_value(&msg_default_bg)->flags & FLG_SET ||
242 1.5 jmmv field_by_value(&msg_default_fg)->flags & FLG_SET ||
243 1.5 jmmv field_by_value(&msg_kernel_attrs)->flags & FLG_SET ||
244 1.5 jmmv field_by_value(&msg_kernel_bg)->flags & FLG_SET ||
245 1.5 jmmv field_by_value(&msg_kernel_fg)->flags & FLG_SET) {
246 1.5 jmmv struct wsdisplay_msgattrs ma;
247 1.5 jmmv
248 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_GMSGATTRS, &ma) < 0)
249 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_GMSGATTRS");
250 1.5 jmmv
251 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_SET) {
252 1.5 jmmv ma.default_attrs = msg_default_attrs;
253 1.5 jmmv pr_field(field_by_value(&msg_default_attrs), " -> ");
254 1.5 jmmv }
255 1.5 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
256 1.5 jmmv if (field_by_value(&msg_default_bg)->flags & FLG_SET) {
257 1.5 jmmv ma.default_bg = msg_default_bg;
258 1.5 jmmv pr_field(field_by_value(&msg_default_bg),
259 1.12 jmmv " -> ");
260 1.5 jmmv }
261 1.5 jmmv if (field_by_value(&msg_default_fg)->flags & FLG_SET) {
262 1.5 jmmv ma.default_fg = msg_default_fg;
263 1.5 jmmv pr_field(field_by_value(&msg_default_fg),
264 1.12 jmmv " -> ");
265 1.5 jmmv }
266 1.5 jmmv }
267 1.5 jmmv
268 1.5 jmmv if (field_by_value(&msg_kernel_attrs)->flags & FLG_SET) {
269 1.5 jmmv ma.kernel_attrs = msg_kernel_attrs;
270 1.5 jmmv pr_field(field_by_value(&msg_kernel_attrs), " -> ");
271 1.5 jmmv }
272 1.5 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
273 1.5 jmmv if (field_by_value(&msg_kernel_bg)->flags & FLG_SET) {
274 1.5 jmmv ma.kernel_bg = msg_kernel_bg;
275 1.5 jmmv pr_field(field_by_value(&msg_kernel_bg),
276 1.12 jmmv " -> ");
277 1.5 jmmv }
278 1.5 jmmv if (field_by_value(&msg_kernel_fg)->flags & FLG_SET) {
279 1.5 jmmv ma.kernel_fg = msg_kernel_fg;
280 1.5 jmmv pr_field(field_by_value(&msg_kernel_fg),
281 1.12 jmmv " -> ");
282 1.5 jmmv }
283 1.5 jmmv }
284 1.5 jmmv
285 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_SMSGATTRS, &ma) < 0)
286 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_SMSGATTRS");
287 1.5 jmmv }
288 1.5 jmmv
289 1.7 jmmv scroll_l.which = 0;
290 1.7 jmmv if (field_by_value(&scroll_l.fastlines)->flags & FLG_SET)
291 1.7 jmmv scroll_l.which |= WSDISPLAY_SCROLL_DOFASTLINES;
292 1.7 jmmv if (field_by_value(&scroll_l.slowlines)->flags & FLG_SET)
293 1.7 jmmv scroll_l.which |= WSDISPLAY_SCROLL_DOSLOWLINES;
294 1.7 jmmv if (scroll_l.which != 0 &&
295 1.7 jmmv ioctl(fd, WSDISPLAYIO_DSSCROLL, &scroll_l) < 0)
296 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_DSSCROLL");
297 1.3 christos if (scroll_l.which & WSDISPLAY_SCROLL_DOFASTLINES)
298 1.3 christos pr_field(field_by_value(&scroll_l.fastlines), " -> ");
299 1.3 christos if (scroll_l.which & WSDISPLAY_SCROLL_DOSLOWLINES)
300 1.3 christos pr_field(field_by_value(&scroll_l.slowlines), " -> ");
301 1.1 hannken }
302