unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* Building Emacs-trunk with gcc >= 4.5.1 and libelf installed
@ 2010-08-23 23:31 Angelo Graziosi
  2010-08-24  4:37 ` Yaakov (Cygwin/X)
  0 siblings, 1 reply; 4+ messages in thread
From: Angelo Graziosi @ 2010-08-23 23:31 UTC (permalink / raw)
  To: Cygwin; +Cc: Emacs

Trying to build Emacs-trunk on Cygwin with GCC >= 4.5.1, I have found a 
problem if also the package 'libelf0' is installed.

The build fails in this way:

=====================================
./configure
[...]
checking for elf_begin in -lelf... yes
[...]
make
[...]
gcc-4.6...
In file included from /usr/include/X11/Xos.h:146:0,
                  from /tmp/emacs/src/xfaces.c:277:
/usr/include/X11/Xarch.h:43:30: fatal error: sys/byteorder.h: No such
file or directory
compilation terminated.
make[2]: *** [xfaces.o] Error 1
make[2]: *** Waiting for unfinished jobs....
make[2]: Leaving directory '/tmp/emacs/Work/src'
make[1]: *** [src] Error 2
make[1]: Leaving directory '/tmp/emacs/Work'
make: *** [bootstrap] Error 2
=====================================

The issue is fixed, simply, if I uninstall 'libelf0'. Indeed...

If 'libelf0' is installed, we have from 'configure',

--------
checking for elf_begin in -lelf... yes
--------

and the following test in 'configure' script is true:

--------
if test $ac_have_func = no && test "$ac_cv_lib_elf_elf_begin" = yes; then
   ac_have_func=yes

$as_echo "#define SVR4 1" >>confdefs.h

fi
--------

i.e. SVR4 is _defined_. But... 'src/xfaces.c' includes indirectly via 
'/usr/include/X11/Xos.h' the header '/usr/include/X11/Xarch.h', which has:

--------
[...]
#  if defined(SVR4) || defined(__SVR4)
#   include <sys/byteorder.h>
#  elif
[...]
--------

i.e. finding SVR4 defined, it searches for 'byteorder.h' in 
'/usr/include/sys' and not in '/usr/include/asm', where it lives (*as on 
GNU/Linux*[1]), and this leads to the above failure.

What does the Cygwin 'libelf0' maintainer think about these facts?

Thanks,
Angelo.

---
[1] Here Cygwin isn't different frome GNU/Linux Kubuntu 10.04. :-)




^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: Building Emacs-trunk with gcc >= 4.5.1 and libelf installed
  2010-08-23 23:31 Angelo Graziosi
@ 2010-08-24  4:37 ` Yaakov (Cygwin/X)
  0 siblings, 0 replies; 4+ messages in thread
From: Yaakov (Cygwin/X) @ 2010-08-24  4:37 UTC (permalink / raw)
  To: cygwin, emacs-devel

On Tue, 2010-08-24 at 01:31 +0200, Angelo Graziosi wrote:
> Trying to build Emacs-trunk on Cygwin with GCC >= 4.5.1, I have found a 
> problem if also the package 'libelf0' is installed.
[snip]
> and the following test in 'configure' script is true:
[snip]
> i.e. SVR4 is _defined_. But... 'src/xfaces.c' includes indirectly via 
> '/usr/include/X11/Xos.h' the header '/usr/include/X11/Xarch.h', which has:
[snip]
> i.e. finding SVR4 defined, it searches for 'byteorder.h' in 
> '/usr/include/sys' and not in '/usr/include/asm', where it lives (*as on 
> GNU/Linux*[1]), and this leads to the above failure.

This is coming from autoconf's AC_FUNC_GETLOADAVG, which tries to find
several different getloadavg(3) implementations (which Cygwin doesn't
provide), otherwise it points to an AC_LIBOBJ from gnulib.  On Solaris,
the gnulib getloadavg uses kvm_open(3) and friends, and libkvm requires
libelf, hence the check for the latter.

AFAICS the proper solution is, in _AC_LIBOBJ_GETLOADAVG:

