Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!
Bug 352495 - sys-devel/gcc-4.[45]: building packages with -mavx causes crashes
Summary: sys-devel/gcc-4.[45]: building packages with -mavx causes crashes
Status: RESOLVED OBSOLETE
Alias: None
Product: Gentoo Linux
Classification: Unclassified
Component: Current packages (show other bugs)
Hardware: AMD64 Linux
: High normal
Assignee: Gentoo Toolchain Maintainers
URL:
Whiteboard:
Keywords:
: 356397 373941 (view as bug list)
Depends on:
Blocks:
 
Reported: 2011-01-23 13:56 UTC by Brian
Modified: 2015-10-02 22:33 UTC (History)
12 users (show)

See Also:
Package list:
Runtime testing required: ---


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Brian 2011-01-23 13:56:32 UTC
After building a new machine and installing Gentoo, both Thunderbird and Firefox will not start.  Neither program produce any error messages when launched from console and just immediately (and silently) return.  I started a forum thread, http://forums.gentoo.org/viewtopic-t-860223.html, and it appears I may not be the only one experiencing this issue.



Reproducible: Always

Steps to Reproduce:
1.  Attempt to launch either Firefox or Thunderbird

Actual Results:  
Nothing happens

Expected Results:  
Firefox or Thunderbird should have launched

