diff options
author | tegge <tegge@FreeBSD.org> | 2006-05-29 01:38:59 +0800 |
---|---|---|
committer | tegge <tegge@FreeBSD.org> | 2006-05-29 01:38:59 +0800 |
commit | b580defab2a751daad63654e40598e608332a685 (patch) | |
tree | 2a39ca3f76ec072bb8ed3032271aa24c645b4e05 /devel | |
parent | fd96ab04d32c94509f89203462b6f50c92103b06 (diff) | |
download | freebsd-ports-gnome-b580defab2a751daad63654e40598e608332a685.tar.gz freebsd-ports-gnome-b580defab2a751daad63654e40598e608332a685.tar.zst freebsd-ports-gnome-b580defab2a751daad63654e40598e608332a685.zip |
Backport 2001-09-11 fix from newer linuxthreads versions making
the communication over the pthread manager pipe a little more robust by
retrying after EINTR failures. Without this fix, linuxthreads based
binaries that run fine on FreeBSD 4 starts crashing in mysterious ways
on FreeBSD 6.
Diffstat (limited to 'devel')
-rw-r--r-- | devel/linuxthreads/files/patch-intrpipe | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/devel/linuxthreads/files/patch-intrpipe b/devel/linuxthreads/files/patch-intrpipe new file mode 100644 index 000000000000..60279b81632b --- /dev/null +++ b/devel/linuxthreads/files/patch-intrpipe @@ -0,0 +1,66 @@ +diff -ru ../../work.PRE4/linuxthreads-2.2.3_20/freebsd-compat.h ./freebsd-compat.h +--- ../../work.PRE4/linuxthreads-2.2.3_20/freebsd-compat.h Sun Jun 8 17:13:55 2003 ++++ ./freebsd-compat.h Tue May 23 21:39:26 2006 +@@ -4,6 +4,7 @@ + #include <sched.h> + #include <sys/types.h> + #include <sys/time.h> ++#include <sys/errno.h> + + + #if __FreeBSD__ >= 5 +@@ -15,9 +16,9 @@ + #define __libc_fsync __sys_fsync + #define __libc_nanosleep __sys_nanosleep + #define __libc_open __sys_open +-#define __libc_read __sys_read ++#define __libc_oread __sys_read + #define __libc_waitpid __waitpid +-#define __libc_write __sys_write ++#define __libc_owrite __sys_write + #define __libc_longjmp __longjmp + #define __libc_siglongjmp __siglongjmp + #define __libc_msync __sys_msync +@@ -37,9 +38,9 @@ + #define __libc_fsync _fsync + #define __libc_nanosleep _nanosleep + #define __libc_open _open +-#define __libc_read _read ++#define __libc_oread _read + #define __libc_waitpid __waitpid +-#define __libc_write _write ++#define __libc_owrite _write + #define __libc_longjmp __longjmp + #define __libc_siglongjmp __siglongjmp + #define __libc_msync _msync +@@ -75,8 +76,28 @@ + #define __ptr_t void * + #define __pid_t pid_t + +-ssize_t __libc_write(int, const void *, size_t); +-ssize_t __libc_read(int, void *, size_t); ++ssize_t __libc_owrite(int, const void *, size_t); ++ssize_t __libc_oread(int, void *, size_t); ++static inline ssize_t ++__libc_write(int fd, const void *buf, size_t wsize) ++{ ++ ssize_t written; ++ ++ do { ++ written = __libc_owrite(fd, buf, wsize); ++ } while (written < 0 && errno == EINTR); ++ return (written); ++} ++static inline ssize_t ++__libc_read(int fd, void *buf, size_t rsize) ++{ ++ ssize_t got; ++ ++ do { ++ got = __libc_oread(fd, buf, rsize); ++ } while (got < 0 && errno == EINTR); ++ return (got); ++} + pid_t __libc_waitpid(pid_t wpid, int *status, int options); + int __libc_poll(struct pollfd *_pfd, unsigned int _nfsd, int _timeout); + pid_t __libc_getpid(void); |