if test $ac_have_func = no && test "$ac_cv_lib_elf_elf_begin" = yes;
then
  ac_have_func=yes
  AC_DEFINE(SVR4, 1, [Define to 1 on System V Release 4.])
fi

to add << && test "$ac_cv_lib_kvm_kvm_open" = yes >> to the conditional.

In the meantime, since libelf isn't needed elsewhere in emacs, an easy
workaround is to add "ac_cv_lib_elf_elf_begin=no" to CYGCONF_ARGS.

HTH,


Yaakov




^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: Building Emacs-trunk with gcc >= 4.5.1 and libelf installed
@ 2010-08-24  9:05 Angelo Graziosi
  2010-08-24  9:29 ` Yaakov (Cygwin/X)
  0 siblings, 1 reply; 4+ messages in thread
From: Angelo Graziosi @ 2010-08-24  9:05 UTC (permalink / raw)
  To: Cygwin, Emacs

Yaakov ,
thanks for clarifications and suggestions. I hope someone on the Emacs 
list can recipie and apply them appropriately.

Emacs guys,
the simplest workaround I found to fix the issue was to add

#undef SVR4

in src/s/cygwin.h

Thanks,
Angelo.


Yaakov (Cygwin/X) wrote:
> On Tue, 2010-08-24 at 01:31 +0200, Angelo Graziosi wrote:
>> Trying to build Emacs-trunk on Cygwin with GCC >= 4.5.1, I have found a
>> problem if also the package 'libelf0' is installed.
> [snip]
>> and the following test in 'configure' script is true:
> [snip]
>> i.e. SVR4 is _defined_. But... 'src/xfaces.c' includes indirectly via
>> '/usr/include/X11/Xos.h' the header '/usr/include/X11/Xarch.h', which has:
> [snip]
>> i.e. finding SVR4 defined, it searches for 'byteorder.h' in
>> '/usr/include/sys' and not in '/usr/include/asm', where it lives (*as on
>> GNU/Linux*[1]), and this leads to the above failure.
>
> This is coming from autoconf's AC_FUNC_GETLOADAVG, which tries to find
> several different getloadavg(3) implementations (which Cygwin doesn't
> provide), otherwise it points to an AC_LIBOBJ from gnulib.  On Solaris,
> the gnulib getloadavg uses kvm_open(3) and friends, and libkvm requires
> libelf, hence the check for the latter.
>
> AFAICS the proper solution is, in _AC_LIBOBJ_GETLOADAVG:
>
> if test $ac_have_func = no && test "$ac_cv_lib_elf_elf_begin" = yes;
> then
>   ac_have_func=yes
>   AC_DEFINE(SVR4, 1, [Define to 1 on System V Release 4.])
> fi
>
> to add << && test "$ac_cv_lib_kvm_kvm_open" = yes >> to the conditional.
>
> In the meantime, since libelf isn't needed elsewhere in emacs, an easy
> workaround is to add "ac_cv_lib_elf_elf_begin=no" to CYGCONF_ARGS.


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: Building Emacs-trunk with gcc >= 4.5.1 and libelf installed
  2010-08-24  9:05 Building Emacs-trunk with gcc >= 4.5.1 and libelf installed Angelo Graziosi
@ 2010-08-24  9:29 ` Yaakov (Cygwin/X)
  0 siblings, 0 replies; 4+ messages in thread
From: Yaakov (Cygwin/X) @ 2010-08-24  9:29 UTC (permalink / raw)
  To: cygwin, emacs-devel

On Tue, 2010-08-24 at 11:05 +0200, Angelo Graziosi wrote:
> Yaakov ,
> thanks for clarifications and suggestions. I hope someone on the Emacs 
> list can recipie and apply them appropriately.

This is not an issue with emacs per se but with autoconf, so this needs
to be fixed there.  Eric?


Yaakov
Cygwin/X




^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2010-08-24  9:29 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-08-24  9:05 Building Emacs-trunk with gcc >= 4.5.1 and libelf installed Angelo Graziosi
2010-08-24  9:29 ` Yaakov (Cygwin/X)
  -- strict thread matches above, loose matches on Subject: below --
2010-08-23 23:31 Angelo Graziosi
2010-08-24  4:37 ` Yaakov (Cygwin/X)

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).