Re: ARM and AArch64 GCC 7.1 ABI change

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Apr 25, 2017 at 2:37 PM, Peter Robinson <pbrobinson@xxxxxxxxx> wrote:
> On Tue, Apr 25, 2017 at 4:52 PM, Jakub Jelinek <jakub@xxxxxxxxxx> wrote:
>> Hi!
>>
>> A severe ABI bug on AArch64 and especially on ARM 32-bit has been
>> recently discovered and GCC 7.1 is going to have that ABI change in.
>> For details see http://gcc.gnu.org/PR77728
>> gcc-7.1.1-0.16.fc{26,27} which I'll build tomorrow will contain the
>> ABI changes as well as a -Wpsabi diagnostics (note:) on code that is
>> changing the ABI.
>> The ABI change should affect primarily just C++ code passing PODs
>
> By primarily is it guaranteed to be limited to C++ or is it possible
> it could affect other code?
>
>> by value where all the non-static data members and base classes are at most
>> word aligned, but there are some static data members with doubleword
>> or bigger alignment or there are typedefs or other nested types in
>> the class/struct which are doubleword or bigger aligned, and are passed
>> in certain positions in the argument list (passing them in even registers
>> is fine, passing them in odd ones changes ABI, on the stack at odd positions
>> might change the ABI too).  For the typedefs, the broken ABI of GCC 5.2 to 7.0.1
>> has been actually not even self-consitent in some templates, earlier
>> instantiation vs. lack thereof could affect the ABI.  GCC 5.1 and earlier
>> for structs used to match earlier AAPCS version and had different rules and
>> issues.
>>
>> Could somebody from rel-eng perform a test mass rebuild on armv7hl
>> and aarch64 of F26 to determine which packages are affected by the
>> ABI changes so that we could rebuild only those that actually need changing?
>>
>> If grepping for note: is not good enough for the test mass rebuild, I could
>> hack up a test compiler that does something different when it encounters
>> this (say abort if it encounters this and some special env var is set,
>> or writes something into some /tmp/ file and let some brp script collect
>> info from there, etc.).
>>

Could this be the reason why capnproto builds fail on ARM? I've been
trying to build it for months, and it seems to just die in the build
process.

c.f.: https://koji.fedoraproject.org/koji/taskinfo?taskID=18098874


-- 
真実はいつも一つ!/ Always, there's only one truth!
_______________________________________________
devel mailing list -- devel@xxxxxxxxxxxxxxxxxxxxxxx
To unsubscribe send an email to devel-leave@xxxxxxxxxxxxxxxxxxxxxxx




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Fedora Announce]     [Fedora Kernel]     [Fedora Testing]     [Fedora Formulas]     [Fedora PHP Devel]     [Kernel Development]     [Fedora Legacy]     [Fedora Maintainers]     [Fedora Desktop]     [PAM]     [Red Hat Development]     [Gimp]     [Yosemite News]
  Powered by Linux