[Python-bugs-list] [ python-Bugs-741307 ] Configure does NOT set properly *FLAGS for thread support

SourceForge.net noreply@sourceforge.net
Mon, 02 Jun 2003 05:45:26 -0700


Bugs item #741307, was opened at 2003-05-21 20:53
Message generated for change (Comment added) made by mmokrejs
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=741307&group_id=5470

Category: Build
Group: Platform-specific
Status: Open
Resolution: None
Priority: 5
Submitted By: Martin Mokrejs (mmokrejs)
Assigned to: Nobody/Anonymous (nobody)
Summary: Configure does NOT set properly *FLAGS for thread support

Initial Comment:
On Tru64Unix 5.1A(but also older version like Digital
Unix 4.0 for example), there have to be specified
CFLAGS="-pthread" and CXXFLAGS="-pthread", so that
configure can detect working pthread.h.

In case of Python-2.3b1 even when user set those both
variables before running configure, at the link step gets:

cc   -o python \
                Modules/ccpython.o \
                libpython2.3.a -lrt -L/usr/local/lib
-L/software/@sys/usr/lib -L/usr/local/openssl/lib
-L/usr/lib   -lm  
ld:
Unresolved:
__pthread_self
__pthread_create
__pthread_detach
make: *** [python] Error 1
$

This can be easily fixed:

$ cc -pthread -o python Modules/ccpython.o
libpython2.3.a -lrt -L/usr/local/lib
-L/software/@sys/usr/lib -L/usr/local/openssl/lib
-L/usr/lib -lm 
$

I guess in this case LDFLAGS are in effect. So,
configure should make sure -pthread is appended to all,
CFLAGS, CXXFLAGS and LDFLAGS.

----------------------------------------------------------------------

>Comment By: Martin Mokrejs (mmokrejs)
Date: 2003-06-02 14:45

Message:
Logged In: YES 
user_id=696559

If you are curious about the status of gcc/g++ ability to
cpmpile python(current cvs on alpha-osf), then see below:

$ CC=gcc CXX=g++ CFLAGS=-g2 CXXFLAGS=-g2 ./configure
--prefix=/software/@sys/usr
$ make
gcc -pthread -c  -DNDEBUG -g -O3 -Wall -Wstrict-prototypes
-I. -I./Include  -DPy_BUILD_CORE -o Modules/main.o
Modules/main.c
gcc -pthread -c  -DNDEBUG -g -O3 -Wall -Wstrict-prototypes
-I. -I./Include  -DPy_BUILD_CORE -o Modules/gcmodule.o
Modules/gcmodule.c
gcc -pthread  -DNDEBUG -g -O3 -Wall -Wstrict-prototypes -I.
-I./Include  -DPy_BUILD_CORE  -c ./Modules/threadmodule.c -o
Modules/threadmodule.o
gcc -pthread  -DNDEBUG -g -O3 -Wall -Wstrict-prototypes -I.
-I./Include  -DPy_BUILD_CORE  -c ./Modules/signalmodule.c -o
Modules/signalmodule.o
gcc -pthread  -DNDEBUG -g -O3 -Wall -Wstrict-prototypes -I.
-I./Include  -DPy_BUILD_CORE  -c ./Modules/posixmodule.c -o
Modules/posixmodule.o
Modules/posixmodule.c: In function `posix_stat':
Modules/posixmodule.c:1775: `stat' undeclared (first use in
this function)
Modules/posixmodule.c:1775: (Each undeclared identifier is
reported only once
Modules/posixmodule.c:1775: for each function it appears in.)
Modules/posixmodule.c: In function `posix_plock':
Modules/posixmodule.c:2880: warning: implicit declaration of
function `plock'
Modules/posixmodule.c: In function `posix_lstat':
Modules/posixmodule.c:4607: `lstat' undeclared (first use in
this function)
Modules/posixmodule.c: In function `posix_unsetenv':
Modules/posixmodule.c:5351: warning: implicit declaration of
function `unsetenv'
make: *** [Modules/posixmodule.o] Error 1
$

from config.log:

configure:3774: checking whether pthreads are available
without options
configure:3800: gcc -o conftest -g2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include  conftest.c -L/usr/lo
cal/lib -L/software/@sys/usr/lib -L/usr/local/openssl/lib
-L/usr/lib >&5
In file included from configure:3784:
/usr/include/pthread.h:312:4: #error "Please compile the
module including pthread.h with -pthread"
configure:3803: $? = 1
configure: program exited with status 1
configure: failed program was:
#line 3782 "configure"
#include "confdefs.h"

#include <pthread.h>

void* routine(void* p){return NULL;}

int main(){
  pthread_t p;
  if(pthread_create(&p,NULL,routine,NULL)!=0)
    return 1;
  (void)pthread_detach(p);
  return 0;
}

