[Rd] Wrong config check for __libc_stack_end
Simon Urbanek
simon.urbanek at r-project.org
Mon Feb 1 16:53:29 CET 2016
On Feb 1, 2016, at 9:56 AM, Alba Pompeo <albapompeo at gmail.com> wrote:
> @Simon. Here's what I did.
> I checked out R revision 70059.
> Ran export r_cv_libc_stack_end=no. (otherwise it would give that error
> we talked about before)
No, the whole point was to test this behavior. I see that the fix is in configure.ac but not configure so you'll need to run something like
aclocal -I m4 && autoconf
to update it.
Also please don't build in the sources - you'll have trouble making sure they are clean. It is recommended to build in a separate directory (see the docs).
> Ran ./configure --without-recommended-packages. (otherwise it would
> complain of not finding ./src/library/Recommended/MASS_*.tar.gz)
I guess you forgot to run
tools/rsync-recommended
perhaps? It doesn't matter either way for the above issues, but it's probably better to build with recommended packages.
Cheers,
Simon
> Ran make.
> Ran make check. Log is here - http://pastebin.com/raw/cGJgqB8p
>
> What do you think? Is there anything else I can do to help solve this issue?
>
>
>
> On Mon, Feb 1, 2016 at 11:36 AM, Simon Urbanek
> <simon.urbanek at r-project.org> wrote:
>>
>> On Feb 1, 2016, at 4:16 AM, Martin Maechler <maechler at stat.math.ethz.ch> wrote:
>>
>>>>>>>> Alba Pompeo <albapompeo at gmail.com>
>>>>>>>> on Fri, 29 Jan 2016 08:23:26 -0200 writes:
>>>
>>>> Here is my log from 'make check' using an Intel i5 64-bit
>>>> processor - http://pastebin.com/raw/N6SYAuFX Here is
>>>> Isaac's log from 'make check' using an Intel Atom 32-bit
>>>> processor - http://pastebin.com/raw/sey6DEk9
>>>
>>>> We are both on Alpine Linux, which uses the musl
>>>> libc. http://www.musl-libc.org/
>>>
>>>> Thank you very much.
>>>
>>> It probably would have helped to choose a different subject
>>> which I now do.
>>>
>>
>> Agreed, since there is actually no abuse, case was easily dismissed as bogus given the subject.
>>
>>
>>>> On Thu, Jan 28, 2016 at 9:54 AM, Alba Pompeo
>>>> <albapompeo at gmail.com> wrote:
>>>>> Hello, developers of R.
>>>>>
>>>>> I have been unsuccessfully trying to build R on a musl
>>>>> libc system for the last days. ./configure works, but
>>>>> make fails. The command that errors out is here -
>>>>> http://pastebin.com/raw/UwFRsiqT
>>>>>
>>>>> It was brought to my attention that this is a (very
>>>>> longstanding) abuse of a private glibc symbol in R.
>>>>>
>>>>> In R 3.2.3, it seems that configure is trying to test for
>>>>> it on Linux. It apparently fails to accurately test (as
>>>>> demonstrated by the link error), perhaps because the test
>>>>> program does not actually *use* __libc_stack_end so it
>>>>> gets optimized out. (See line 35500 or so in
>>>>> R-3.2.3/configure.) Ideally, the test program would
>>>>> check that a pointer to __libc_stack_end is non-null, but
>>>>> that's an autoconf bug.
>>>
>>> So, ideally someone who knows autoconf much better than I do
>>> should submit a bug report to the autoconf maintainers.
>>>
>>
>> @Alba, can you, please, check that your hypothesis actually holds true and the latest R from trunk fixes the check for you?
>>
>>
>>> Back to R: I'm not familiar with that part of the code, neither
>>> the configuration, nor the usage (in R/src/unix/system.c ).
>>> However, that code seems to be using a a glibc "feature" widely
>>> available which does help making R startup (a very tiny bit ??)
>>> faster.
>>>
>>
>> No, it's actually very crucial as it is used to detect stack overflows.
>>
>> Cheers,
>> Simon
>>
>>
>>
>>>>> A work around was to 'export r_cv_libc_stack_end=no'
>>>>> before configuring R.
>>>
>>> which *does* solve that problem, right?
>>>
>>>>> However, there are a couple little issues with non-ASCII
>>>>> text and a *lot* of math differences, many of which say
>>>>> "*no* convergence: NOTIFY R-core!".
>>>
>>> Hmm, I may be off, but these would look like entirely unrelated
>>> with the libc_stack_end availibility, wouldn't they ?
>>>
>>> Maybe you / the musl developers should try to make those C
>>> libraries more "standard", notably because I would see math
>>> differences as something pretty grave for R, and indeed, I would
>>> not want to use a platform where R's math functions work
>>> incompatibly with all other platforms ... but maybe I
>>> misunderstand completely.
>>>
>>> Hmm... I've found this,
>>>
>>> http://wiki.musl-libc.org/wiki/Functional_differences_from_glibc#Floating-point_and_mathematical_library
>>>
>>> which make what you say above more relevant/interesting.
>>>
>>> Still, from this thread I get that the C source code of R needs
>>> considerable configuration patches before R can work with musl.
>>> But that needs another thread, something like 'Building R with musl'.
>>>
>>>>> Until these are resolved, R can't be packaged for
>>>>> distributions that use musl, such as Alpine Linux.
>>>
>>> which I agree would not be ideal.
>>> Martin
>>>
>>> --
>>> Martin <Maechler at stat.math.ethz.ch> http://stat.ethz.ch/people/maechler
>>> Seminar für Statistik, ETH Zürich
>>>
>>> ______________________________________________
>>> R-devel at r-project.org mailing list
>>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>>
>>
>
More information about the R-devel
mailing list