1 /* $NetBSD: key.c,v 1.19 2003/08/07 09:05:41 agc Exp $ */
4 * Copyright (c) 1991, 1993, 1994
5 * The Regents of the University of California. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
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 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 #include <sys/cdefs.h>
35 static char sccsid
[] = "@(#)key.c 8.4 (Berkeley) 2/20/95";
37 __RCSID("$NetBSD: key.c,v 1.19 2003/08/07 09:05:41 agc Exp $");
41 #include <sys/types.h>
56 void f_all(struct info
*);
57 void f_cbreak(struct info
*);
58 void f_columns(struct info
*);
59 void f_dec(struct info
*);
60 void f_everything(struct info
*);
61 void f_extproc(struct info
*);
62 void f_insane(struct info
*);
63 void f_ispeed(struct info
*);
64 void f_nl(struct info
*);
65 void f_ospeed(struct info
*);
66 void f_raw(struct info
*);
67 void f_rows(struct info
*);
68 void f_sane(struct info
*);
69 void f_size(struct info
*);
70 void f_speed(struct info
*);
71 void f_ostart(struct info
*);
72 void f_ostop(struct info
*);
73 void f_tty(struct info
*);
76 static const struct key
{
77 const char *name
; /* name */
78 void (*f
)(struct info
*); /* function */
79 #define F_NEEDARG 0x01 /* needs an argument */
80 #define F_OFFOK 0x02 /* can turn off */
84 { "cbreak", f_cbreak
, F_OFFOK
},
85 { "cols", f_columns
, F_NEEDARG
},
86 { "columns", f_columns
, F_NEEDARG
},
87 { "cooked", f_sane
, 0 },
89 { "everything", f_everything
, 0 },
90 { "extproc", f_extproc
, F_OFFOK
},
91 { "insane", f_insane
, 0 },
92 { "ispeed", f_ispeed
, F_NEEDARG
},
94 { "nl", f_nl
, F_OFFOK
},
96 { "ospeed", f_ospeed
, F_NEEDARG
},
97 { "ostart", f_ostart
, 0 },
98 { "ostop", f_ostop
, 0 },
99 { "raw", f_raw
, F_OFFOK
},
100 { "rows", f_rows
, F_NEEDARG
},
101 { "sane", f_sane
, 0 },
102 { "size", f_size
, 0 },
103 { "speed", f_speed
, 0 },
107 static int c_key(const void *, const void *);
110 c_key(const void *a
, const void *b
)
113 return (strcmp(((const struct key
*)a
)->name
,
114 ((const struct key
*)b
)->name
));
118 ksearch(char ***argvp
, struct info
*ip
)
131 if (!(kp
= (struct key
*)bsearch(&tmp
, keys
,
132 sizeof(keys
)/sizeof(struct key
), sizeof(struct key
), c_key
)))
134 if (!(kp
->flags
& F_OFFOK
) && ip
->off
) {
135 warnx("illegal option -- %s", name
);
138 if (kp
->flags
& F_NEEDARG
&& !(ip
->arg
= *++*argvp
)) {
139 warnx("option requires an argument -- %s", name
);
147 f_all(struct info
*ip
)
149 print(&ip
->t
, &ip
->win
, ip
->ldisc
, STTY_BSD
);
153 f_cbreak(struct info
*ip
)
158 ip
->t
.c_iflag
|= BRKINT
|IXON
|IMAXBEL
;
159 ip
->t
.c_oflag
|= OPOST
;
160 ip
->t
.c_lflag
|= ISIG
|IEXTEN
;
161 ip
->t
.c_lflag
&= ~ICANON
;
167 f_columns(struct info
*ip
)
169 ip
->win
.ws_col
= atoi(ip
->arg
);
174 f_dec(struct info
*ip
)
176 ip
->t
.c_cc
[VERASE
] = (u_char
)0177;
177 ip
->t
.c_cc
[VKILL
] = CTRL('u');
178 ip
->t
.c_cc
[VINTR
] = CTRL('c');
179 ip
->t
.c_lflag
&= ~ECHOPRT
;
180 ip
->t
.c_lflag
|= ECHOE
|ECHOKE
|ECHOCTL
;
181 ip
->t
.c_iflag
&= ~IXANY
;
186 f_everything(struct info
*ip
)
188 print(&ip
->t
, &ip
->win
, ip
->ldisc
, STTY_BSD
);
192 f_extproc(struct info
*ip
)
197 (void)ioctl(ip
->fd
, TIOCEXT
, &tmp
);
200 (void)ioctl(ip
->fd
, TIOCEXT
, &tmp
);
207 f_insane(struct info
*ip
)
211 r
= f
= open(_PATH_URANDOM
, O_RDONLY
, 0);
213 r
= read(f
, &(ip
->t
), sizeof(struct termios
));
217 /* XXX not cryptographically secure! */
220 ip
->t
.c_iflag
= random();
221 ip
->t
.c_oflag
= random();
222 ip
->t
.c_cflag
= random();
223 ip
->t
.c_lflag
= random();
224 for (f
= 0; f
< NCCS
; f
++) {
225 ip
->t
.c_cc
[f
] = random() & 0xFF;
227 ip
->t
.c_ispeed
= random();
228 ip
->t
.c_ospeed
= random();
235 f_ispeed(struct info
*ip
)
237 cfsetispeed(&ip
->t
, atoi(ip
->arg
));
242 f_nl(struct info
*ip
)
245 ip
->t
.c_iflag
|= ICRNL
;
246 ip
->t
.c_oflag
|= ONLCR
;
248 ip
->t
.c_iflag
&= ~ICRNL
;
249 ip
->t
.c_oflag
&= ~ONLCR
;
255 f_ospeed(struct info
*ip
)
257 cfsetospeed(&ip
->t
, atoi(ip
->arg
));
262 f_raw(struct info
*ip
)
268 ip
->t
.c_cflag
&= ~(CSIZE
|PARENB
);
269 ip
->t
.c_cflag
|= CS8
;
275 f_rows(struct info
*ip
)
277 ip
->win
.ws_row
= atoi(ip
->arg
);
282 f_sane(struct info
*ip
)
284 ip
->t
.c_cflag
= TTYDEF_CFLAG
| (ip
->t
.c_cflag
& (CLOCAL
|CRTSCTS
|CDTRCTS
));
285 ip
->t
.c_iflag
= TTYDEF_IFLAG
;
286 ip
->t
.c_iflag
|= ICRNL
;
287 /* preserve user-preference flags in lflag */
288 #define LKEEP (ECHOKE|ECHOE|ECHOK|ECHOPRT|ECHOCTL|ALTWERASE|TOSTOP|NOFLSH)
289 ip
->t
.c_lflag
= TTYDEF_LFLAG
| (ip
->t
.c_lflag
& LKEEP
);
290 ip
->t
.c_oflag
= TTYDEF_OFLAG
;
295 f_size(struct info
*ip
)
297 (void)printf("%d %d\n", ip
->win
.ws_row
, ip
->win
.ws_col
);
301 f_speed(struct info
*ip
)
303 (void)printf("%d\n", cfgetospeed(&ip
->t
));
308 f_tty(struct info
*ip
)
314 if (ioctl(0, TIOCSETD
, &tmp
) < 0)
320 f_ostart(struct info
*ip
)
322 if (ioctl (0, TIOCSTART
) < 0)
327 f_ostop(struct info
*ip
)
329 if (ioctl (0, TIOCSTOP
) < 0)