wsfontload.c revision 1.6 1 1.6 cgd /* $NetBSD: wsfontload.c,v 1.6 2001/02/19 23:22:50 cgd Exp $ */
2 1.1 drochner
3 1.1 drochner /*
4 1.1 drochner * Copyright (c) 1999
5 1.1 drochner * Matthias Drochner. All rights reserved.
6 1.1 drochner *
7 1.1 drochner * Redistribution and use in source and binary forms, with or without
8 1.1 drochner * modification, are permitted provided that the following conditions
9 1.1 drochner * are met:
10 1.1 drochner * 1. Redistributions of source code must retain the above copyright
11 1.1 drochner * notice, this list of conditions and the following disclaimer.
12 1.1 drochner * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 drochner * notice, this list of conditions and the following disclaimer in the
14 1.1 drochner * documentation and/or other materials provided with the distribution.
15 1.1 drochner * 3. All advertising materials mentioning features or use of this software
16 1.1 drochner * must display the following acknowledgement:
17 1.1 drochner * This product includes software developed for the NetBSD Project
18 1.1 drochner * by Matthias Drochner.
19 1.1 drochner * 4. The name of the author may not be used to endorse or promote products
20 1.1 drochner * derived from this software without specific prior written permission.
21 1.1 drochner *
22 1.1 drochner * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23 1.1 drochner * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 drochner * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 drochner * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26 1.1 drochner * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27 1.1 drochner * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 1.1 drochner * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 1.1 drochner * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 1.1 drochner * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31 1.1 drochner * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 drochner *
33 1.1 drochner */
34 1.1 drochner
35 1.1 drochner #include <stdio.h>
36 1.1 drochner #include <fcntl.h>
37 1.6 cgd #include <stdlib.h>
38 1.4 matt #include <string.h>
39 1.1 drochner #include <unistd.h>
40 1.1 drochner #include <sys/types.h>
41 1.1 drochner #include <sys/ioctl.h>
42 1.1 drochner #include <err.h>
43 1.1 drochner #include <malloc.h>
44 1.1 drochner
45 1.1 drochner #include <dev/wscons/wsconsio.h>
46 1.1 drochner
47 1.3 ad #define DEFDEV "/dev/ttyEcfg"
48 1.3 ad #define DEFWIDTH 8
49 1.3 ad #define DEFHEIGHT 16
50 1.3 ad #define DEFENC WSDISPLAY_FONTENC_ISO
51 1.3 ad #define DEFBITORDER WSDISPLAY_FONTORDER_L2R
52 1.3 ad #define DEFBYTEORDER WSDISPLAY_FONTORDER_L2R
53 1.1 drochner
54 1.1 drochner int main __P((int, char**));
55 1.1 drochner static void usage __P((void));
56 1.1 drochner static int getencoding __P((char *));
57 1.5 hubertf static char *rgetencoding __P((int));
58 1.5 hubertf static char *rgetfontorder __P((int));
59 1.5 hubertf
60 1.5 hubertf static struct {
61 1.5 hubertf char *name;
62 1.5 hubertf int val;
63 1.5 hubertf } fontorders[] = {
64 1.5 hubertf { "known", WSDISPLAY_FONTORDER_KNOWN},
65 1.5 hubertf { "l2r", WSDISPLAY_FONTORDER_L2R},
66 1.5 hubertf { "r2l", WSDISPLAY_FONTORDER_R2L},
67 1.5 hubertf };
68 1.5 hubertf
69 1.5 hubertf static struct {
70 1.5 hubertf char *name;
71 1.5 hubertf int val;
72 1.5 hubertf } encodings[] = {
73 1.5 hubertf {"iso", WSDISPLAY_FONTENC_ISO},
74 1.5 hubertf {"ibm", WSDISPLAY_FONTENC_IBM},
75 1.5 hubertf {"pcvt", WSDISPLAY_FONTENC_PCVT},
76 1.5 hubertf };
77 1.1 drochner
78 1.1 drochner static void
79 1.1 drochner usage()
80 1.1 drochner {
81 1.1 drochner
82 1.1 drochner (void)fprintf(stderr,
83 1.1 drochner "Usage: %s [-f wsdev] [-w width] [-h height] [-e encoding]"
84 1.3 ad " [-N name] [-b] [-B] [fontfile]\n",
85 1.6 cgd getprogname());
86 1.1 drochner exit(1);
87 1.1 drochner }
88 1.1 drochner
89 1.5 hubertf /*
90 1.5 hubertf * map given fontorder to it's string representation
91 1.5 hubertf */
92 1.5 hubertf static char *
93 1.5 hubertf rgetfontorder(fontorder)
94 1.5 hubertf int fontorder;
95 1.5 hubertf {
96 1.5 hubertf int i;
97 1.5 hubertf
98 1.5 hubertf for (i = 0; i < sizeof(fontorders) / sizeof(fontorders[0]); i++)
99 1.5 hubertf if (fontorders[i].val == fontorder)
100 1.5 hubertf return (fontorders[i].name);
101 1.5 hubertf
102 1.5 hubertf return "unknown";
103 1.5 hubertf }
104 1.5 hubertf
105 1.5 hubertf /*
106 1.5 hubertf * map given encoding to it's string representation
107 1.5 hubertf */
108 1.5 hubertf static char *
109 1.5 hubertf rgetencoding(enc)
110 1.5 hubertf int enc;
111 1.5 hubertf {
112 1.5 hubertf int i;
113 1.5 hubertf
114 1.5 hubertf for (i = 0; i < sizeof(encodings) / sizeof(encodings[0]); i++)
115 1.5 hubertf if (encodings[i].val == enc)
116 1.5 hubertf return (encodings[i].name);
117 1.5 hubertf
118 1.5 hubertf return "unknown";
119 1.5 hubertf }
120 1.5 hubertf
121 1.5 hubertf /*
122 1.5 hubertf * map given encoding string to integer value
123 1.5 hubertf */
124 1.5 hubertf static int
125 1.5 hubertf getencoding(name)
126 1.5 hubertf char *name;
127 1.5 hubertf {
128 1.5 hubertf int i;
129 1.5 hubertf
130 1.5 hubertf for (i = 0; i < sizeof(encodings) / sizeof(encodings[0]); i++)
131 1.5 hubertf if (!strcmp(name, encodings[i].name))
132 1.5 hubertf return (encodings[i].val);
133 1.5 hubertf
134 1.5 hubertf if (sscanf(name, "%d", &i) != 1)
135 1.5 hubertf errx(1, "invalid encoding");
136 1.5 hubertf return (i);
137 1.5 hubertf }
138 1.5 hubertf
139 1.1 drochner int
140 1.1 drochner main(argc, argv)
141 1.1 drochner int argc;
142 1.1 drochner char **argv;
143 1.1 drochner {
144 1.1 drochner char *wsdev;
145 1.1 drochner struct wsdisplay_font f;
146 1.5 hubertf int c, res, wsfd, ffd, verbose;
147 1.1 drochner size_t len;
148 1.1 drochner void *buf;
149 1.1 drochner
150 1.1 drochner wsdev = DEFDEV;
151 1.1 drochner f.fontwidth = DEFWIDTH;
152 1.1 drochner f.fontheight = DEFHEIGHT;
153 1.1 drochner f.firstchar = 0;
154 1.1 drochner f.numchars = 256;
155 1.1 drochner f.stride = 0;
156 1.1 drochner f.encoding = DEFENC;
157 1.1 drochner f.name = 0;
158 1.3 ad f.bitorder = DEFBITORDER;
159 1.3 ad f.byteorder = DEFBYTEORDER;
160 1.1 drochner
161 1.5 hubertf while ((c = getopt(argc, argv, "f:w:h:e:N:bB:v")) != -1) {
162 1.1 drochner switch (c) {
163 1.1 drochner case 'f':
164 1.1 drochner wsdev = optarg;
165 1.1 drochner break;
166 1.1 drochner case 'w':
167 1.1 drochner if (sscanf(optarg, "%d", &f.fontwidth) != 1)
168 1.1 drochner errx(1, "invalid font width");
169 1.1 drochner break;
170 1.1 drochner case 'h':
171 1.1 drochner if (sscanf(optarg, "%d", &f.fontheight) != 1)
172 1.1 drochner errx(1, "invalid font height");
173 1.1 drochner break;
174 1.1 drochner case 'e':
175 1.1 drochner f.encoding = getencoding(optarg);
176 1.1 drochner break;
177 1.1 drochner case 'N':
178 1.1 drochner f.name = optarg;
179 1.2 ad break;
180 1.2 ad case 'b':
181 1.2 ad f.bitorder = WSDISPLAY_FONTORDER_R2L;
182 1.2 ad break;
183 1.2 ad case 'B':
184 1.2 ad f.byteorder = WSDISPLAY_FONTORDER_R2L;
185 1.1 drochner break;
186 1.5 hubertf case 'v':
187 1.5 hubertf verbose = 1;
188 1.5 hubertf break;
189 1.1 drochner case '?':
190 1.1 drochner default:
191 1.1 drochner usage();
192 1.1 drochner break;
193 1.1 drochner }
194 1.1 drochner }
195 1.1 drochner argc -= optind;
196 1.1 drochner argv += optind;
197 1.1 drochner
198 1.1 drochner if (argc > 1)
199 1.1 drochner usage();
200 1.1 drochner
201 1.1 drochner wsfd = open(wsdev, O_RDWR, 0);
202 1.1 drochner if (wsfd < 0)
203 1.5 hubertf err(2, "open ws-device %s", wsdev);
204 1.1 drochner
205 1.1 drochner if (argc > 0) {
206 1.1 drochner ffd = open(argv[0], O_RDONLY, 0);
207 1.1 drochner if (ffd < 0)
208 1.5 hubertf err(4, "open font %s", argv[0]);
209 1.1 drochner if (!f.name)
210 1.1 drochner f.name = argv[0];
211 1.1 drochner } else
212 1.1 drochner ffd = 0;
213 1.1 drochner
214 1.1 drochner if (!f.stride)
215 1.1 drochner f.stride = (f.fontwidth + 7) / 8;
216 1.1 drochner len = f.fontheight * f.numchars * f.stride;
217 1.1 drochner if (!len)
218 1.1 drochner errx(1, "invalid font size");
219 1.1 drochner
220 1.1 drochner buf = malloc(len);
221 1.1 drochner if (!buf)
222 1.1 drochner errx(1, "malloc");
223 1.1 drochner res = read(ffd, buf, len);
224 1.1 drochner if (res < 0)
225 1.1 drochner err(4, "read font");
226 1.1 drochner if (res != len)
227 1.1 drochner errx(4, "short read");
228 1.1 drochner
229 1.1 drochner f.data = buf;
230 1.1 drochner
231 1.5 hubertf if (verbose) {
232 1.5 hubertf printf("name: %s\n", f.name);
233 1.5 hubertf printf("firstchar: %d\n", f.firstchar);
234 1.5 hubertf printf("numchars: %d\n", f.numchars);
235 1.5 hubertf printf("encoding: %s (%d)\n",
236 1.5 hubertf rgetencoding(f.encoding), f.encoding);
237 1.5 hubertf printf("fontwidth: %d\n", f.fontwidth);
238 1.5 hubertf printf("fontheight: %d\n", f.fontheight);
239 1.5 hubertf printf("stride: %d\n", f.stride);
240 1.5 hubertf printf("bitorder: %s (%d)\n",
241 1.5 hubertf rgetfontorder(f.bitorder), f.bitorder);
242 1.5 hubertf printf("byteorder: %s (%d)\n",
243 1.5 hubertf rgetfontorder(f.byteorder), f.byteorder);
244 1.5 hubertf }
245 1.5 hubertf
246 1.1 drochner res = ioctl(wsfd, WSDISPLAYIO_LDFONT, &f);
247 1.1 drochner if (res < 0)
248 1.1 drochner err(3, "WSDISPLAYIO_LDFONT");
249 1.1 drochner
250 1.1 drochner return (0);
251 1.1 drochner }
252