-march=<name of native> doesn't seem to set flags -march=native does?

Roger Pack rogerdpack2@gmail.com
Tue Jul 26 14:26:00 GMT 2016


On 7/14/16, Marc Glisse <marc.glisse@inria.fr> wrote:
> On Thu, 14 Jul 2016, Jonathan Wakely wrote:
>
>> On 14 July 2016 at 01:05, Roger Pack wrote:
>>> Hello.
>>> As a note after a discussion [1]
>>>
>>> I ran into this oddness:
>>>
>>>
>>> $ gcc-6 -march=native -Q --help=target | grep march
>>>   -march=                               ivybridge
>>> $ gcc-6 -march=native -Q --help=target | grep sse3
>>>   -msse3                                [enabled]
>>>   -mssse3                               [enabled]
>>> $ gcc-6 -march=ivybridge -Q --help=target | grep sse3
>>>   -msse3                                [disabled]
>>>   -mssse3                               [disabled]
>>>
>>> It appears that specifying (in this case) "-march=ivybridge" which is
>>> the native, isn't enough/the same as specifying -march=native?
>>> In addition, the "cache sizes" don't seem to be called out with
>>> "-march=ivybridge" as they are with "-march=native"
>>> Anybody know what I'm missing here?
>>
>> The named arch is a pre-configured set of supported instructions,
>> which should be true for all processors in that range.
>>
>> Whereas "native" probes the CPU flags and enables precisely the set of
>> instructions it supports.
>>
>> That they are different suggests either the preconfigured settings for
>> ivybridge are wrong, or not all processors in that family support all
>> the instructions your particular model supports.
>>
>> Ivybridge should enable SSE3 and SSSE3 though, so I'm nto sure what's
>> happening there.
>
> Option reporting is not reliable. Try preprocessing a file that contains
> the macro __SSE3__ to check if sse3 is enabled.
>

OK that makes more sense thank you.

can anyone confirm or deny if the cache-size and cache-line-size are
set "appropriately" if cc1 receives the "-march" flag for a particular
processor?



More information about the Gcc-help mailing list