configure:3823: result: no
configure:3836: checking whether gcc accepts -Kpthread
configure:3864: gcc -Kpthread -o conftest -g2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include  conftest.c
 -L/usr/local/lib -L/software/@sys/usr/lib
-L/usr/local/openssl/lib -L/usr/lib >&5
gcc: unrecognized option `-Kpthread'
In file included from configure:3848:
/usr/include/pthread.h:312:4: #error "Please compile the
module including pthread.h with -pthread"
configure:3867: $? = 1
configure: program exited with status 1
configure: failed program was:
#line 3846 "configure"
#include "confdefs.h"

#include <pthread.h>

void* routine(void* p){return NULL;}

int main(){
  pthread_t p;
  if(pthread_create(&p,NULL,routine,NULL)!=0)
    return 1;
  (void)pthread_detach(p);
  return 0;
}

configure:3887: result: no
configure:3898: checking whether gcc accepts -Kthread
configure:3926: gcc -Kthread -o conftest -g2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include  conftest.c 
-L/usr/local/lib -L/software/@sys/usr/lib
-L/usr/local/openssl/lib -L/usr/lib >&5
gcc: unrecognized option `-Kthread'
In file included from configure:3910:
/usr/include/pthread.h:312:4: #error "Please compile the
module including pthread.h with -pthread"
configure:3929: $? = 1
configure: program exited with status 1
configure: failed program was:
#line 3908 "configure"
#include "confdefs.h"

#include <pthread.h>

void* routine(void* p){return NULL;}

int main(){
  pthread_t p;
  if(pthread_create(&p,NULL,routine,NULL)!=0)
    return 1;
  (void)pthread_detach(p);
  return 0;
}

configure:3949: result: no
configure:3960: checking whether gcc accepts -pthread
configure:3988: gcc -pthread -o conftest -g2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include  conftest.c 
-L/usr/local/lib -L/software/@sys/usr/lib
-L/usr/local/openssl/lib -L/usr/lib >&5
configure:3991: $? = 0
configure:3993: ./conftest
configure:3996: $? = 0
configure:4011: result: yes


configure:4214: checking pthread.h usability
configure:4223: gcc -c -g2 -I/software/@sys/usr/include
-I/usr/local/include -I/usr/local/openssl/include conftest.c >&5
In file included from configure:4251:
/usr/include/pthread.h:312:4: #error "Please compile the
module including pthread.h with -pthread"
configure:4226: $? = 1
[...]
configure:4241: result: no
configure:4245: checking pthread.h presence
configure:4252: gcc -E -I/software/@sys/usr/include
-I/usr/local/include -I/usr/local/openssl/include conftest.c
In file included from configure:4248:
/usr/include/pthread.h:312:4: #error "Please compile the
module including pthread.h with -pthread"
configure:4258: $? = 1
[...]
configure:9269: checking for pthread_t
configure:9291: gcc -pthread -c -g2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include conftest.c >&5
configure:9294: $? = 0
configure:9297: test -s conftest.o
configure:9300: $? = 0
configure:9308: result: yes
configure:9312: checking size of pthread_t
configure:9334: gcc -pthread -o conftest -g2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include  conftest.c 
-L/usr/local/lib -L/software/@sys/usr/lib
-L/usr/local/openssl/lib -L/usr/lib >&5
configure:9337: $? = 0
configure:9339: ./conftest
configure:9342: $? = 0
configure:9357: result: 8


----------------------------------------------------------------------

Comment By: Martin Mokrejs (mmokrejs)
Date: 2003-06-02 13:47

Message:
Logged In: YES 
user_id=696559

Sorry, but my  Mozilla/5.0 (X11; U; Linux i686; en-US;
rv:1.3) Gecko/20030523  does not recognize the link to
download page (the "Download" word really is NOT clickable).
Trying to access
http://sourceforge.net/tracker/download.php?group_id=5470&amp;atid=305470&amp;file_id=47386&amp;aid=719359
manually gives me:


ERROR - No ID Passed

I'm sorry for the delay in communication, I was away for a
week from net. Could anyone send me the latest version of
patches I should use for Python-2.3b1? I'll try cvs as I
read that some stuff was already merged into ... I'm a bit
lost what is alread checked in and what not yet, so ...




----------------------------------------------------------------------

Comment By: Neal Norwitz (nnorwitz)
Date: 2003-05-26 16:02

Message:
Logged In: YES 
user_id=33168

A solution was already checked in that solves thread
problems for several architectures.  Please test current CVS
and report if it works or not.

----------------------------------------------------------------------

Comment By: Neal Norwitz (nnorwitz)
Date: 2003-05-25 18:44

Message:
Logged In: YES 
user_id=33168

