* [PATCH 1/1] support cross compilation [not found] <20210526073239.21270-1-ptr@void-ptr.info> @ 2021-05-26 7:32 ` Petr Ovtchenkov 2021-05-26 13:09 ` Érico Nogueira 0 siblings, 1 reply; 6+ messages in thread From: Petr Ovtchenkov @ 2021-05-26 7:32 UTC (permalink / raw) To: elfutils-devel Possible problem with out-of-tree build expected --- Makefile.am | 2 +- configure.ac | 6 ++++++ lib-host/Makefile.am | 47 ++++++++++++++++++++++++++++++++++++++++++++ libcpu/Makefile.am | 11 +++++++++++ 4 files changed, 65 insertions(+), 1 deletion(-) create mode 100644 lib-host/Makefile.am diff --git a/Makefile.am b/Makefile.am index 9c47afa9..b93839ec 100644 --- a/Makefile.am +++ b/Makefile.am @@ -26,7 +26,7 @@ AM_MAKEFLAGS = --no-print-directory pkginclude_HEADERS = version.h -SUBDIRS = config lib libelf libcpu backends libebl libdwelf libdwfl libdw \ +SUBDIRS = config lib lib-host libelf libcpu backends libebl libdwelf libdwfl libdw \ libasm debuginfod src po doc tests EXTRA_DIST = elfutils.spec GPG-KEY NOTES CONTRIBUTING \ diff --git a/configure.ac b/configure.ac index b348a717..432b961a 100644 --- a/configure.ac +++ b/configure.ac @@ -88,6 +88,7 @@ AS_IF([test "$use_locks" = yes], AH_TEMPLATE([USE_LOCKS], [Defined if libraries should be thread-safe.]) AC_PROG_CC +AX_PROG_CC_FOR_BUILD AC_PROG_RANLIB AC_PROG_YACC AM_PROG_LEX @@ -96,6 +97,8 @@ m4_ifdef([AM_PROG_AR], [AM_PROG_AR]) AC_CHECK_TOOL([READELF], [readelf]) AC_CHECK_TOOL([NM], [nm]) +AM_CONDITIONAL([CROSS], [test "x$cross_compiling" = xyes]) + # We use -std=gnu99 but have explicit checks for some language constructs # and GNU extensions since some compilers claim GNU99 support, but don't # really support all language extensions. In particular we need @@ -593,6 +596,9 @@ AC_CONFIG_FILES([doc/Makefile]) dnl Support library. AC_CONFIG_FILES([lib/Makefile]) +dnl Support library. +AC_CONFIG_FILES([lib-host/Makefile]) + dnl ELF library. AC_CONFIG_FILES([libelf/Makefile]) diff --git a/lib-host/Makefile.am b/lib-host/Makefile.am new file mode 100644 index 00000000..9316c8ed --- /dev/null +++ b/lib-host/Makefile.am @@ -0,0 +1,47 @@ +## Process this file with automake to create Makefile.in +## +## Copyright (C) 1996-2011 Red Hat, Inc. +## This file is part of elfutils. +## +## This file is free software; you can redistribute it and/or modify +## it under the terms of either +## +## * the GNU Lesser General Public License as published by the Free +## Software Foundation; either version 3 of the License, or (at +## your option) any later version +## +## or +## +## * the GNU General Public License as published by the Free +## Software Foundation; either version 2 of the License, or (at +## your option) any later version +## +## or both in parallel, as here. +## +## elfutils is distributed in the hope that it will be useful, but +## WITHOUT ANY WARRANTY; without even the implied warranty of +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +## General Public License for more details. +## +## You should have received copies of the GNU General Public License and +## the GNU Lesser General Public License along with this program. If +## not, see <http://www.gnu.org/licenses/>. +## +if CROSS + +include $(top_srcdir)/config/eu.am +AM_CFLAGS += $(fpic_CFLAGS) +AM_CPPFLAGS += -D_GNU_SOURCE -I$(srcdir)/../lib -I$(srcdir)/../libelf + +noinst_LIBRARIES = libeu.a + +$(libeu_a_OBJECTS): CC=${CC_FOR_BUILD} + +libeu_a_SOURCES = ../lib/xstrdup.c ../lib/xstrndup.c ../lib/xmalloc.c ../lib/next_prime.c \ + ../lib/crc32.c ../lib/crc32_file.c \ + ../lib/color.c ../lib/printversion.c + +if !GPROF +xmalloc_CFLAGS = -ffunction-sections +endif +endif diff --git a/libcpu/Makefile.am b/libcpu/Makefile.am index 43844ecf..5086f8be 100644 --- a/libcpu/Makefile.am +++ b/libcpu/Makefile.am @@ -27,6 +27,13 @@ ## the GNU Lesser General Public License along with this program. If ## not, see <http://www.gnu.org/licenses/>. ## + +if CROSS +i386_gendis_LINK = ${CC_FOR_BUILD} ${LDFLAGS} -o $@ + +$(i386_gendis_OBJECTS): CC=${CC_FOR_BUILD} +endif + include $(top_srcdir)/config/eu.am AM_CPPFLAGS += -I$(srcdir)/../libelf -I$(srcdir)/../libebl \ -I$(srcdir)/../libdw -I$(srcdir)/../libasm @@ -79,7 +86,11 @@ endif i386_lex_no_Werror = yes +if CROSS +libeu = ../lib-host/libeu.a +else libeu = ../lib/libeu.a +endif i386_lex_CFLAGS = -Wno-unused-label -Wno-unused-function -Wno-sign-compare \ -Wno-implicit-fallthrough -- 2.29.2.1.g08c1adf7b9 ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/1] support cross compilation 2021-05-26 7:32 ` [PATCH 1/1] support cross compilation Petr Ovtchenkov @ 2021-05-26 13:09 ` Érico Nogueira 2021-05-26 13:58 ` Petr Ovtchenkov 0 siblings, 1 reply; 6+ messages in thread From: Érico Nogueira @ 2021-05-26 13:09 UTC (permalink / raw) To: Petr Ovtchenkov, elfutils-devel Hi! Are you sure this is necessary? In Void Linux, we cross compile elfutils for arm and aarch64 without any issue, and I have built it a few times for powerpc as well. On Wed May 26, 2021 at 4:32 AM -03, Petr Ovtchenkov wrote: > Possible problem with out-of-tree build expected > --- > Makefile.am | 2 +- > configure.ac | 6 ++++++ > lib-host/Makefile.am | 47 ++++++++++++++++++++++++++++++++++++++++++++ > libcpu/Makefile.am | 11 +++++++++++ > 4 files changed, 65 insertions(+), 1 deletion(-) > create mode 100644 lib-host/Makefile.am > > diff --git a/Makefile.am b/Makefile.am > index 9c47afa9..b93839ec 100644 > --- a/Makefile.am > +++ b/Makefile.am > @@ -26,7 +26,7 @@ AM_MAKEFLAGS = --no-print-directory > > pkginclude_HEADERS = version.h > > -SUBDIRS = config lib libelf libcpu backends libebl libdwelf libdwfl > libdw \ > +SUBDIRS = config lib lib-host libelf libcpu backends libebl libdwelf > libdwfl libdw \ > libasm debuginfod src po doc tests > > EXTRA_DIST = elfutils.spec GPG-KEY NOTES CONTRIBUTING \ > diff --git a/configure.ac b/configure.ac > index b348a717..432b961a 100644 > --- a/configure.ac > +++ b/configure.ac > @@ -88,6 +88,7 @@ AS_IF([test "$use_locks" = yes], > AH_TEMPLATE([USE_LOCKS], [Defined if libraries should be thread-safe.]) > > AC_PROG_CC > +AX_PROG_CC_FOR_BUILD > AC_PROG_RANLIB > AC_PROG_YACC > AM_PROG_LEX > @@ -96,6 +97,8 @@ m4_ifdef([AM_PROG_AR], [AM_PROG_AR]) > AC_CHECK_TOOL([READELF], [readelf]) > AC_CHECK_TOOL([NM], [nm]) > > +AM_CONDITIONAL([CROSS], [test "x$cross_compiling" = xyes]) > + > # We use -std=gnu99 but have explicit checks for some language > constructs > # and GNU extensions since some compilers claim GNU99 support, but don't > # really support all language extensions. In particular we need > @@ -593,6 +596,9 @@ AC_CONFIG_FILES([doc/Makefile]) > dnl Support library. > AC_CONFIG_FILES([lib/Makefile]) > > +dnl Support library. > +AC_CONFIG_FILES([lib-host/Makefile]) > + > dnl ELF library. > AC_CONFIG_FILES([libelf/Makefile]) > > diff --git a/lib-host/Makefile.am b/lib-host/Makefile.am > new file mode 100644 > index 00000000..9316c8ed > --- /dev/null > +++ b/lib-host/Makefile.am > @@ -0,0 +1,47 @@ > +## Process this file with automake to create Makefile.in > +## > +## Copyright (C) 1996-2011 Red Hat, Inc. > +## This file is part of elfutils. > +## > +## This file is free software; you can redistribute it and/or modify > +## it under the terms of either > +## > +## * the GNU Lesser General Public License as published by the Free > +## Software Foundation; either version 3 of the License, or (at > +## your option) any later version > +## > +## or > +## > +## * the GNU General Public License as published by the Free > +## Software Foundation; either version 2 of the License, or (at > +## your option) any later version > +## > +## or both in parallel, as here. > +## > +## elfutils is distributed in the hope that it will be useful, but > +## WITHOUT ANY WARRANTY; without even the implied warranty of > +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU > +## General Public License for more details. > +## > +## You should have received copies of the GNU General Public License > and > +## the GNU Lesser General Public License along with this program. If > +## not, see <http://www.gnu.org/licenses/>. > +## > +if CROSS > + > +include $(top_srcdir)/config/eu.am > +AM_CFLAGS += $(fpic_CFLAGS) > +AM_CPPFLAGS += -D_GNU_SOURCE -I$(srcdir)/../lib -I$(srcdir)/../libelf > + > +noinst_LIBRARIES = libeu.a > + > +$(libeu_a_OBJECTS): CC=${CC_FOR_BUILD} > + > +libeu_a_SOURCES = ../lib/xstrdup.c ../lib/xstrndup.c ../lib/xmalloc.c > ../lib/next_prime.c \ > + ../lib/crc32.c ../lib/crc32_file.c \ > + ../lib/color.c ../lib/printversion.c > + > +if !GPROF > +xmalloc_CFLAGS = -ffunction-sections > +endif > +endif > diff --git a/libcpu/Makefile.am b/libcpu/Makefile.am > index 43844ecf..5086f8be 100644 > --- a/libcpu/Makefile.am > +++ b/libcpu/Makefile.am > @@ -27,6 +27,13 @@ > ## the GNU Lesser General Public License along with this program. If > ## not, see <http://www.gnu.org/licenses/>. > ## > + > +if CROSS > +i386_gendis_LINK = ${CC_FOR_BUILD} ${LDFLAGS} -o $@ > + > +$(i386_gendis_OBJECTS): CC=${CC_FOR_BUILD} > +endif Isn't this hardcoding an assumption that the build machine is x86? > + > include $(top_srcdir)/config/eu.am > AM_CPPFLAGS += -I$(srcdir)/../libelf -I$(srcdir)/../libebl \ > -I$(srcdir)/../libdw -I$(srcdir)/../libasm > @@ -79,7 +86,11 @@ endif > > i386_lex_no_Werror = yes > > +if CROSS > +libeu = ../lib-host/libeu.a > +else > libeu = ../lib/libeu.a > +endif > > i386_lex_CFLAGS = -Wno-unused-label -Wno-unused-function > -Wno-sign-compare \ > -Wno-implicit-fallthrough > -- > 2.29.2.1.g08c1adf7b9 ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/1] support cross compilation 2021-05-26 13:09 ` Érico Nogueira @ 2021-05-26 13:58 ` Petr Ovtchenkov 2021-05-26 15:41 ` Érico Nogueira 0 siblings, 1 reply; 6+ messages in thread From: Petr Ovtchenkov @ 2021-05-26 13:58 UTC (permalink / raw) To: Érico Nogueira; +Cc: elfutils-devel On Wed, 26 May 2021 10:09:31 -0300 Érico Nogueira <ericonr@disroot.org> wrote: > Hi! Are you sure this is necessary? In Void Linux, we cross compile > elfutils for arm and aarch64 without any issue, and I have built it a > few times for powerpc as well. > Hello! Yes, I am sure. I do not know about you process (check, that you really cross, not run via qemu or like). Build process _run_ i386_gendis to generate headers: <snip> if MAINTAINER_MODE noinst_HEADERS += memory-access.h i386_parse.h i386_data.h noinst_PROGRAMS = i386_gendis$(EXEEXT) $(srcdir)/%_dis.h: %_defs i386_gendis$(EXEEXT) $(AM_V_GEN)./i386_gendis$(EXEEXT) $< > $@T <================ $(AM_V_at)mv -f $@T $@ else $(srcdir)/%_dis.h: @echo '*** missing $@; configure with --enable-maintainer-mode' @false endif </snip> > > +if CROSS > > +i386_gendis_LINK = ${CC_FOR_BUILD} ${LDFLAGS} -o $@ > > + > > +$(i386_gendis_OBJECTS): CC=${CC_FOR_BUILD} > > +endif > > Isn't this hardcoding an assumption that the build machine is x86? I think no. But this question is for original author: commit 3cbdd387c752999255aea91600b5cfdefbeac7d0 Author: Ulrich Drepper <drepper@redhat.com> Date: Wed Jan 2 17:44:39 2008 +0000 propagate from branch 'com.redhat.elfutils.disasm' (head d15b4eb794e81e477f9896fe82a74cb5ecf4514c) to branch 'com.redhat.elfutils' (head eaacbf01f8cc89d043ec6eca9b5e35cb5c4cde06) ;) ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/1] support cross compilation 2021-05-26 13:58 ` Petr Ovtchenkov @ 2021-05-26 15:41 ` Érico Nogueira 2021-05-26 16:34 ` Petr Ovtchenkov 0 siblings, 1 reply; 6+ messages in thread From: Érico Nogueira @ 2021-05-26 15:41 UTC (permalink / raw) To: Petr Ovtchenkov; +Cc: elfutils-devel On Wed May 26, 2021 at 10:58 AM -03, Petr Ovtchenkov wrote: > On Wed, 26 May 2021 10:09:31 -0300 > Érico Nogueira <ericonr@disroot.org> wrote: > > > Hi! Are you sure this is necessary? In Void Linux, we cross compile > > elfutils for arm and aarch64 without any issue, and I have built it a > > few times for powerpc as well. > > > > Hello! > > Yes, I am sure. I do not know about you process (check, that you really > cross, not run via qemu or like). Build process _run_ i386_gendis to > generate headers: Yes, we really cross. > > <snip> > if MAINTAINER_MODE > noinst_HEADERS += memory-access.h i386_parse.h i386_data.h > > noinst_PROGRAMS = i386_gendis$(EXEEXT) > > $(srcdir)/%_dis.h: %_defs i386_gendis$(EXEEXT) > $(AM_V_GEN)./i386_gendis$(EXEEXT) $< > $@T <================ > $(AM_V_at)mv -f $@T $@ > > else > > $(srcdir)/%_dis.h: > @echo '*** missing $@; configure with --enable-maintainer-mode' > @false > > endif > </snip> We always use the release tarballs, which already have the %_dis.h files. This explains why we haven't hit any issues. > > > > +if CROSS > > > +i386_gendis_LINK = ${CC_FOR_BUILD} ${LDFLAGS} -o $@ > > > + > > > +$(i386_gendis_OBJECTS): CC=${CC_FOR_BUILD} > > > +endif > > > > Isn't this hardcoding an assumption that the build machine is x86? > > I think no. But this question is for original author: Indeed it isn't, I hadn't looked into it properly yet. > > commit 3cbdd387c752999255aea91600b5cfdefbeac7d0 > Author: Ulrich Drepper <drepper@redhat.com> > Date: Wed Jan 2 17:44:39 2008 +0000 > > propagate from branch 'com.redhat.elfutils.disasm' (head > d15b4eb794e81e477f9896fe82a74cb5ecf4514c) to branch > 'com.redhat.elfutils' (head > eaacbf01f8cc89d043ec6eca9b5e35cb5c4cde06) > > ;) Anyway, couldn't you (re)use the distribution tarball generation stuff for cross setups from git master? Otherwise this would add a dependency on autoconf-archive for anyone generating the configure script locally... I think a final version of this patch should document the autoconf-archive requirement, if it's merged. Cheers, Érico ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/1] support cross compilation 2021-05-26 15:41 ` Érico Nogueira @ 2021-05-26 16:34 ` Petr Ovtchenkov 2022-12-21 12:26 ` Mark Wielaard 0 siblings, 1 reply; 6+ messages in thread From: Petr Ovtchenkov @ 2021-05-26 16:34 UTC (permalink / raw) To: Érico Nogueira; +Cc: elfutils-devel On Wed, 26 May 2021 12:41:51 -0300 Érico Nogueira <ericonr@disroot.org> wrote: > > Yes, we really cross. It doesn't matter because > We always use the release tarballs, which already have the %_dis.h > files. This explains why we haven't hit any issues. > Anyway, couldn't you (re)use the distribution tarball generation stuff > for cross setups from git master? I can. But I haven't problems with building it "directly from VCS" too, as you see. Nevertheless there are opinion that code from VCS could be smoothly building without procedures behind scene. > Otherwise this would add a > dependency on autoconf-archive for anyone generating the configure > script locally... Well, anyone who generate configure locally has it. Otherwise it is a big pain ;). > I think a final version of this patch should > document the autoconf-archive requirement, if it's merged. May be addition of m4/ax_prog_cc_for_build.m4 make sense? Best regards, -- - ptr ^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 1/1] support cross compilation 2021-05-26 16:34 ` Petr Ovtchenkov @ 2022-12-21 12:26 ` Mark Wielaard 0 siblings, 0 replies; 6+ messages in thread From: Mark Wielaard @ 2022-12-21 12:26 UTC (permalink / raw) To: Petr Ovtchenkov, Érico Nogueira; +Cc: elfutils-devel Hi, It looks like I missed this. Sorry. On Wed, 2021-05-26 at 19:34 +0300, Petr Ovtchenkov wrote: > On Wed, 26 May 2021 12:41:51 -0300 > Érico Nogueira <ericonr@disroot.org> wrote: > > > > > Yes, we really cross. > > It doesn't matter because > > > We always use the release tarballs, which already have the %_dis.h > > files. This explains why we haven't hit any issues. > > > > Anyway, couldn't you (re)use the distribution tarball generation > > stuff > > for cross setups from git master? > > I can. But I haven't problems with building it "directly from VCS" > too, > as you see. Nevertheless there are opinion that code from VCS > could be smoothly building without procedures behind scene. Isn't it simpler to first do a local make dist and then build cross from that? Cheers, Mark ^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2022-12-21 12:26 UTC | newest] Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- [not found] <20210526073239.21270-1-ptr@void-ptr.info> 2021-05-26 7:32 ` [PATCH 1/1] support cross compilation Petr Ovtchenkov 2021-05-26 13:09 ` Érico Nogueira 2021-05-26 13:58 ` Petr Ovtchenkov 2021-05-26 15:41 ` Érico Nogueira 2021-05-26 16:34 ` Petr Ovtchenkov 2022-12-21 12:26 ` Mark Wielaard
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).