On Tue, Sep 5, 2017 at 10:28 PM, Grant <[email protected]> wrote:
>>>> Now I'm running into "trap invalid opcode" errors on the older
>>>> systems.  Can I disable some of the newer CPU instruction sets on the
>>>> master laptop when compiling to hopefully generate binaries that will
>>>> work on the older systems?
>>>
>>>   Yes.  You need to find out CPU_FLAGS_X86 and "-march=" values the
>>> machines have, and use that in make.conf.  Run the commands...
>>>
>>> cpuinfo2cpuflags-x86
>>> gcc -c -Q -march=native --help=target | grep march=
>>>
>>> ...on the target machines.  This will tell you what "native" is and
>>> what CPU_FLAGS_X86 values to use.
>>>
>>> https://gcc.gnu.org/onlinedocs/gcc-6.3.0/gcc/x86-Options.html#x86-Options
>>> lists available "march=" options, and what instruction sets they support.
>>> E.g. my old core2 desktop shows...
>>>
>>> [d531][waltdnes][~] cpuinfo2cpuflags-x86
>>> CPU_FLAGS_X86="mmx mmxext sse sse2 sse3 ssse3"
>>>
>>> [d531][waltdnes][~] gcc -c -Q -march=native --help=target | grep march=
>>>   -march=                               core2
>>>
>>>
>>>   Unless the laptops are really old, you can probably get away with...
>>> CFLAGS="-O2 march=core2 -mfpmath=sse -fopenmp -fomit-frame-pointer -pipe 
>>> -fno-unwind-tables -fno-asynchronous-unwind-tables"
>>>
>>> booby trap 1) Unless all machines are Intel "Atom" family, do *NOT* use
>>> a "march=" that implements the "movbe" instruction.
>>>
>>> booby trap 2) If you throw in any AMD-based machines proceed with care.
>>>
>>>   Can you post the output of...
>>> gcc -c -Q -march=native --help=target | grep march=
>>> ...for all the target machines?
>>
>>
>> Let's see how -mtune=native goes and resort to the above if necessary.
>> It doesn't look too bad though.
>
>
> emerge -e world has finished and pushed and -mtune=native seems to
> have solved the issue for now.
>

You might be interested in "-march=x86-64 -mtune=generic" though this
will mean you might miss out on some optimizations.

Reply via email to