This problem has a tentative solution.  Please test the
patch in http://python.org/sf/719359
Scroll to the bottom and click Download on the
osf-opts.patch line.  Thanks.

----------------------------------------------------------------------

Comment By: Martin Mokrejs (mmokrejs)
Date: 2003-05-22 16:20

Message:
Logged In: YES 
user_id=696559

So, this is a solution:

CC="cc -pthread" CXX="cxx -pthread" CFLAGS="$CFLAGS
-pthread" CXXFLAGS=$CFLAGS ./configure



----------------------------------------------------------------------

Comment By: Martin Mokrejs (mmokrejs)
Date: 2003-05-22 10:28

Message:
Logged In: YES 
user_id=696559

BTW: With gcc, I don't get even to the link step:

gcc  -DNDEBUG -g -O3 -Wall -Wstrict-prototypes -I.
-I./Include  -DPy_BUILD_CORE  -c ./Modules/posixmodule.c -o
Modules/posixmodule.o
Modules/posixmodule.c: In function `posix_stat':
Modules/posixmodule.c:1851: `stat' undeclared (first use in
this function)
Modules/posixmodule.c:1851: (Each undeclared identifier is
reported only once
Modules/posixmodule.c:1851: for each function it appears in.)
Modules/posixmodule.c: In function `posix_plock':
Modules/posixmodule.c:2956: warning: implicit declaration of
function `plock'
Modules/posixmodule.c: In function `posix_lstat':
Modules/posixmodule.c:4683: `lstat' undeclared (first use in
this function)
Modules/posixmodule.c: In function `posix_unsetenv':
Modules/posixmodule.c:5431: warning: implicit declaration of
function `unsetenv'
make: *** [Modules/posixmodule.o] Error 1


----------------------------------------------------------------------

Comment By: Martin Mokrejs (mmokrejs)
Date: 2003-05-22 09:24

Message:
Logged In: YES 
user_id=696559

This is specific for Dec/Compaq/HP compiler. The manpage for
cc says:

  -pthread
      Directs the linker to use the threadsafe version of
any library speci-
      fied with the -l option when linking programs. This
option also tells
      the linker to include the POSIX 1003.1c-conformant
DECthreads inter-
      faces in libpthread when linking the program. This
option also defines
      the _REENTRANT macro.


As I remeber from experience, it's not enough to use it
really as LDFLAG supplied to ld. The code has to be compiled
with that flag already and therefore I set CC or CFLAGS to
contain this value. Same applies for CXX or CXXFLAGS.

Actually, there's a configure macro check, I saw it
somewhere in documentation on the web. I posted that once
into some my bugreport in GNOME bugzilla. You can dig out
from there that URL. Unfortunately, bugzilla searches never
worked for me. :(

As for gcc:
$ CFLAGS="-O2" CXXFLAGS="-O2" CC=gcc CXX=g++ ./configure
[...]
checking whether pthreads are available without options... no
checking whether gcc accepts -Kpthread... no
[...]
checking for --with-dec-threads... no
checking for --with-threads... yes
checking for _POSIX_THREADS in unistd.h... yes
checking cthreads.h usability... no
checking cthreads.h presence... no
checking for cthreads.h... no
checking mach/cthreads.h usability... no
checking mach/cthreads.h presence... no
checking for mach/cthreads.h... no
checking for --with-pth... no
checking for pthread_create in -lpthread... yes
checking if PTHREAD_SCOPE_SYSTEM is supported... yes
checking for pthread_sigmask... yes

from config.log:

configure:3753: checking whether pthreads are available
without options
configure:3779: gcc -o conftest -O2
-I/software/@sys/usr/include -I/usr/local/include
-I/usr/local/openssl/include  conftest.c -L/usr/l
ocal/lib -L/software/@sys/usr/lib -L/usr/local/openssl/lib
-L/usr/lib >&5
In file included from configure:3763:
/usr/include/pthread.h:312:4: #error "Please compile the
module including pthread.h with -pthread"
configure:3782: $? = 1
configure: program exited with status 1
configure: failed program was:
#line 3761 "configure"
#include "confdefs.h"

#include <pthread.h>

void* routine(void* p){return NULL;}

int main(){
  pthread_t p;
  if(pthread_create(&p,NULL,routine,NULL)!=0)
    return 1;
  (void)pthread_detach(p);
  return 0;
}

configure:3802: result: no



So, to conclude, -pthread has to be specified even for
gcc/g++. Simply, always on 

----------------------------------------------------------------------

Comment By: Neal Norwitz (nnorwitz)
Date: 2003-05-22 05:34

Message:
Logged In: YES 
user_id=33168

Is this only with the Dec/Compaq/HP compiler (cc/cxx)?  Do
you know if python links ok with gcc?

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=741307&group_id=5470