From: pxinwr Date: Mon, 7 Dec 2020 20:41:12 +0000 (+0800) Subject: bpo-41462: Add os.set_blocking() support for VxWorks RTOS (GH-21713) X-Git-Tag: v3.10.0a4~220 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=06afac6c5740bb81d2b7ab9639d2b08cccf77d33;p=thirdparty%2FPython%2Fcpython.git bpo-41462: Add os.set_blocking() support for VxWorks RTOS (GH-21713) --- diff --git a/Misc/NEWS.d/next/Library/2020-08-03-17-54-32.bpo-41462.ek38d_.rst b/Misc/NEWS.d/next/Library/2020-08-03-17-54-32.bpo-41462.ek38d_.rst new file mode 100644 index 000000000000..ca5da1b17b43 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2020-08-03-17-54-32.bpo-41462.ek38d_.rst @@ -0,0 +1 @@ +Add :func:`os.set_blocking()` support for VxWorks RTOS. diff --git a/Python/fileutils.c b/Python/fileutils.c index b589d7390d46..ac3828211742 100644 --- a/Python/fileutils.c +++ b/Python/fileutils.c @@ -2070,7 +2070,9 @@ _Py_get_blocking(int fd) int _Py_set_blocking(int fd, int blocking) { -#if defined(HAVE_SYS_IOCTL_H) && defined(FIONBIO) +/* bpo-41462: On VxWorks, ioctl(FIONBIO) only works on sockets. + Use fcntl() instead. */ +#if defined(HAVE_SYS_IOCTL_H) && defined(FIONBIO) && !defined(__VXWORKS__) int arg = !blocking; if (ioctl(fd, FIONBIO, &arg) < 0) goto error;