> On 14 Jan 2019, at 13:53, Rainer Orth <r...@cebitec.uni-bielefeld.de> wrote:
> 
> "MCC CS" <mc...@gmx.com> writes:
> 
>> I've been running the testsuite on my macOS, on which
>> it is especially unbearable. I want to (at least try to)
> 
> that problem may well be macOS specific: since at least macOS 10.13
> (maybe even 10.12; cannot currently tell for certain) make -jN check
> times on my Mac mini skyrocketed with between 60 and 80% system time.
> It seems this is due to lock contention on one specific kernel lock, but
> I haven't been able to find out more yet.

this PR mentions the compilation, but it’ even more apparent on test.
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84257

* Assuming SIP is disabled.

Some testing suggests that each DYLD_LIBRARY_PATH entry adds around 2ms to each 
exe launch.
So .. when you’re doing something that’s a lot of work per launch, not much is 
seen - but when you’re doing things with a huge number of exe launches - e.g. 
configuring or running the test suite, it bites.

A work-around is to remove the RPATH_ENVAR variable setting in the top level 
Makefile.in (which actually has the same effect as running things with SIP 
enabled)

=== Possible solution (partial hacks locally, not ready for posting)

My current investigations (targeted at GCC 10 time frame, even if they are 
subsequently back-ported) is to replace all use of absolute pathnames in GCC 
libraries with @rpath/xxx and figure out a way to get the compiler to auto-add 
the relevant rpaths to exes (so that a fixed installation of GCC behaves the 
same way as it does currently).

=== DejaGNU on macOS...

DejaGNU / expect are not fantastic on macOS, even given the comments above - 
it’s true.  Writing an interpreter/funnel for the testsuite has crossed my mind 
more than once. 

However, I suspect it’s a large job, and it might be more worth investing any 
available effort in debugging the slowness in expect/dejaGNU - especially the 
lock contention that Rainer mentions.

> There's no such problem on other targets, not even e.g. on Mac OS X 10.7.

indeed.

Iain

Reply via email to