]> granicus.if.org Git - musl/commitdiff
get rid of eh_frame bloat
authorRich Felker <dalias@aerifal.cx>
Wed, 29 Aug 2012 13:36:02 +0000 (09:36 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 29 Aug 2012 13:36:02 +0000 (09:36 -0400)
if needed for debugging, it will be output in the .debug_frame section
instead, where it is not part of the loaded program and where the
strip command is free to strip it.

configure

index 11051800d3e4b291b7358b40fb5442447b7756f9..4e3931c1c2b49236340e9d31ed348dc88b7b8b9a 100755 (executable)
--- a/configure
+++ b/configure
@@ -226,15 +226,24 @@ test "x$debug" = xyes && CFLAGS_AUTO="-g"
 tryflag CFLAGS_AUTO -pipe
 
 #
-# If debugging is disabled, omit bloated DWARF2 unwind tables & frame ptr
+# If debugging is disabled, omit frame pointer. Modern GCC does this
+# anyway on most archs even when debugging is enabled since the frame
+# pointer is no longer needed for debugging.
 #
 if fnmatch '-g*|*\ -g*' "$CFLAGS_AUTO $CFLAGS" ; then :
 else 
-tryflag CFLAGS_AUTO -fno-unwind-tables
-tryflag CFLAGS_AUTO -fno-asynchronous-unwind-tables
 tryflag CFLAGS_AUTO -fomit-frame-pointer
 fi
 
+#
+# Modern GCC wants to put DWARF tables (used for debugging and
+# unwinding) in the loaded part of the program where they are
+# unstrippable. These options force them back to debug sections (and
+# cause them not to get generated at all if debugging is off).
+#
+tryflag CFLAGS_AUTO -fno-unwind-tables
+tryflag CFLAGS_AUTO -fno-asynchronous-unwind-tables
+
 #
 # Some optimization levels add bloated alignment that hurt performance
 #