-fno-strict-aliasing in CWARNFLAGS?
Jeremy Huddleston
jeremyhu at apple.com
Tue Feb 2 17:34:53 PST 2010
On Feb 2, 2010, at 17:11, Gaetan Nadon wrote:
> On Tue, 2010-02-02 at 14:00 -0800, Jeremy Huddleston wrote:
>
>> On Feb 2, 2010, at 13:18, Gaetan Nadon wrote:
>>
>>> I have not seen any compelling reasons to turn off this optimization.
>>> Maybe 10 years ago when it was first introduced. I have seen reports of
>>> large number of warnings, but from older gcc versions. As it is today,
>>> we are losing some optimization that could be beneficial.
>>>
>>> This option has been there for so long (most likely copied along), I
>>> doubt you will will get a clear answer for each of the 240 xorg modules.
>>> It would take a few modules to try it out first.
>>
>> I see it in libX11 has historically used -fno-strict-aliasing:
>> http://cgit.freedesktop.org/xorg/lib/libX11/commit/?id=db7c6fdeeaef9475458498e4cf09d6b1329e9aa3
>>
>> but adding XORG_CWARNFLAGS to XORG_DEFAULT_OPTIONS has caused this to change for other modules.
>>
>> Looking at historic versions of modules, I see it present in:
>>
>> libICE
>> libSM
>> libX11
>> libXau
>> libXfont
>> libXft
>> libXpm
>> libXres
>> xorg-server
>>
>> of course most of these seem to have just copied the entire GCC_WARNINGS block and probably didn't actually need -fno-strict-aliasing
>
> Of course. Whatever the reasons were, if anyone remembers, may not apply
> anymore. Devising a plan for it's removal will not be an easy task. I
> see 3 options:
>
> 1) take it out of macros, 1 patch
I sent that patch already.
> 2) transfer it to all makefiles and then removing it gradually, that's
> 2*240 +1 patches
I don't think that's wise. If anything, you should just put it in the ones where it was prior to XORG_CWARNFLAGS (the 9 mentioned above).
That being said, I also enabled the warning which should mention when it discovers code sensitive to the -fstrict-aliasing optimization, and none of the libs in the list above spewed such a warning.
> 3) override in 'n' makefiles until proven safe. Then take it out macros.
> That's 2*n +1 patches.
We could do that for the 9 modules above. I'm fairly confident that the libs don't need it, but I haven't rebuilt all of the server to be confident it doesn't spew any warnings about strict-aliasing.
More information about the xorg-devel
mailing list