emerge --info
Portage 2.1.9.25 (default/linux/amd64/10.0/desktop/gnome, gcc-4.4.4, glibc-2.11.2-r3, 2.6.36-gentoo-r5 x86_64) 
================================================================= 
System uname: Linux-2.6.36-gentoo-r5-x86_64-Intel-R-_Core-TM-_i7-2600_CPU_@_3.40GHz-with-gentoo-1.12.14 
Timestamp of tree: Fri, 14 Jan 2011 11:15:02 +0000 
app-shells/bash:     4.1_p7 
dev-java/java-config: 2.1.11-r3 
dev-lang/python:     2.6.6-r1, 3.1.2-r4 
dev-util/cmake:      2.8.1-r2 
sys-apps/baselayout: 1.12.14-r1 
sys-apps/sandbox:    2.4 
sys-devel/autoconf:  2.13, 2.65-r1 
sys-devel/automake:  1.4_p6-r1, 1.9.6-r3, 1.10.3, 1.11.1 
sys-devel/binutils:  2.20.1-r1 
sys-devel/gcc:       4.4.4-r2 
sys-devel/gcc-config: 1.4.1 
sys-devel/libtool:   2.2.10 
sys-devel/make:      3.81-r2 
virtual/os-headers:  2.6.30-r1 (sys-kernel/linux-headers) 
ACCEPT_KEYWORDS="amd64" 
ACCEPT_LICENSE="* -@EULA" 
CBUILD="x86_64-pc-linux-gnu" 
CFLAGS="-march=native -O2 -pipe -fomit-frame-pointer" 
CHOST="x86_64-pc-linux-gnu" 
CONFIG_PROTECT="/etc /var/lib/hsqldb" 
CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/env.d /etc/env.d/java/ /etc/fonts/fonts.conf /etc/gconf /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo" 
CXXFLAGS="-march=native -O2 -pipe -fomit-frame-pointer" 
DISTDIR="/usr/portage/distfiles" 
EMERGE_DEFAULT_OPTS="--quiet-build" 
FEATURES="assume-digests binpkg-logs distlocks fixlafiles fixpackages news parallel-fetch protect-owned sandbox sfperms strict unknown-features-warn unmerge-logs unmerge-orphans userfetch" 
GENTOO_MIRRORS="http://www.gtlib.gatech.edu/pub/gentoo http://mirrors.rit.edu/gentoo/ http://mirror.lug.udel.edu/pub/gentoo/" 
LANG="C" 
LDFLAGS="-Wl,-O1 -Wl,--as-needed" 
LINGUAS="en_US en" 
MAKEOPTS="-j9" 
PKGDIR="/usr/portage/packages" 
PORTAGE_CONFIGROOT="/" 
PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --compress --force --whole-file --delete --stats --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages" 
PORTAGE_TMPDIR="/var/tmp" 
PORTDIR="/usr/portage" 
SYNC="rsync://rsync.us.gentoo.org/gentoo-portage" 
USE="X a52 aac acl acpi alsa amd64 bash-completion berkdb bluetooth bluray branding bzip2 cairo cdda cddb cdr cleartype cli consolekit corefonts cracklib crypt css cups cxx dbus dhcpcd directfb dri dts dvd dvdr eds emboss emerald encode evo exif fam fbcon ffmpeg firefox flac fortran ftp fts3 fuse gdbm gdu geoip gif gimp glitz gnome gnome-keyring gnutls gpm gstreamer gtk hal iconv ieee1394 imagemagick java java6 jpeg lame latex lcms ldap libnotify mad mikmod mmx mng modules mp3 mp4 mpeg mudflap multilib nautilus ncurses nls nptl nptlonly nsplugin nvidia offensive ogg openal opengl openmp pam pango pcre pdf perl png policykit posix ppds pppd pulseaudio python qt3support quicktime readline samba scanner sdl session smp spell sqlite sqlite3 sse sse2 sse3 sse4 ssl ssse3 startup-notification subversion svg symlink sysfs tcpd theora threads tiff truetype type1 udev unicode usb vaapi vdpau vim vim-syntax vorbis wxwidgets x264 xcb xinerama xml xorg xulrunner xv xvid xvmc zlib" ALSA_CARDS="ali5451 als4000 atiixp atiixp-modem bt87x ca0106 cmipci emu10k1x ens1370 ens1371 es1938 es1968 fm801 hda-intel intel8x0 intel8x0m maestro3 trident usb-audio via82xx via82xx-modem ymfpci" ALSA_PCM_PLUGINS="adpcm alaw asym copy dmix dshare dsnoop empty extplug file hooks iec958 ioplug ladspa lfloat linear meter mmap_emul mulaw multi null plug rate route share shm softvol" APACHE2_MODULES="actions alias auth_basic authn_alias authn_anon authn_dbm authn_default authn_file authz_dbm authz_default authz_groupfile authz_host authz_owner authz_user autoindex cache cgi cgid dav dav_fs dav_lock deflate dir disk_cache env expires ext_filter file_cache filter headers include info log_config logio mem_cache mime mime_magic negotiation rewrite setenvif speling status unique_id userdir usertrack vhost_alias" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock itrax mtk3301 nmea ntrip navcom oceanserver oldstyle oncore rtcm104v2 rtcm104v3 sirf superstar2 timing tsip tripmate tnt ubx" INPUT_DEVICES="evdev" KERNEL="linux" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LINGUAS="en_US en" PHP_TARGETS="php5-3" RUBY_TARGETS="ruby18" USERLAND="GNU" VIDEO_CARDS="nvidia" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq steal rawnat logmark ipmark dhcpmac delude chaos account" 
Unset:  CPPFLAGS, CTARGET, FFLAGS, INSTALL_MASK, LC_ALL, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, PORTDIR_OVERLAY
Comment 1 Jory A. Pratt gentoo-dev 2011-01-23 16:04:45 UTC
check dmesg to see if it is logging an error, also you will need to provide a backtrace.
Comment 2 Brian 2011-01-23 16:49:07 UTC
Nothing is being logged to dmesg.

