configure: improve check for POSIX ioctl

Instead of relying on system #ifdefs which may or may not be correct,
detect the POSIX ioctl signature at configure time.

Signed-off-by: Paul B Mahol <onemda@gmail.com>
This commit is contained in:
Ramiro Polla 2024-08-29 15:40:00 +02:00 committed by Paul B Mahol
parent 81a3528647
commit a7647a6f88
2 changed files with 3 additions and 1 deletions

2
configure vendored
View File

@ -2518,6 +2518,7 @@ HAVE_LIST="
opencl_videotoolbox opencl_videotoolbox
perl perl
pod2man pod2man
posix_ioctl
texi2html texi2html
xmllint xmllint
zlib_gzip zlib_gzip
@ -7143,6 +7144,7 @@ xmllint --version > /dev/null 2>&1 && enable xmllint || disable xmllint
check_headers linux/fb.h check_headers linux/fb.h
check_headers linux/videodev2.h check_headers linux/videodev2.h
test_code cc linux/videodev2.h "struct v4l2_frmsizeenum vfse; vfse.discrete.width = 0;" && enable_sanitized struct_v4l2_frmivalenum_discrete test_code cc linux/videodev2.h "struct v4l2_frmsizeenum vfse; vfse.discrete.width = 0;" && enable_sanitized struct_v4l2_frmivalenum_discrete
test_code cc sys/ioctl.h "int ioctl(int, int, ...)" && enable posix_ioctl
# check V4L2 codecs available in the API # check V4L2 codecs available in the API
if enabled v4l2_m2m; then if enabled v4l2_m2m; then

View File

@ -111,7 +111,7 @@ struct video_data {
int (*open_f)(const char *file, int oflag, ...); int (*open_f)(const char *file, int oflag, ...);
int (*close_f)(int fd); int (*close_f)(int fd);
int (*dup_f)(int fd); int (*dup_f)(int fd);
#if defined(__sun) || defined(__BIONIC__) || defined(__musl__) /* POSIX-like */ #if HAVE_POSIX_IOCTL
int (*ioctl_f)(int fd, int request, ...); int (*ioctl_f)(int fd, int request, ...);
#else #else
int (*ioctl_f)(int fd, unsigned long int request, ...); int (*ioctl_f)(int fd, unsigned long int request, ...);