| delorie.com/archives/browse.cgi | search |
| X-Recipient: | archive-cygwin AT delorie DOT com |
| X-SWARE-Spam-Status: | No, hits=-1.1 required=5.0 tests=AWL,BAYES_00,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FROM,T_TO_NO_BRKTS_FREEMAIL |
| X-Spam-Check-By: | sourceware.org |
| Message-ID: | <448494.36555.qm@web25508.mail.ukl.yahoo.com> |
| Date: | Sat, 16 Oct 2010 15:57:00 +0100 (BST) |
| From: | Marco Atzeri <marco_atzeri AT yahoo DOT it> |
| Subject: | Re: gfortran 4.3.4: NINT() intrinsic triggers undefined references to '_llround' and '_llroundf' |
| To: | cygwin AT cygwin DOT com |
| In-Reply-To: | <AANLkTi=fHP=JvYFB0BoLkmcZibYoLXcC4BFeR7f7EEpF@mail.gmail.com> |
| MIME-Version: | 1.0 |
| X-IsSubscribed: | yes |
| Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
| List-Id: | <cygwin.cygwin.com> |
| List-Unsubscribe: | <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com> |
| List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
| List-Archive: | <http://sourceware.org/ml/cygwin/> |
| List-Post: | <mailto:cygwin AT cygwin DOT com> |
| List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs> |
| Sender: | cygwin-owner AT cygwin DOT com |
| Mail-Followup-To: | cygwin AT cygwin DOT com |
| Delivered-To: | mailing list cygwin AT cygwin DOT com |
--- Sab 16/10/10, Cornelis de Gier ha scritto:
> 2010/10/16 Marco Atzeri <xxxxxxxxx AT xxxxxxx>:
^^^^^^^^^^^^^^^^^=20=20=20
don't feed spammer please
> > As Dave wrote the problem is inside cygwin
> >
> >> I thought it was just because we are failing to
> export
> >> them in the cygwin.din file. =A0The correct .o
> files are
> >> compiled as part of the newlib libm build.
> >
> > but we forgot to make a patch.
> >
> > I will look on it.
> >
> > Marco
>=20
> Below follows a C program that triggers the same undefined
> reference
> (gcc 4.3.4, current cygwin). A simpler version using e.g.
> llround(4.5)
> is optimized away. A strings command on /lib/libm.a shows
> llround is
> not available.
>=20
> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D
> #include <math.h>
> float test(){
> return(4.569);
> }=A0=A0=A0=20
>=20
> int main(){
> return(llround(test()));
> }
> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D
> $ gcc -Wall -lm testllround.c
> /tmp/ccLX7lEo.o:testllround.c:(.text+0x32): undefined
> reference to `_llround'
> collect2: ld returned 1 exit status
> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D
> $ strings /lib/libm.a | grep lround
> _lround
> _lroundf
> _lround
> __imp__lround
> _lroundf
> __imp__lroundf
> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=
=3D=3D=3D=3D=3D=3D=3D=3D=3D
Of course. As I wrote it is a cygwin problem
not a fortran issue.
llround and llroundf are built in newlib (cygwin C library)
$ nm i686-pc-cygwin/newlib/libm.a |grep round |grep T
00000000 T _llround
00000000 T _lround
00000000 T _round
00000000 T _llroundf
00000000 T _lroundf
00000000 T _roundf
but are not included in the final libm.a
$ nm i686-pc-cygwin/winsup/cygwin/libm.a |grep round |grep T
00000000 T _lround
00000000 T _lroundf
00000000 T _round
00000000 T _roundf
I will prepare a patch in the coming days, so that
next cygwin release will have them.
Regards
Marco
--
Problem reports: http://cygwin.com/problems.html
FAQ: http://cygwin.com/faq/
Documentation: http://cygwin.com/docs.html
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
| webmaster | delorie software privacy |
| Copyright © 2019 by DJ Delorie | Updated Jul 2019 |