display.c revision 1.18 1 1.18 mlelstv /* $NetBSD: display.c,v 1.18 2024/10/20 13:44:37 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.17 mlelstv static uint8_t edid_buf[256];
56 1.5 jmmv static int msg_default_attrs, msg_default_bg, msg_default_fg;
57 1.5 jmmv static int msg_kernel_attrs, msg_kernel_bg, msg_kernel_fg;
58 1.13 jmcneill static int splash_enable, splash_progress;
59 1.1 hannken
60 1.1 hannken struct field display_field_tab[] = {
61 1.11 jmmv { "border", &border, FMT_COLOR, 0 },
62 1.1 hannken { "type", &dpytype, FMT_DPYTYPE, FLG_RDONLY },
63 1.18 mlelstv { "font", &font.name, FMT_STRING, 0 },
64 1.10 uwe { "backlight", &backlight.curval, FMT_UINT, 0 },
65 1.10 uwe { "brightness", &brightness.curval, FMT_UINT, FLG_MODIFY },
66 1.10 uwe { "contrast", &contrast.curval, FMT_UINT, FLG_MODIFY },
67 1.12 jmmv { "scroll.fastlines", &scroll_l.fastlines, FMT_UINT, FLG_MODIFY },
68 1.12 jmmv { "scroll.slowlines", &scroll_l.slowlines, FMT_UINT, FLG_MODIFY },
69 1.17 mlelstv { "edid", &edid_info, FMT_EDID, FLG_RDONLY|FLG_NOAUTO },
70 1.11 jmmv { "msg.default.attrs", &msg_default_attrs, FMT_ATTRS, 0 },
71 1.11 jmmv { "msg.default.bg", &msg_default_bg, FMT_COLOR, 0 },
72 1.11 jmmv { "msg.default.fg", &msg_default_fg, FMT_COLOR, 0 },
73 1.11 jmmv { "msg.kernel.attrs", &msg_kernel_attrs, FMT_ATTRS, 0 },
74 1.11 jmmv { "msg.kernel.bg", &msg_kernel_bg, FMT_COLOR, 0 },
75 1.11 jmmv { "msg.kernel.fg", &msg_kernel_fg, FMT_COLOR, 0 },
76 1.14 uwe { "splash.enable", &splash_enable, FMT_UINT, FLG_WRONLY },
77 1.14 uwe { "splash.progress", &splash_progress, FMT_UINT, FLG_WRONLY },
78 1.1 hannken };
79 1.1 hannken
80 1.12 jmmv int display_field_tab_len = sizeof(display_field_tab) /
81 1.12 jmmv sizeof(display_field_tab[0]);
82 1.1 hannken
83 1.1 hannken void
84 1.9 xtraeme display_get_values(int fd)
85 1.1 hannken {
86 1.18 mlelstv if (field_by_value(&font.name)->flags & FLG_GET) {
87 1.18 mlelstv gfont.gf_name = fontname_buf;
88 1.18 mlelstv gfont.gf_size = sizeof(fontname_buf);
89 1.18 mlelstv font.name = gfont.gf_name;
90 1.18 mlelstv if (ioctl(fd, WSDISPLAYIO_GFONT, &gfont) < 0)
91 1.18 mlelstv field_disable_by_value(&font.name);
92 1.18 mlelstv }
93 1.12 jmmv
94 1.1 hannken if (field_by_value(&dpytype)->flags & FLG_GET)
95 1.1 hannken if (ioctl(fd, WSDISPLAYIO_GTYPE, &dpytype) < 0)
96 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_GTYPE");
97 1.3 christos
98 1.6 jmmv if (field_by_value(&border)->flags & FLG_GET)
99 1.6 jmmv if (ioctl(fd, WSDISPLAYIO_GBORDER, &border) < 0)
100 1.7 jmmv field_disable_by_value(&border);
101 1.6 jmmv
102 1.10 uwe if (field_by_value(&backlight.curval)->flags & FLG_GET) {
103 1.10 uwe backlight.param = WSDISPLAYIO_PARAM_BACKLIGHT;
104 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &backlight) < 0)
105 1.10 uwe field_disable_by_value(&backlight.curval);
106 1.10 uwe }
107 1.10 uwe
108 1.10 uwe if (field_by_value(&brightness.curval)->flags & FLG_GET) {
109 1.10 uwe brightness.param = WSDISPLAYIO_PARAM_BRIGHTNESS;
110 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &brightness))
111 1.10 uwe field_disable_by_value(&brightness.curval);
112 1.10 uwe }
113 1.10 uwe
114 1.10 uwe if (field_by_value(&contrast.curval)->flags & FLG_GET) {
115 1.10 uwe contrast.param = WSDISPLAYIO_PARAM_CONTRAST;
116 1.10 uwe if (ioctl(fd, WSDISPLAYIO_GETPARAM, &contrast))
117 1.10 uwe field_disable_by_value(&contrast.curval);
118 1.10 uwe }
119 1.10 uwe
120 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_GET ||
121 1.5 jmmv field_by_value(&msg_default_bg)->flags & FLG_GET ||
122 1.5 jmmv field_by_value(&msg_default_fg)->flags & FLG_GET ||
123 1.5 jmmv field_by_value(&msg_kernel_attrs)->flags & FLG_GET ||
124 1.5 jmmv field_by_value(&msg_kernel_bg)->flags & FLG_GET ||
125 1.5 jmmv field_by_value(&msg_kernel_fg)->flags & FLG_GET) {
126 1.5 jmmv struct wsdisplay_msgattrs ma;
127 1.5 jmmv
128 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_GMSGATTRS, &ma) < 0) {
129 1.7 jmmv field_disable_by_value(&msg_default_attrs);
130 1.7 jmmv field_disable_by_value(&msg_default_bg);
131 1.7 jmmv field_disable_by_value(&msg_default_fg);
132 1.7 jmmv field_disable_by_value(&msg_kernel_attrs);
133 1.7 jmmv field_disable_by_value(&msg_kernel_bg);
134 1.7 jmmv field_disable_by_value(&msg_kernel_fg);
135 1.7 jmmv } else {
136 1.7 jmmv msg_default_attrs = ma.default_attrs;
137 1.7 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
138 1.7 jmmv msg_default_bg = ma.default_bg;
139 1.7 jmmv msg_default_fg = ma.default_fg;
140 1.7 jmmv } else
141 1.7 jmmv msg_default_bg = msg_default_fg = -1;
142 1.7 jmmv
143 1.7 jmmv msg_kernel_attrs = ma.kernel_attrs;
144 1.7 jmmv if (ma.kernel_attrs & WSATTR_WSCOLORS) {
145 1.7 jmmv msg_kernel_bg = ma.kernel_bg;
146 1.7 jmmv msg_kernel_fg = ma.kernel_fg;
147 1.7 jmmv } else
148 1.7 jmmv msg_kernel_bg = msg_kernel_fg = -1;
149 1.5 jmmv }
150 1.5 jmmv }
151 1.5 jmmv
152 1.7 jmmv if (field_by_value(&scroll_l.fastlines)->flags & FLG_GET ||
153 1.7 jmmv field_by_value(&scroll_l.slowlines)->flags & FLG_GET) {
154 1.7 jmmv if (ioctl(fd, WSDISPLAYIO_DGSCROLL, &scroll_l) < 0) {
155 1.7 jmmv field_disable_by_value(&scroll_l.fastlines);
156 1.7 jmmv field_disable_by_value(&scroll_l.slowlines);
157 1.7 jmmv }
158 1.4 christos }
159 1.17 mlelstv
160 1.17 mlelstv if (field_by_value(&edid_info)->flags & FLG_GET) {
161 1.17 mlelstv edid_info.edid_data = edid_buf;
162 1.17 mlelstv edid_info.buffer_size = sizeof(edid_buf);
163 1.17 mlelstv if (ioctl(fd, WSDISPLAYIO_GET_EDID, &edid_info) < 0) {
164 1.17 mlelstv field_disable_by_value(&edid_info);
165 1.17 mlelstv }
166 1.17 mlelstv }
167 1.1 hannken }
168 1.1 hannken
169 1.1 hannken void
170 1.16 matt display_put_values(int fd)
171 1.1 hannken {
172 1.12 jmmv
173 1.2 hannken if (field_by_value(&font.name)->flags & FLG_SET) {
174 1.2 hannken if (ioctl(fd, WSDISPLAYIO_SFONT, &font) < 0)
175 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_SFONT");
176 1.2 hannken pr_field(field_by_value(&font.name), " -> ");
177 1.2 hannken }
178 1.5 jmmv
179 1.6 jmmv if (field_by_value(&border)->flags & FLG_SET) {
180 1.6 jmmv if (ioctl(fd, WSDISPLAYIO_SBORDER, &border) < 0)
181 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_SBORDER");
182 1.6 jmmv pr_field(field_by_value(&border), " -> ");
183 1.6 jmmv }
184 1.6 jmmv
185 1.10 uwe if (field_by_value(&backlight.curval)->flags & FLG_SET) {
186 1.10 uwe backlight.param = WSDISPLAYIO_PARAM_BACKLIGHT;
187 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &backlight) < 0)
188 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_PARAM_BACKLIGHT");
189 1.10 uwe pr_field(field_by_value(&backlight.curval), " -> ");
190 1.10 uwe }
191 1.10 uwe
192 1.10 uwe if (field_by_value(&brightness.curval)->flags & FLG_SET) {
193 1.10 uwe brightness.param = WSDISPLAYIO_PARAM_BRIGHTNESS;
194 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &brightness) < 0)
195 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_PARAM_BRIGHTNESS");
196 1.10 uwe pr_field(field_by_value(&brightness.curval), " -> ");
197 1.10 uwe }
198 1.10 uwe
199 1.10 uwe if (field_by_value(&contrast.curval)->flags & FLG_SET) {
200 1.10 uwe contrast.param = WSDISPLAYIO_PARAM_CONTRAST;
201 1.10 uwe if (ioctl(fd, WSDISPLAYIO_SETPARAM, &contrast) < 0)
202 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_PARAM_CONTRAST");
203 1.10 uwe pr_field(field_by_value(&contrast.curval), " -> ");
204 1.10 uwe }
205 1.10 uwe
206 1.13 jmcneill if (field_by_value(&splash_enable)->flags & FLG_SET) {
207 1.13 jmcneill if (ioctl(fd, WSDISPLAYIO_SSPLASH, &splash_enable) < 0)
208 1.13 jmcneill err(EXIT_FAILURE, "WSDISPLAYIO_SSPLASH");
209 1.13 jmcneill pr_field(field_by_value(&splash_enable), " -> ");
210 1.13 jmcneill }
211 1.13 jmcneill
212 1.13 jmcneill if (field_by_value(&splash_progress)->flags & FLG_SET) {
213 1.13 jmcneill if (ioctl(fd, WSDISPLAYIO_SPROGRESS, &splash_progress) < 0)
214 1.13 jmcneill err(EXIT_FAILURE, "WSDISPLAYIO_SPROGRESS");
215 1.13 jmcneill pr_field(field_by_value(&splash_progress), " -> ");
216 1.13 jmcneill }
217 1.13 jmcneill
218 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_SET ||
219 1.5 jmmv field_by_value(&msg_default_bg)->flags & FLG_SET ||
220 1.5 jmmv field_by_value(&msg_default_fg)->flags & FLG_SET ||
221 1.5 jmmv field_by_value(&msg_kernel_attrs)->flags & FLG_SET ||
222 1.5 jmmv field_by_value(&msg_kernel_bg)->flags & FLG_SET ||
223 1.5 jmmv field_by_value(&msg_kernel_fg)->flags & FLG_SET) {
224 1.5 jmmv struct wsdisplay_msgattrs ma;
225 1.5 jmmv
226 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_GMSGATTRS, &ma) < 0)
227 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_GMSGATTRS");
228 1.5 jmmv
229 1.5 jmmv if (field_by_value(&msg_default_attrs)->flags & FLG_SET) {
230 1.5 jmmv ma.default_attrs = msg_default_attrs;
231 1.5 jmmv pr_field(field_by_value(&msg_default_attrs), " -> ");
232 1.5 jmmv }
233 1.5 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
234 1.5 jmmv if (field_by_value(&msg_default_bg)->flags & FLG_SET) {
235 1.5 jmmv ma.default_bg = msg_default_bg;
236 1.5 jmmv pr_field(field_by_value(&msg_default_bg),
237 1.12 jmmv " -> ");
238 1.5 jmmv }
239 1.5 jmmv if (field_by_value(&msg_default_fg)->flags & FLG_SET) {
240 1.5 jmmv ma.default_fg = msg_default_fg;
241 1.5 jmmv pr_field(field_by_value(&msg_default_fg),
242 1.12 jmmv " -> ");
243 1.5 jmmv }
244 1.5 jmmv }
245 1.5 jmmv
246 1.5 jmmv if (field_by_value(&msg_kernel_attrs)->flags & FLG_SET) {
247 1.5 jmmv ma.kernel_attrs = msg_kernel_attrs;
248 1.5 jmmv pr_field(field_by_value(&msg_kernel_attrs), " -> ");
249 1.5 jmmv }
250 1.5 jmmv if (ma.default_attrs & WSATTR_WSCOLORS) {
251 1.5 jmmv if (field_by_value(&msg_kernel_bg)->flags & FLG_SET) {
252 1.5 jmmv ma.kernel_bg = msg_kernel_bg;
253 1.5 jmmv pr_field(field_by_value(&msg_kernel_bg),
254 1.12 jmmv " -> ");
255 1.5 jmmv }
256 1.5 jmmv if (field_by_value(&msg_kernel_fg)->flags & FLG_SET) {
257 1.5 jmmv ma.kernel_fg = msg_kernel_fg;
258 1.5 jmmv pr_field(field_by_value(&msg_kernel_fg),
259 1.12 jmmv " -> ");
260 1.5 jmmv }
261 1.5 jmmv }
262 1.5 jmmv
263 1.5 jmmv if (ioctl(fd, WSDISPLAYIO_SMSGATTRS, &ma) < 0)
264 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_SMSGATTRS");
265 1.5 jmmv }
266 1.5 jmmv
267 1.7 jmmv scroll_l.which = 0;
268 1.7 jmmv if (field_by_value(&scroll_l.fastlines)->flags & FLG_SET)
269 1.7 jmmv scroll_l.which |= WSDISPLAY_SCROLL_DOFASTLINES;
270 1.7 jmmv if (field_by_value(&scroll_l.slowlines)->flags & FLG_SET)
271 1.7 jmmv scroll_l.which |= WSDISPLAY_SCROLL_DOSLOWLINES;
272 1.7 jmmv if (scroll_l.which != 0 &&
273 1.7 jmmv ioctl(fd, WSDISPLAYIO_DSSCROLL, &scroll_l) < 0)
274 1.12 jmmv err(EXIT_FAILURE, "WSDISPLAYIO_DSSCROLL");
275 1.3 christos if (scroll_l.which & WSDISPLAY_SCROLL_DOFASTLINES)
276 1.3 christos pr_field(field_by_value(&scroll_l.fastlines), " -> ");
277 1.3 christos if (scroll_l.which & WSDISPLAY_SCROLL_DOSLOWLINES)
278 1.3 christos pr_field(field_by_value(&scroll_l.slowlines), " -> ");
279 1.1 hannken }
280