Index: ChangeLog
authorGeoffrey Keating <geoffk@apple.com>
Tue, 3 Aug 2004 00:52:18 +0000 (00:52 +0000)
committerGeoffrey Keating <geoffk@gcc.gnu.org>
Tue, 3 Aug 2004 00:52:18 +0000 (00:52 +0000)
2004-08-02  Geoffrey Keating  <geoffk@apple.com>

* ltcf-cxx.sh: On Darwin, make archive multi-module, and don't
use -all_load flag.

Index: gcc/ChangeLog
2004-08-02  Geoffrey Keating  <geoffk@apple.com>

* dwarf2out.c (output_call_frame_info): Don't change data format
due to TARGET_USES_WEAK_UNWIND_INFO.  Always refer to the local
label.  Use 'true' not '1'.
* doc/install.texi (powerpc-*-darwin*): Mention cctools version
required.

From-SVN: r85461

ChangeLog
gcc/ChangeLog
gcc/doc/install.texi
gcc/dwarf2out.c
ltcf-cxx.sh

index df96fb7aed606eb66b774b4d0bfc943f8a173dfb..27d0730fe0ae0585036c9eae23bec70501bf8cd3 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2004-08-02  Geoffrey Keating  <geoffk@apple.com>
+
+       * ltcf-cxx.sh: On Darwin, make archive multi-module, and don't
+       use -all_load flag.
+
 2004-08-02  Paolo Bonzini  <bonzini@gnu.org>
 
        * configure.in: Sync from src, add noconfigdirs for crx-*-*.
index 1e66034b8eb39c8a6ac6aa502fb9677c7a6dfa6f..7164a2989a66ee42575cf79b5189fa3cda451616 100644 (file)
@@ -1,3 +1,11 @@
+2004-08-02  Geoffrey Keating  <geoffk@apple.com>
+
+       * dwarf2out.c (output_call_frame_info): Don't change data format
+       due to TARGET_USES_WEAK_UNWIND_INFO.  Always refer to the local
+       label.  Use 'true' not '1'.
+       * doc/install.texi (powerpc-*-darwin*): Mention cctools version
+       required.
+
 2004-08-02  Gabriel Dos Reis  <gdr@cs.tamu.edu>
 
        * gdbinit.in: Reflect previous changes to rtunion_def.
index 0af4aa73e0fda6f82d28c8c378e9523093f238eb..9c7d01029c417975ac534d164cf66642dbf278e3 100644 (file)
@@ -3306,17 +3306,11 @@ binaries are available at
 @uref{http://developer.apple.com/tools/compilers.html} (free
 registration required).
 
-The default stack limit of 512K is too small, which may cause compiles
-to fail with 'Bus error'.  Set the stack larger, for instance
-by doing @samp{limit stack 800}.  It's a good idea to use the GNU
-preprocessor instead of Apple's @file{cpp-precomp} during the first stage of
-bootstrapping; this is automatic when doing @samp{make bootstrap}, but
-to do it from the toplevel objdir you will need to say @samp{make
-CC='cc -no-cpp-precomp' bootstrap}.
+This version of GCC requires at least cctools-528.
 
 The version of GCC shipped by Apple typically includes a number of
 extensions not available in a standard GCC release.  These extensions
-are generally specific to Mac programming.
+are generally for backwards compatibility and best avoided.
 
 @html
 <hr />
index 4a1037fdf72cf7970fa052d67ff895a15e5e57f9..46b3b512660460320e747858d5e74fefc4c4891e 100644 (file)
@@ -2089,7 +2089,7 @@ output_call_frame_info (int for_eh)
          any_eh_needed = any_lsda_needed = true;
         else if (TARGET_USES_WEAK_UNWIND_INFO
                 && DECL_ONE_ONLY (fde_table[i].decl))
-         any_eh_needed = 1;
+         any_eh_needed = true;
        else if (! fde_table[i].nothrow
                 && ! fde_table[i].all_throwers_are_sibcalls)
          any_eh_needed = true;
@@ -2141,9 +2141,7 @@ output_call_frame_info (int for_eh)
         P      Indicates the presence of an encoding + language
                personality routine in the CIE augmentation.  */
 
-      fde_encoding = TARGET_USES_WEAK_UNWIND_INFO
-       ? ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/2, /*global=*/1)
-       : ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/1, /*global=*/0);
+      fde_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/1, /*global=*/0);
       per_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/2, /*global=*/1);
       lsda_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/0, /*global=*/0);
 
@@ -2258,20 +2256,11 @@ output_call_frame_info (int for_eh)
 
       if (for_eh)
        {
-         if (TARGET_USES_WEAK_UNWIND_INFO
-             && DECL_ONE_ONLY (fde->decl))
-           dw2_asm_output_encoded_addr_rtx (fde_encoding,
-                    gen_rtx_SYMBOL_REF (Pmode, IDENTIFIER_POINTER
-                                                 (DECL_ASSEMBLER_NAME (fde->decl))),
-                    "FDE initial location");
-         else
-           {
-             rtx sym_ref = gen_rtx_SYMBOL_REF (Pmode, fde->dw_fde_begin);
-             SYMBOL_REF_FLAGS (sym_ref) |= SYMBOL_FLAG_LOCAL;
-             dw2_asm_output_encoded_addr_rtx (fde_encoding,
-                                              sym_ref,
-                                              "FDE initial location");
-           }
+         rtx sym_ref = gen_rtx_SYMBOL_REF (Pmode, fde->dw_fde_begin);
+         SYMBOL_REF_FLAGS (sym_ref) |= SYMBOL_FLAG_LOCAL;
+         dw2_asm_output_encoded_addr_rtx (fde_encoding,
+                                          sym_ref,
+                                          "FDE initial location");
          dw2_asm_output_delta (size_of_encoded_value (fde_encoding),
                                fde->dw_fde_end, fde->dw_fde_begin,
                                "FDE address range");
index ce28177ee11b86a3d66798e743ab77e1aeb043fa..7edeb864b1758cff0bdfd154c3f585641a86059f 100644 (file)
@@ -254,7 +254,8 @@ case $host_os in
            ;;
     esac
     output_verbose_link_cmd='echo'
-    archive_cmds='$CC -r ${wl}-bind_at_load -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring'
+
+    archive_cmds='$CXX -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring'
     module_cmds='$CC ${wl}-bind_at_load $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags'
 
     # Don't fix this by using the ld -exported_symbols_list flag,
@@ -264,7 +265,6 @@ case $host_os in
     hardcode_direct=no
     hardcode_automatic=yes
     hardcode_shlibpath_var=unsupported
-    whole_archive_flag_spec='-all_load $convenience'
     link_all_deplibs=yes
     ;;