I attempted to get a backtrace with gdb (following the directions at http://www.gentoo.org/proj/en/qa/backtraces.xml) but it says "No Stack."  Here's the c&p from GDB:

gdb firefox
GNU gdb (Gentoo 7.2 p1) 7.2
Copyright (C) 2010 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-pc-linux-gnu".
For bug reporting instructions, please see:
<http://bugs.gentoo.org/>...
Reading symbols from /usr/bin/firefox...done.
(gdb) run
Starting program: /usr/bin/firefox 
[Thread debugging using libthread_db enabled]
[New Thread 0x7fffe5df6710 (LWP 28403)]
[New Thread 0x7fffe55f5710 (LWP 28404)]
[New Thread 0x7fffe4df4710 (LWP 28405)]
[New Thread 0x7fffe45f3710 (LWP 28406)]
[Thread 0x7fffe45f3710 (LWP 28406) exited]
[Thread 0x7fffe4df4710 (LWP 28405) exited]
[Thread 0x7fffe55f5710 (LWP 28404) exited]
[Thread 0x7fffe5df6710 (LWP 28403) exited]
process 28400 is executing new program: /usr/lib64/firefox/firefox
[Thread debugging using libthread_db enabled]
[New Thread 0x7fffe5bf2710 (LWP 28407)]
[New Thread 0x7fffe53f1710 (LWP 28408)]
[New Thread 0x7fffe4bf0710 (LWP 28409)]
[New Thread 0x7fffe43ef710 (LWP 28410)]
[New Thread 0x7fffe3bee710 (LWP 28411)]
[New Thread 0x7fffe1e34710 (LWP 28412)]
[Thread 0x7fffe43ef710 (LWP 28410) exited]
[Thread 0x7fffe1e34710 (LWP 28412) exited]
[Thread 0x7fffe3bee710 (LWP 28411) exited]
[Thread 0x7fffe4bf0710 (LWP 28409) exited]
[Thread 0x7fffe53f1710 (LWP 28408) exited]
[Thread 0x7fffe5bf2710 (LWP 28407) exited]

Program exited with code 01.
(gdb) set logging file backtrace.log
(gdb) set logging on
Copying output to backtrace.log.
(gdb) bt
No stack.
(gdb) set logging off
Done logging to backtrace.log.
(gdb) quit

I also attempted to run /usr/lib64/firefox/firefox and got the same result.
Comment 3 Brian 2011-01-23 17:02:22 UTC
After some Googling, I decided to fiddle with "-profilemanager" and via some combination of deleting .mozilla and -profilemanager, got Firefox to launch.  (Un)fortunately it's segfaulting regularly but I did manage to get a backtrace of a segfault:

#0  nsDataDocumentContentPolicy::ShouldLoad (this=<value optimized out>, aContentType=3, 
    aContentLocation=<value optimized out>, aRequestingLocation=0x19d60d0, aRequestingContext=0x1d549b0, aMimeGuess=..., 
    aExtra=0xc, aDecision=0x7ffff5e1ca3b) at nsDataDocumentContentPolicy.cpp:61
#1  0x00007ffff57cfa90 in nsContentPolicy::CheckPolicy (this=0xb4d000, 
    policyMethod=&virtual nsIContentPolicy::ShouldLoad(PRUint32, nsIURI*, nsIURI*, nsISupports*, nsACString_internal const&, nsISupports*, PRInt16*), contentType=<value optimized out>, contentLocation=<value optimized out>, 
    requestingLocation=0x19d60d0, requestingContext=0x1d549b0, mimeType=..., extra=0xc, decision=0x7ffff5e1ca3b)
    at nsContentPolicy.cpp:157
#2  0x00007ffff57cf7ef in nsContentPolicy::ShouldLoad (this=0x7fffffff6300, contentType=<value optimized out>, 
    contentLocation=<value optimized out>, requestingLocation=<value optimized out>, 
    requestingContext=<value optimized out>, mimeType=<value optimized out>, extra=0xc, decision=0x7ffff5e1ca3b)
    at nsContentPolicy.cpp:218
#3  0x00007ffff5e106de in NS_InvokeByIndex_P (that=0x7fffffff6300, methodIndex=30755248, paramCount=4125602640, 
    params=0x19d60d0) at xptcinvoke_x86_64_unix.cpp:208
