Re: Supporting -export-dynamic on AIX
On Tue, Aug 08, 2006 at 02:58:44PM -0500, Albert Chin wrote: > > Another version. Patch against branch-1-5 only. I've reordered where > --export-dynamic occurs so we don't have to worry about the above. Our use of both $export_dynamic_symbols_cmds and $export_dynamic_flag_spec somewhat breaks the "whether a program can dlopen itself" test: case $lt_cv_dlopen in dlopen) save_CPPFLAGS="$CPPFLAGS" test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS="$LDFLAGS" wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" ... Why? Because we set $export_dynamic_flag_spec to: _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)="\${wl}$exp_sym_flag:\$export_symbols" so, in the above LDFLAGS="$LDFLAGS -Wl,-bexport:". Because -bexport: requires an argument, we get an error from the linker: ld: 0706-015 The -b export option needs a parameter. Option syntax: -b export:PARM We could make this test pass by creating conftest.exp, setting export_symbols=conftest.exp, and adding "fnord" to it: save_LDFLAGS="$LDFLAGS" echo fnord >conftest.exp wl=$lt_prog_compiler_wl export_symbols=conftest.exp \ eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" Should we do this or let it continue failing? -- albert chin ([EMAIL PROTECTED])
Re: Supporting -export-dynamic on AIX
On Sun, Jul 02, 2006 at 10:58:23PM +0900, Peter O'Gorman wrote: > On Tue, 2006-06-20 at 12:12 -0500, Albert Chin wrote: > > Albert also questioned the documentation: > > > On some operating systems, a program symbol must be specially > > declared > > in order to be dynamically resolved with the `dlsym' (or equivalent) > > function. > > > > Libtool provides the `-export-dynamic' and `-module' link flags > > (*note Link mode::), which do this declaration. You need to use > > these > > flags if you are linking an application program that dlopens other > > modules or a libtool library that will also be dlopened. > > > > Should the last sentence above end with ", respectively"? > > I think this is a documentation bug. -export-dynamic does not imply > -module, there is a line of code in ltmain that adds dlname to the .la > file if either -module or -export-dynamic was specified, but this only > "works" if modules and libraries are otherwise equivalent, so it should > probably be removed and the documentation adjusted for HEAD, thoughts? > Either way this patch does not affect that behavior at all. > > Here are patches against branch-1-5 and HEAD, okay (with apropriate > ChangeLog, of course)? Another version. Patch against branch-1-5 only. I've reordered where --export-dynamic occurs so we don't have to worry about the above. -- albert chin ([EMAIL PROTECTED]) Index: libtool.m4 === RCS file: /cvsroot/libtool/libtool/Attic/libtool.m4,v retrieving revision 1.314.2.162 diff -u -p -r1.314.2.162 libtool.m4 --- libtool.m4 3 Aug 2006 14:31:47 - 1.314.2.162 +++ libtool.m4 8 Aug 2006 13:16:45 - @@ -2911,6 +2911,13 @@ case $host_os in exp_sym_flag='-bexport' no_entry_flag='-bnoentry' + + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + _LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)='$NM -Bpg $objs $libobjs $old_deplibs $old_convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + else + _LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)='$NM -BCpg $objs $libobjs $old_deplibs $old_convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + fi + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)="\${wl}$exp_sym_flag:\$export_symbols" fi # When large executables or shared objects are built, AIX ld can @@ -3974,6 +3981,7 @@ _LT_AC_TAGVAR(archive_cmds_need_lc, $1)= _LT_AC_TAGVAR(allow_undefined_flag, $1)= _LT_AC_TAGVAR(always_export_symbols, $1)=no _LT_AC_TAGVAR(archive_expsym_cmds, $1)= +_LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)= _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= _LT_AC_TAGVAR(hardcode_direct, $1)=no _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= @@ -4209,6 +4217,7 @@ if test -f "$ltmain"; then _LT_AC_TAGVAR(lt_prog_compiler_pic, $1) \ _LT_AC_TAGVAR(lt_prog_compiler_static, $1) \ _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) \ +_LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1) \ _LT_AC_TAGVAR(export_dynamic_flag_spec, $1) \ _LT_AC_TAGVAR(thread_safe_flag_spec, $1) \ _LT_AC_TAGVAR(whole_archive_flag_spec, $1) \ @@ -4243,6 +4252,7 @@ if test -f "$ltmain"; then _LT_AC_TAGVAR(old_archive_from_new_cmds, $1) | \ _LT_AC_TAGVAR(archive_cmds, $1) | \ _LT_AC_TAGVAR(archive_expsym_cmds, $1) | \ +_LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1) | \ _LT_AC_TAGVAR(module_cmds, $1) | \ _LT_AC_TAGVAR(module_expsym_cmds, $1) | \ _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1) | \ @@ -4455,6 +4465,7 @@ link_static_flag=$lt_[]_LT_AC_TAGVAR(lt_ no_builtin_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) # Compiler flag to allow reflexive dlopens. +export_dynamic_symbols_cmds=$lt_[]_LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1) export_dynamic_flag_spec=$lt_[]_LT_AC_TAGVAR(export_dynamic_flag_spec, $1) # Compiler flag to generate shared objects directly from archives. @@ -5480,6 +5491,7 @@ ifelse([$1],[CXX],[ _LT_AC_TAGVAR(archive_expsym_cmds, $1)= _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)= _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1)= + _LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)= _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= _LT_AC_TAGVAR(thread_safe_flag_spec, $1)= @@ -5788,8 +5800,11 @@ _LT_EOF # -C means demangle to AIX nm, but means don't demangle with GNU nm if $NM -V 2>&1 | grep 'GNU' > /dev/null; then _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + _LT_AC_TAGVAR(export_dyna
Re: Supporting -export-dynamic on AIX
On Mon, 2006-07-03 at 01:29 -0500, Albert Chin wrote: > On Sun, Jul 02, 2006 at 10:58:23PM +0900, Peter O'Gorman wrote: > > Here are patches against branch-1-5 and HEAD, okay (with apropriate > > ChangeLog, of course)? > > The patch I submitted doesn't work when the command-line length is > exceeded so the patch needs a little more work. I'll try to address > this soon. As far as I can see we never check max_cmd_len when building programs, only libraries, so there is no need to do this. Peter signature.asc Description: This is a digitally signed message part
Re: Supporting -export-dynamic on AIX
On Sun, Jul 02, 2006 at 10:58:23PM +0900, Peter O'Gorman wrote: > Here are patches against branch-1-5 and HEAD, okay (with apropriate > ChangeLog, of course)? The patch I submitted doesn't work when the command-line length is exceeded so the patch needs a little more work. I'll try to address this soon. -- albert chin ([EMAIL PROTECTED])
Re: Supporting -export-dynamic on AIX
On Tue, 2006-06-20 at 12:12 -0500, Albert Chin wrote: > On Sun, Jun 11, 2006 at 01:14:23AM -0500, Albert Chin wrote: > > On Sat, Jun 10, 2006 at 07:12:34PM -0500, Albert Chin wrote: > > > On Sun, Jun 11, 2006 at 01:04:17AM +0200, Ralf Wildenhues wrote: > > > > * Albert Chin wrote on Sat, Jun 10, 2006 at 08:49:29PM CEST: > > > > > On Sat, Jun 10, 2006 at 08:29:44PM +0200, Ralf Wildenhues wrote: > > > > > > * Albert Chin wrote on Sat, Jun 10, 2006 at 08:08:15PM CEST: > > > > > > > Any reason we don't use -bexpall to support -export-dynamic on > > > > > > > AIX? > > > > > > > > > > I'm thinking of a patch along the lines of the one below. What do you > > think? > > Well, this has some problems. First, if only export_dynamic_flag_spec > is set, the new export list code is wrong. Fixed in the patch below. Albert and I have talked about this a little off-list. There are a couple of issues with Albert's patch. We really need to export all symbols from the executable, so we need to add static libraries and convenience archives too. Since the $convenience variable is not set at the time export_dynamic is checked, I moved this much closer to the program link stage. Then I could build and run irssi on aix with perl support. > The second problem is when libtool is passed multiple source files, > rather than object files to create the executable. This method totally > fails then. What to do in this case? I don't think this is supported, it works "by accident" because unknown things are simply added to $compile_command, the source files get added to the compile command and the compiler does the right thing. If you try this when building a library, it will fail: $ libtool --mode=link gcc -o libfoo.la libfoo.c ar cru .libs/libfoo.a ...empty archive created. Albert also questioned the documentation: > On some operating systems, a program symbol must be specially > declared > in order to be dynamically resolved with the `dlsym' (or equivalent) > function. > > Libtool provides the `-export-dynamic' and `-module' link flags > (*note Link mode::), which do this declaration. You need to use > these > flags if you are linking an application program that dlopens other > modules or a libtool library that will also be dlopened. > > Should the last sentence above end with ", respectively"? I think this is a documentation bug. -export-dynamic does not imply -module, there is a line of code in ltmain that adds dlname to the .la file if either -module or -export-dynamic was specified, but this only "works" if modules and libraries are otherwise equivalent, so it should probably be removed and the documentation adjusted for HEAD, thoughts? Either way this patch does not affect that behavior at all. Here are patches against branch-1-5 and HEAD, okay (with apropriate ChangeLog, of course)? Peter Index: libtool.m4 === RCS file: /cvsroot/libtool/libtool/Attic/libtool.m4,v retrieving revision 1.314.2.159 diff -u -3 -p -u -r1.314.2.159 libtool.m4 --- libtool.m4 24 Jun 2006 05:00:22 - 1.314.2.159 +++ libtool.m4 2 Jul 2006 13:39:17 - @@ -2908,11 +2908,17 @@ case $host_os in done ;; esac - exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi +if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + _LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)='$NM -Bpg $objs $old_deplibs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' +else + _LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)='$NM -BCpg $objs $old_deplibs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' +fi +_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)="\${wl}$exp_sym_flag:\$export_symbols" + # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to @@ -3950,6 +3956,7 @@ _LT_AC_TAGVAR(archive_cmds_need_lc, $1)= _LT_AC_TAGVAR(allow_undefined_flag, $1)= _LT_AC_TAGVAR(always_export_symbols, $1)=no _LT_AC_TAGVAR(archive_expsym_cmds, $1)= +_LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1)= _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= _LT_AC_TAGVAR(hardcode_direct, $1)=no _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= @@ -4185,6 +4192,7 @@ if test -f "$ltmain"; then _LT_AC_TAGVAR(lt_prog_compiler_pic, $1) \ _LT_AC_TAGVAR(lt_prog_compiler_static, $1) \ _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) \ +_LT_AC_TAGVAR(export_dynamic_symbols_cmds, $1) \ _LT_AC_TAGVAR(export_dynamic_flag_spec, $1) \ _LT_AC_TAGVAR(thread_safe_flag_spec, $1) \ _LT_AC_TAGVAR(whole_archive_flag_spec, $1) \ @@ -4219,6 +4227,7 @@ if test -f "$ltmain"; t