util/qemu-openpty.c: Don't assume pty.h is glibc-only

Instead of using an OS-specific ifdef test to select the "openpty()
is in pty.h" codepath, make configure check for the existence of
the header and use the new CONFIG_PTY instead.

This is necessary to build on Haiku, which also provides openpty()
via pty.h.

Signed-off-by: David Carlier <devnexen@gmail.com>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Message-id: 20200703145614.16684-3-peter.maydell@linaro.org
[PMM: Expanded commit message; rename to HAVE_PTY_H]
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
David CARLIER 2020-07-13 14:36:09 +01:00 committed by Peter Maydell
parent fc4334303e
commit c9c8b88f0b
2 changed files with 10 additions and 1 deletions

9
configure vendored
View File

@ -2402,6 +2402,12 @@ else
l2tpv3=no l2tpv3=no
fi fi
if check_include "pty.h" ; then
pty_h=yes
else
pty_h=no
fi
######################################### #########################################
# vhost interdependencies and host support # vhost interdependencies and host support
@ -7893,6 +7899,9 @@ fi
if test "$sheepdog" = "yes" ; then if test "$sheepdog" = "yes" ; then
echo "CONFIG_SHEEPDOG=y" >> $config_host_mak echo "CONFIG_SHEEPDOG=y" >> $config_host_mak
fi fi
if test "$pty_h" = "yes" ; then
echo "HAVE_PTY_H=y" >> $config_host_mak
fi
if test "$fuzzing" = "yes" ; then if test "$fuzzing" = "yes" ; then
if test "$have_fuzzer" = "yes"; then if test "$have_fuzzer" = "yes"; then
FUZZ_LDFLAGS=" -fsanitize=address,fuzzer" FUZZ_LDFLAGS=" -fsanitize=address,fuzzer"

View File

@ -35,7 +35,7 @@
#include "qemu/osdep.h" #include "qemu/osdep.h"
#include "qemu-common.h" #include "qemu-common.h"
#if defined(__GLIBC__) #if defined HAVE_PTY_H
# include <pty.h> # include <pty.h>
#elif defined CONFIG_BSD #elif defined CONFIG_BSD
# include <termios.h> # include <termios.h>