#4  0x00007ffff554e5d4 in XPCWrappedNative::CallMethod (ccx=..., mode=<value optimized out>) at xpcwrappednative.cpp:2722
#5  0x00007ffff5556947 in XPC_WN_CallMethod (cx=0xbb6760, obj=0x1fd89c0, argc=6, argv=0xc4d4c8, vp=<value optimized out>)
    at xpcwrappednativejsops.cpp:1740
#6  0x00007ffff6931d47 in js_Invoke (cx=0xbb6760, argc=28040096, vp=0xc4d4b8, flags=<value optimized out>)
    at jsinterp.cpp:1360
#7  0x00007ffff692221c in js_Interpret (cx=0xbb6760) at jsops.cpp:2240
#8  0x00007ffff693224d in js_Invoke (cx=0xbb6760, argc=28040096, vp=0xc4d2f8, flags=<value optimized out>)
    at jsinterp.cpp:1368
#9  0x00007ffff554b526 in nsXPCWrappedJSClass::CallMethod (this=0xbdc020, wrapper=<value optimized out>, 
    methodIndex=<value optimized out>, info=0x932f20, nativeParams=<value optimized out>) at xpcwrappedjsclass.cpp:1696
#10 0x00007ffff5e112a9 in PrepareAndDispatch (self=0x13c73e0, methodIndex=<value optimized out>, args=0x7fffffff7850, 
    gpregs=0x7fffffff77d0, fpregs=0x7fffffff7800) at xptcstubs_x86_64_linux.cpp:153
#11 0x00007ffff5e1076b in SharedStub () from /usr/lib64/xulrunner-1.9.2/libxul.so
#12 0x00007ffff583d986 in nsEventListenerManager::HandleEventSubType(struct {...} *, nsIDOMEventListener *, nsIDOMEvent *, nsPIDOMEventTarget *, PRUint32) (this=<value optimized out>, aListenerStruct=0x13d0c58, aListener=0x13c73e0, aDOMEvent=
    0x1c330b0, aCurrentTarget=0xe80810, aPhaseFlags=28040096) at nsEventListenerManager.cpp:1041
#13 0x00007ffff583dd50 in nsEventListenerManager::HandleEvent (this=<value optimized out>, 
    aPresContext=<value optimized out>, aEvent=0x1bc3340, aDOMEvent=<value optimized out>, 
    aCurrentTarget=<value optimized out>, aFlags=<value optimized out>, aEventStatus=0x7fffffff7bb8)
    at nsEventListenerManager.cpp:1147
#14 0x00007ffff5852b56 in nsEventTargetChainItem::HandleEvent (this=0xc4bc58, aVisitor=..., aFlags=2, 
    aMayHaveNewListenerManagers=0) at nsEventDispatcher.cpp:246
#15 0x00007ffff5852d02 in nsEventTargetChainItem::HandleEventTargetChain (this=<value optimized out>, aVisitor=..., 
    aFlags=6, aCallback=0x0, aMayHaveNewListenerManagers=30755248) at nsEventDispatcher.cpp:332
#16 0x00007ffff585330a in nsEventDispatcher::Dispatch (aTarget=<value optimized out>, aPresContext=<value optimized out>, 
    aEvent=0x1bc3340, aDOMEvent=<value optimized out>, aEventStatus=0x7fffffff7d1c, aCallback=<value optimized out>, 
    aTargets=0x0) at nsEventDispatcher.cpp:573
#17 0x00007ffff58535a6 in nsEventDispatcher::DispatchDOMEvent (aTarget=0x100c4f0, aEvent=<value optimized out>, 
    aDOMEvent=0x1c330b0, aPresContext=0x0, aEventStatus=0x7fffffff7d1c) at nsEventDispatcher.cpp:636
