diff options
author | tegge <tegge@FreeBSD.org> | 2003-07-14 20:15:03 +0800 |
---|---|---|
committer | tegge <tegge@FreeBSD.org> | 2003-07-14 20:15:03 +0800 |
commit | ff255c9b215deeeafea3c51434bb4f460816d055 (patch) | |
tree | e81e0237f237a2dac56dc7d17f428c4374a3c60a | |
parent | f40260f3228d4de25d8c5b31eb787736f1ed4733 (diff) | |
download | freebsd-ports-graphics-ff255c9b215deeeafea3c51434bb4f460816d055.tar.gz freebsd-ports-graphics-ff255c9b215deeeafea3c51434bb4f460816d055.tar.zst freebsd-ports-graphics-ff255c9b215deeeafea3c51434bb4f460816d055.zip |
Restore gethostbyaddr_r wrapper and remove getpw{nam,uid}_r wrappers for
newer versions of FreeBSD 5.X.
Drop use of deprecated AINC variable.
Reenable use of ld(1) to restore the LINUXTHREADS_WRAP_API option.
Rename __thread to __xthread in prototypes to avoid conflict with
new gcc keyword.
Bump port revision.
-rw-r--r-- | devel/linuxthreads/Makefile | 2 | ||||
-rw-r--r-- | devel/linuxthreads/files/gethostby_r.c | 2 | ||||
-rw-r--r-- | devel/linuxthreads/files/getpw_r.c | 3 | ||||
-rw-r--r-- | devel/linuxthreads/files/patch-aa | 56 |
4 files changed, 57 insertions, 6 deletions
diff --git a/devel/linuxthreads/Makefile b/devel/linuxthreads/Makefile index c3696a5fa46..d00545bfa5a 100644 --- a/devel/linuxthreads/Makefile +++ b/devel/linuxthreads/Makefile @@ -7,7 +7,7 @@ PORTNAME= linuxthreads PORTVERSION= 2.2.3 -PORTREVISION= 12 +PORTREVISION= 13 CATEGORIES= devel MASTER_SITES= ${MASTER_SITE_GNU} MASTER_SITE_SUBDIR= glibc diff --git a/devel/linuxthreads/files/gethostby_r.c b/devel/linuxthreads/files/gethostby_r.c index c5c88355ffc..4d6d6b487f9 100644 --- a/devel/linuxthreads/files/gethostby_r.c +++ b/devel/linuxthreads/files/gethostby_r.c @@ -105,7 +105,7 @@ convert (struct hostent *host, struct hostent *result, return 0; } -#if __FreeBSD__ < 5 +#if __FreeBSD__ < 5 || __FreeBSD__version >= 501101 struct hostent * gethostbyaddr_r (const char *addr, int length, int type, struct hostent *result, char *buffer, int buflen, diff --git a/devel/linuxthreads/files/getpw_r.c b/devel/linuxthreads/files/getpw_r.c index 5dd44e958ba..246a4479a9e 100644 --- a/devel/linuxthreads/files/getpw_r.c +++ b/devel/linuxthreads/files/getpw_r.c @@ -2,8 +2,10 @@ #include <string.h> #include <errno.h> #include <pwd.h> +#include <osreldate.h> #include "pthread.h" +#if __FreeBSD_version < 500112 static pthread_mutex_t getpw_mutex = PTHREAD_MUTEX_INITIALIZER; static int @@ -106,3 +108,4 @@ int getpwuid_r (uid_t uid, struct passwd *result, pthread_mutex_unlock (&getpw_mutex); return retval; } +#endif diff --git a/devel/linuxthreads/files/patch-aa b/devel/linuxthreads/files/patch-aa index b411dc08d7c..a805bfcb649 100644 --- a/devel/linuxthreads/files/patch-aa +++ b/devel/linuxthreads/files/patch-aa @@ -13,7 +13,7 @@ diff -ru ../../work/linuxthreads-2.2.3/Examples/Makefile ./Examples/Makefile diff -ru ../../work/linuxthreads-2.2.3/Makefile ./Makefile --- ../../work/linuxthreads-2.2.3/Makefile Wed Apr 25 21:50:59 2001 +++ ./Makefile Thu Jun 7 23:13:52 2001 -@@ -1,128 +1,104 @@ +@@ -1,128 +1,122 @@ -# Copyright (C) 1996,1997,1998,1999,2000,2001 Free Software Foundation, Inc. -# This file is part of the GNU C Library. +LIB=lthread @@ -74,7 +74,7 @@ diff -ru ../../work/linuxthreads-2.2.3/Makefile ./Makefile +LD=${LINUXTHREADS_WRAP_LD} +.endif + -+AINC = -I${LIBSRC_BASE}/libc/${MACHINE_ARCH} -I${.CURDIR}/sysdeps/${MACHINE_ARCH} ++CFLAGS += -I${LIBSRC_BASE}/libc/${MACHINE_ARCH} -I${.CURDIR}/sysdeps/${MACHINE_ARCH} + +# Contents of the library. +SRCS := attr.c cancel.c clone.S condvar.c errno.c getgr_r.c gethostby_r.c \ @@ -245,6 +245,24 @@ diff -ru ../../work/linuxthreads-2.2.3/Makefile ./Makefile -endif + +.include <bsd.lib.mk> ++ ++.if defined(LINUXTHREADS_WRAP_API) ++.c.o: ++ ${CC} ${CFLAGS} -c ${.IMPSRC} -o ${.TARGET} ++ @${LD} ${LDFLAGS} -o ${.TARGET}.tmp -x -r ${.TARGET} ++ @mv ${.TARGET}.tmp ${.TARGET} ++ ++.c.po: ++ ${CC} -pg ${CFLAGS} -c ${.IMPSRC} -o ${.TARGET} ++ @${LD} ${LDFLAGS} -o ${.TARGET}.tmp -X -r ${.TARGET} ++ @mv ${.TARGET}.tmp ${.TARGET} ++ ++.c.So: ++ ${CC} ${PICFLAG} -DPIC ${CFLAGS} -c ${.IMPSRC} -o ${.TARGET} ++ @${LD} ${LDFLAGS} -o ${.TARGET}.tmp -x -r ${.TARGET} ++ @mv ${.TARGET}.tmp ${.TARGET} ++.endif ++ diff -ru ../../work/linuxthreads-2.2.3/attr.c ./attr.c --- ../../work/linuxthreads-2.2.3/attr.c Tue Mar 27 04:52:55 2001 +++ ./attr.c Thu Jun 7 22:59:29 2001 @@ -392,6 +410,15 @@ diff -ru ../../work/linuxthreads-2.2.3/internals.h ./internals.h /* Global pointers to old or new suspend functions */ +@@ -545,7 +555,7 @@ + /* Prototypes for compatibility functions. */ + extern int __pthread_attr_init_2_1 (pthread_attr_t *__attr); + extern int __pthread_attr_init_2_0 (pthread_attr_t *__attr); +-extern int __pthread_create_2_1 (pthread_t *__restrict __thread, ++extern int __pthread_create_2_1 (pthread_t *__restrict __xthread, + const pthread_attr_t *__attr, + void *(*__start_routine) (void *), + void *__restrict __arg); diff -ru ../../work/linuxthreads-2.2.3/join.c ./join.c --- ../../work/linuxthreads-2.2.3/join.c Thu Apr 12 21:02:02 2001 +++ ./join.c Thu Jun 7 22:59:29 2001 @@ -1154,6 +1181,24 @@ diff -ru ../../work/linuxthreads-2.2.3/sysdeps/pthread/pthread.h ./sysdeps/pthre #include <sched.h> #include <time.h> +@@ -160,7 +162,7 @@ + /* Create a thread with given attributes ATTR (or default attributes + if ATTR is NULL), and call function START_ROUTINE with given + arguments ARG. */ +-extern int pthread_create (pthread_t *__restrict __thread, ++extern int pthread_create (pthread_t *__restrict __xthread, + __const pthread_attr_t *__restrict __attr, + void *(*__start_routine) (void *), + void *__restrict __arg) __THROW; +@@ -588,7 +590,7 @@ + extern int pthread_setcanceltype (int __type, int *__oldtype) __THROW; + + /* Cancel THREAD immediately or at the next possibility. */ +-extern int pthread_cancel (pthread_t __thread) __THROW; ++extern int pthread_cancel (pthread_t __xthread) __THROW; + + /* Test for pending cancellation for the current thread and terminate + the thread as per pthread_exit(PTHREAD_CANCELED) if it has been diff -ru ../../work/linuxthreads-2.2.3/sysdeps/unix/sysv/linux/bits/local_lim.h ./sysdeps/unix/sysv/linux/bits/local_lim.h --- ../../work/linuxthreads-2.2.3/sysdeps/unix/sysv/linux/bits/local_lim.h Fri Jun 9 19:17:35 2000 +++ ./sysdeps/unix/sysv/linux/bits/local_lim.h Thu Jun 7 22:59:29 2001 @@ -1169,7 +1214,7 @@ diff -ru ../../work/linuxthreads-2.2.3/sysdeps/unix/sysv/linux/bits/local_lim.h diff -ru ../../work/linuxthreads-2.2.3/sysdeps/unix/sysv/linux/bits/sigthread.h ./sysdeps/unix/sysv/linux/bits/sigthread.h --- ../../work/linuxthreads-2.2.3/sysdeps/unix/sysv/linux/bits/sigthread.h Thu Aug 31 21:45:04 2000 +++ ./sysdeps/unix/sysv/linux/bits/sigthread.h Thu Jun 7 22:59:29 2001 -@@ -29,8 +29,8 @@ +@@ -29,10 +29,10 @@ /* Modify the signal mask for the calling thread. The arguments have the same meaning as for sigprocmask(2). */ extern int pthread_sigmask (int __how, @@ -1179,7 +1224,10 @@ diff -ru ../../work/linuxthreads-2.2.3/sysdeps/unix/sysv/linux/bits/sigthread.h + sigset_t *__restrict __oldmask)__THROW; /* Send signal SIGNO to the given thread. */ - extern int pthread_kill (pthread_t __thread, int __signo) __THROW; +-extern int pthread_kill (pthread_t __thread, int __signo) __THROW; ++extern int pthread_kill (pthread_t __xthread, int __signo) __THROW; + + #endif /* bits/sigthread.h */ diff -ru ../../work/linuxthreads-2.2.3/wrapsyscall.c ./wrapsyscall.c --- ../../work/linuxthreads-2.2.3/wrapsyscall.c Wed Apr 25 21:50:59 2001 +++ ./wrapsyscall.c Thu Jun 7 22:59:29 2001 |