aboutsummaryrefslogtreecommitdiff
path: root/libexec
diff options
context:
space:
mode:
authorPedro F. Giffuni <pfg@FreeBSD.org>2016-02-26 18:52:06 +0000
committerPedro F. Giffuni <pfg@FreeBSD.org>2016-02-26 18:52:06 +0000
commita3e4b9829e14e640e3b9a5d0d130e8ca184d2040 (patch)
tree25ec41b6807271eae4d4773ddbdd8ca7ad127516 /libexec
parent6bcf245ebce1b74649ec5aa36bfc230db4479b53 (diff)
downloadsrc-a3e4b9829e14e640e3b9a5d0d130e8ca184d2040.tar.gz
src-a3e4b9829e14e640e3b9a5d0d130e8ca184d2040.zip
Notes
Diffstat (limited to 'libexec')
-rw-r--r--libexec/getty/subr.c27
1 files changed, 13 insertions, 14 deletions
diff --git a/libexec/getty/subr.c b/libexec/getty/subr.c
index 992280a5e8c0..5ce03bd4bff9 100644
--- a/libexec/getty/subr.c
+++ b/libexec/getty/subr.c
@@ -38,14 +38,16 @@ static const char rcsid[] =
/*
* Melbourne getty.
*/
-#include <stdlib.h>
-#include <string.h>
-#include <termios.h>
-#include <unistd.h>
#include <sys/ioctl.h>
#include <sys/param.h>
#include <sys/time.h>
+
+#include <poll.h>
+#include <stdlib.h>
+#include <string.h>
#include <syslog.h>
+#include <termios.h>
+#include <unistd.h>
#include "gettytab.h"
#include "pathnames.h"
@@ -633,24 +635,21 @@ portselector(void)
const char *
autobaud(void)
{
- int rfds;
- struct timeval timeout;
+struct pollfd set[1];
+ struct timespec timeout;
char c;
const char *type = "9600-baud";
(void)tcflush(0, TCIOFLUSH);
- rfds = 1 << 0;
- timeout.tv_sec = 5;
- timeout.tv_usec = 0;
- if (select(32, (fd_set *)&rfds, (fd_set *)NULL,
- (fd_set *)NULL, &timeout) <= 0)
+ set[0].fd = STDIN_FILENO;
+ set[0].events = POLLIN;
+ if (poll(set, 1, 5000) <= 0)
return (type);
if (read(STDIN_FILENO, &c, sizeof(char)) != sizeof(char))
return (type);
timeout.tv_sec = 0;
- timeout.tv_usec = 20;
- (void) select(32, (fd_set *)NULL, (fd_set *)NULL,
- (fd_set *)NULL, &timeout);
+ timeout.tv_nsec = 20000;
+ (void)nanosleep(&timeout, NULL);
(void)tcflush(0, TCIOFLUSH);
switch (c & 0377) {