#18 0x00007ffff57d585c in nsContentUtils::DispatchChromeEvent (aDoc=0x1786820, aTarget=<value optimized out>, 
    aEventName=<value optimized out>, aCanBubble=<value optimized out>, aCancelable=<value optimized out>, 
    aDefaultAction=0x0) at nsContentUtils.cpp:3257
#19 0x00007ffff585226f in nsPLDOMEvent::Run (this=0x1d54b40) at nsPLDOMEvent.cpp:62
#20 0x00007ffff5e057c7 in nsThread::ProcessNextEvent (this=0x6c9f30, mayWait=0, result=0x7fffffff7ddc) at nsThread.cpp:527
#21 0x00007ffff5dd9fb5 in NS_ProcessNextEvent_P (thread=0x7fffffff6300, mayWait=30755248) at nsThreadUtils.cpp:250
#22 0x00007ffff5d6cf5e in mozilla::ipc::MessagePump::Run (this=0x6bba70, aDelegate=0x6c7000) at MessagePump.cpp:110
#23 0x00007ffff5dae930 in MessageLoop::Run (this=0x6c7000) at ./src/base/message_loop.cc:173
#24 0x00007ffff5ce9029 in nsBaseAppShell::Run (this=0x7b1120) at nsBaseAppShell.cpp:174
#25 0x00007ffff5bba2d6 in nsAppStartup::Run (this=0x80cdb0) at nsAppStartup.cpp:183
#26 0x00007ffff5524803 in XRE_main (argc=<value optimized out>, argv=<value optimized out>, aAppData=<value optimized out>)
    at nsAppRunner.cpp:3483
#27 0x0000000000401c07 in main (argc=1, argv=0x7fffffffdf28) at nsXULStub.cpp:583
Comment 4 Brian 2011-01-25 01:10:16 UTC
Additional information provided.
Comment 5 Brian 2011-01-26 22:07:44 UTC
As mentioned in the linked forum thread, a workaround this problem was found.  Compiling xulrunner and firefox/thunderbird without -march=native fixes the problem.  It appears to be affecting those with Sandy Bridge processors.
Comment 6 Jory A. Pratt gentoo-dev 2011-01-27 00:57:58 UTC
(In reply to comment #5)
> As mentioned in the linked forum thread, a workaround this problem was found. 
> Compiling xulrunner and firefox/thunderbird without -march=native fixes the
> problem.  It appears to be affecting those with Sandy Bridge processors.
> 

Makes this a toolchain problem.
Comment 7 Ryan Hill (RETIRED) gentoo-dev 2011-01-27 01:21:49 UTC
echo "int main() { return 0; }" | gcc -march=native -v -E - 2>&1 | grep march
Comment 8 Brian 2011-01-27 03:05:58 UTC
(In reply to comment #7)
> echo "int main() { return 0; }" | gcc -march=native -v -E - 2>&1 | grep march
> 

/usr/libexec/gcc/x86_64-pc-linux-gnu/4.4.4/cc1 -E -quiet -v - -D_FORTIFY_SOURCE=2 -march=core2 -mcx16 -msahf -maes -mpclmul -mpopcnt -mavx --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=256 -mtune=core2
Comment 9 Ryan Hill (RETIRED) gentoo-dev 2011-01-27 04:25:24 UTC
Can you start from "-O2 -march=core2 -mcx16 -msahf -maes -mpclmul -mpopcnt -mavx", make sure that fails, and then remove flags one by one off the back until it works?  (it'll probably be -mavx)

Comment 10 Ryan Hill (RETIRED) gentoo-dev 2011-02-08 06:08:28 UTC
Confirmed on forums it's -mavx.  Can someone try gcc-4.4.5 or gcc-4.5.2?

Xulrunner stuff always seems to have issues with stack alignment (eg. bug #270120) and I know I've seen a few gcc bug reports regarding AVX alignment.
Comment 11 Stephan Friedrichs 2011-02-08 08:31:56 UTC
(In reply to comment #10)
> Confirmed on forums it's -mavx.  Can someone try gcc-4.4.5 or gcc-4.5.2?

Confirming for gcc-4.5.2. I'm using gcc-4.5.2 on a Sandy Bridge system and I have the same problem. Removing -mavx from the CFLAGS helps.

BTW: It seems to be enough to rebuild xulrunner without -mavx, I did not have to rebuild firefox or thunderbird.
Comment 12 Stephan Friedrichs 2011-02-28 09:00:09 UTC
If xulrunner has a history of problems with stack alignment, can't we just filter the -mavx cflag in the xulrunner ebuild?
Comment 13 SpanKY gentoo-dev 2011-03-01 00:08:14 UTC
stack misalignment on x86 isnt specific to xulrunner.  any package using zlib can hit it.
Comment 14 Stephan Friedrichs 2011-03-01 10:10:49 UTC
(In reply to comment #13)
> stack misalignment on x86 isnt specific to xulrunner.  any package using zlib
> can hit it.
> 

Would you recommend a system-wide

CFLAGS="-march=native -mnoavx -O2 -pipe"

instead of

CFLAGS="-march=native -O2 -pipe"

as workaround for Sandy Bridge CPUs?
Comment 15 Aidan Marks 2011-04-11 09:59:31 UTC
Hit this one today after upgrading from firefox 3.6.15 to 3.6.16.  firefox wouldn't start up, even with no profile or safe mode, silently exits.  went back to 3.6.15, still broken. I have march=native with gcc 4.5.2 on sandy bridge.  I put just -O2 -pipe in /etc/portage/env for xulrunner and firefox and recompiled and all back working with my original profile.
Comment 16 stardub 2011-05-13 07:25:37 UTC
Hi

I can not confirm this on ARM: 

Yesterday I tried to emerge xulrunner-2.0.1 on my armv7 (cortex-a9) smartbook - Configure failed cause of -mno-avx while compile a conftest.c.
I edited my temp/environment and removed the -mno-avx and run ebuild .. configure compile... ...success

Test:
# echo "int main(){return 0;}" | gcc -E -mno-avx  - > /dev/null
cc1: error: unrecognized command line option "-mno-avx"

# gcc-config -l
[1] armv7a-unknown-linux-gnueabi-4.4.5 *
Comment 17 Matt Turner gentoo-dev 2011-06-03 04:41:09 UTC
(In reply to comment #16)
> I can not confirm this on ARM: 

Huh? ARM? AVX is an instruction set addition for new Intel x86 CPUs. I think you got confused. :)
Comment 18 Jory A. Pratt gentoo-dev 2011-06-03 13:01:25 UTC
(In reply to comment #16)
> Hi
> 
> I can not confirm this on ARM: 
> 
> Yesterday I tried to emerge xulrunner-2.0.1 on my armv7 (cortex-a9) smartbook -
> Configure failed cause of -mno-avx while compile a conftest.c.
> I edited my temp/environment and removed the -mno-avx and run ebuild ..
> configure compile... ...success
> 
> Test:
> # echo "int main(){return 0;}" | gcc -E -mno-avx  - > /dev/null
> cc1: error: unrecognized command line option "-mno-avx"
> 
> # gcc-config -l
> [1] armv7a-unknown-linux-gnueabi-4.4.5 *

	# Ensure we do not fail on i{3,5,7} processors that support -mavx
	if use amd64 || use x86; then
		append-flags -mno-avx
	fi

Straight from the ebuild, if your still seeing a problem on arm then your tree is out of sync.
Comment 19 Chema 2011-06-05 20:04:30 UTC
# Ensure we do not fail on i{3,5,7} processors that support -mavx
    if use amd64 || use x86; then
        append-flags -mno-avx
    fi

Adding that in xulrunner ebuild may be sufficient for Firefox, but for Thunderbird you also need to add it to its ebuild or it won't start
Comment 20 Jory A. Pratt gentoo-dev 2011-06-05 22:54:42 UTC
(In reply to comment #19)
> # Ensure we do not fail on i{3,5,7} processors that support -mavx
>     if use amd64 || use x86; then
>         append-flags -mno-avx
>     fi
> 
> Adding that in xulrunner ebuild may be sufficient for Firefox, but for
> Thunderbird you also need to add it to its ebuild or it won't start

Thunderbird-3.3_alpha* already includes as well.
Comment 21 SpanKY gentoo-dev 2011-06-07 04:27:07 UTC
*** Bug 356397 has been marked as a duplicate of this bug. ***
Comment 22 Ryan Hill (RETIRED) gentoo-dev 2011-06-23 05:25:15 UTC
>     # Ensure we do not fail on i{3,5,7} processors that support -mavx
>     if use amd64 || use x86; then
>         append-flags -mno-avx
>     fi
> 
> Straight from the ebuild, if your still seeing a problem on arm then your tree
> is out of sync.

If you're going to do that then make it dependent on >=4.4 so you don't break older versions (and preferably only on versions you know are broken).
Comment 23 Ryan Hill (RETIRED) gentoo-dev 2011-07-10 23:49:58 UTC
*** Bug 373941 has been marked as a duplicate of this bug. ***
Comment 24 Ryan Hill (RETIRED) gentoo-dev 2011-07-12 23:23:24 UTC
*** Bug 373941 has been marked as a duplicate of this bug. ***
Comment 25 Clemente Aguiar 2011-07-14 07:13:04 UTC
Regarding specifically of the bug 373941, app-office/libreoffice-3.3.3 builds with "-mno-avx".
Comment 26 Richard 2011-07-30 05:55:36 UTC
This also affects GCC 4.4.6.

By the way, a possible issue with -mno-avx is that -mavx disables SSE optimizations and it is uncertain (until someone examines GCC) that -mno-avx will turn them back on. It is probably better to specify optimizations manually:

"-march=core2 -mcx16 -msahf -maes -mpclmul -msse4.1 -msse4.2 --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=256 -mtune=core2"

You can get GCC to show you what -march=native does with "gcc -march=native -v --help=target". Since -mavx is used, the "-msse4.1 -msse4.2" options will be missing.
Comment 27 Richard 2011-07-30 06:11:18 UTC
Correction, here are the optimizations you want (in addition to -O2 and -pipe):

-march=core2 -mcx16 -msahf -maes -mpclmul -mpopcnt -msse4.1 -msse4.2 --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=256 -mtune=core2

I forgot to include -mpopcnt.
Comment 28 Ryan Hill (RETIRED) gentoo-dev 2011-07-30 06:39:40 UTC
> "-march=core2 -mcx16 -msahf -maes -mpclmul -msse4.1 -msse4.2 --param
> l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=256
> -mtune=core2"

NB: this is processor-specific so people shouldn't blindly copy it.  Also there are a few packages that call strip-flags that choke on --param options.
 
> You can get GCC to show you what -march=native does with "gcc -march=native -v
> --help=target". Since -mavx is used, the "-msse4.1 -msse4.2" options will be
> missing.

Use `echo "" | gcc -march=native -E - 2>&1 | grep cc1`.  --help=target can miss some options enabled by other options because it's evaluated early.

> By the way, a possible issue with -mno-avx is that -mavx disables SSE
> optimizations and it is uncertain (until someone examines GCC) that -mno-avx
> will turn them back on.

So what does -march=native -mno-avx tell you?
Comment 29 Jory A. Pratt gentoo-dev 2011-10-31 21:52:08 UTC
Nothing for mozilla team to do here, readd later if needed.
Comment 30 SpanKY gentoo-dev 2015-10-02 22:33:14 UTC
re-open if it's still an issue with gcc-4.9+