* [Buildroot] [PATCH] bzip2: Rearrange build order
@ 2013-06-05 12:56 Markos Chandras
2013-06-05 13:08 ` Thomas Petazzoni
2013-06-05 13:50 ` Peter Korsgaard
0 siblings, 2 replies; 12+ messages in thread
From: Markos Chandras @ 2013-06-05 12:56 UTC (permalink / raw)
To: buildroot
From: Markos Chandras <markos.chandras@imgtec.com>
Several object files are shared between the libbz2.so shared library
and the libbz2.a static one. MIPS will refuce to build a relocatable
object when creating a new shared library with the following error:
blocksort.o: relocation R_MIPS_HI16 against `__gnu_local_gp' can not be used
when making a shared object; recompile with -fPIC
This is because these files are build without -fPIC when creating the
static library and later on they are used to build the shared one.
This is easily fixed if we add the shared library build rule before
creating the static library so object files are always compiled with
-fPIC.
Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
---
package/bzip2/bzip2.mk | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/package/bzip2/bzip2.mk b/package/bzip2/bzip2.mk
index 5f8c35e..c49109a 100644
--- a/package/bzip2/bzip2.mk
+++ b/package/bzip2/bzip2.mk
@@ -18,9 +18,9 @@ endef
endif
define BZIP2_BUILD_CMDS
+ $(BZIP2_BUILD_SHARED_CMDS)
$(TARGET_MAKE_ENV)
$(MAKE) -C $(@D) libbz2.a bzip2 bzip2recover $(TARGET_CONFIGURE_OPTS)
- $(BZIP2_BUILD_SHARED_CMDS)
endef
ifeq ($(BR2_PREFER_STATIC_LIB),)
--
1.8.2.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 12:56 [Buildroot] [PATCH] bzip2: Rearrange build order Markos Chandras
@ 2013-06-05 13:08 ` Thomas Petazzoni
2013-06-05 13:50 ` Peter Korsgaard
1 sibling, 0 replies; 12+ messages in thread
From: Thomas Petazzoni @ 2013-06-05 13:08 UTC (permalink / raw)
To: buildroot
Dear Markos Chandras,
On Wed, 5 Jun 2013 13:56:16 +0100, Markos Chandras wrote:
> From: Markos Chandras <markos.chandras@imgtec.com>
>
> Several object files are shared between the libbz2.so shared library
> and the libbz2.a static one. MIPS will refuce to build a relocatable
> object when creating a new shared library with the following error:
>
> blocksort.o: relocation R_MIPS_HI16 against `__gnu_local_gp' can not be used
> when making a shared object; recompile with -fPIC
>
> This is because these files are build without -fPIC when creating the
> static library and later on they are used to build the shared one.
>
> This is easily fixed if we add the shared library build rule before
> creating the static library so object files are always compiled with
> -fPIC.
>
> Signed-off-by: Markos Chandras <markos.chandras@imgtec.com>
This seems to make sense to me, so:
Reviewed-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
--
Thomas Petazzoni, Free Electrons
Kernel, drivers, real-time and embedded Linux
development, consulting, training and support.
http://free-electrons.com
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 12:56 [Buildroot] [PATCH] bzip2: Rearrange build order Markos Chandras
2013-06-05 13:08 ` Thomas Petazzoni
@ 2013-06-05 13:50 ` Peter Korsgaard
2013-06-05 14:02 ` Markos Chandras
2013-06-05 14:04 ` Thomas Petazzoni
1 sibling, 2 replies; 12+ messages in thread
From: Peter Korsgaard @ 2013-06-05 13:50 UTC (permalink / raw)
To: buildroot
>>>>> "Markos" == Markos Chandras <markos.chandras@gmail.com> writes:
Markos> From: Markos Chandras <markos.chandras@imgtec.com>
Markos> Several object files are shared between the libbz2.so shared library
Markos> and the libbz2.a static one. MIPS will refuce to build a relocatable
Markos> object when creating a new shared library with the following error:
Markos> blocksort.o: relocation R_MIPS_HI16 against `__gnu_local_gp' can not be used
Markos> when making a shared object; recompile with -fPIC
Markos> This is because these files are build without -fPIC when creating the
Markos> static library and later on they are used to build the shared one.
Markos> This is easily fixed if we add the shared library build rule before
Markos> creating the static library so object files are always compiled with
Markos> -fPIC.
This works, but is afaik less efficient for the static lib case.
The real fix is imho to build the object files twice, like how libtool
does it.
If you look at the Debian package, they work around it by adding a
seperate .c -> .sho build rule, which adds -fPIC, and then link the .so
file with the .sho files instead.
--
Bye, Peter Korsgaard
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 13:50 ` Peter Korsgaard
@ 2013-06-05 14:02 ` Markos Chandras
2013-06-05 14:04 ` Thomas Petazzoni
1 sibling, 0 replies; 12+ messages in thread
From: Markos Chandras @ 2013-06-05 14:02 UTC (permalink / raw)
To: buildroot
On 5 June 2013 14:50, Peter Korsgaard <jacmet@uclibc.org> wrote:
>>>>>> "Markos" == Markos Chandras <markos.chandras@gmail.com> writes:
>
> Markos> From: Markos Chandras <markos.chandras@imgtec.com>
> Markos> Several object files are shared between the libbz2.so shared library
> Markos> and the libbz2.a static one. MIPS will refuce to build a relocatable
> Markos> object when creating a new shared library with the following error:
>
> Markos> blocksort.o: relocation R_MIPS_HI16 against `__gnu_local_gp' can not be used
> Markos> when making a shared object; recompile with -fPIC
>
> Markos> This is because these files are build without -fPIC when creating the
> Markos> static library and later on they are used to build the shared one.
>
> Markos> This is easily fixed if we add the shared library build rule before
> Markos> creating the static library so object files are always compiled with
> Markos> -fPIC.
>
> This works, but is afaik less efficient for the static lib case.
>
> The real fix is imho to build the object files twice, like how libtool
> does it.
>
> If you look at the Debian package, they work around it by adding a
> seperate .c -> .sho build rule, which adds -fPIC, and then link the .so
> file with the .sho files instead.
>
> --
> Bye, Peter Korsgaard
Hi Peter,
Ok I will send a new patch based on the debian patch.
--
Regards,
Markos Chandras
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 13:50 ` Peter Korsgaard
2013-06-05 14:02 ` Markos Chandras
@ 2013-06-05 14:04 ` Thomas Petazzoni
2013-06-05 14:08 ` Markos Chandras
2013-06-05 14:15 ` Peter Korsgaard
1 sibling, 2 replies; 12+ messages in thread
From: Thomas Petazzoni @ 2013-06-05 14:04 UTC (permalink / raw)
To: buildroot
Dear Peter Korsgaard,
On Wed, 05 Jun 2013 15:50:21 +0200, Peter Korsgaard wrote:
> This works, but is afaik less efficient for the static lib case.
>
> The real fix is imho to build the object files twice, like how libtool
> does it.
>
> If you look at the Debian package, they work around it by adding a
> seperate .c -> .sho build rule, which adds -fPIC, and then link the .so
> file with the .sho files instead.
Are you sure there are not already many packages that build things only
once with -fPIC and use that for both the static and the shared library?
What you're proposing here is quite the opposite to what you merged
(from me) in a33baa1ef9dadbec8e45d411c30d636fa6b8872a (icu: don't build
object files twice).
Thomas
--
Thomas Petazzoni, Free Electrons
Kernel, drivers, real-time and embedded Linux
development, consulting, training and support.
http://free-electrons.com
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 14:04 ` Thomas Petazzoni
@ 2013-06-05 14:08 ` Markos Chandras
2013-06-05 14:15 ` Peter Korsgaard
1 sibling, 0 replies; 12+ messages in thread
From: Markos Chandras @ 2013-06-05 14:08 UTC (permalink / raw)
To: buildroot
On 5 June 2013 15:04, Thomas Petazzoni
<thomas.petazzoni@free-electrons.com> wrote:
> Dear Peter Korsgaard,
>
> On Wed, 05 Jun 2013 15:50:21 +0200, Peter Korsgaard wrote:
>
>> This works, but is afaik less efficient for the static lib case.
>>
>> The real fix is imho to build the object files twice, like how libtool
>> does it.
>>
>> If you look at the Debian package, they work around it by adding a
>> seperate .c -> .sho build rule, which adds -fPIC, and then link the .so
>> file with the .sho files instead.
>
> Are you sure there are not already many packages that build things only
> once with -fPIC and use that for both the static and the shared library?
>
> What you're proposing here is quite the opposite to what you merged
> (from me) in a33baa1ef9dadbec8e45d411c30d636fa6b8872a (icu: don't build
> object files twice).
>
> Thomas
> --
> Thomas Petazzoni, Free Electrons
> Kernel, drivers, real-time and embedded Linux
> development, consulting, training and support.
> http://free-electrons.com
My understanding is that there is a small performance penalty in
static libraries because of the GOT presence introduced by the shared
object. Apart from that, nothing else should change in the static
library.
Gentoo does the same thing for bzip2. It builds the shared library first.
--
Regards,
Markos Chandras
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 14:04 ` Thomas Petazzoni
2013-06-05 14:08 ` Markos Chandras
@ 2013-06-05 14:15 ` Peter Korsgaard
2013-06-05 14:25 ` Markos Chandras
2013-06-05 15:22 ` Thomas Petazzoni
1 sibling, 2 replies; 12+ messages in thread
From: Peter Korsgaard @ 2013-06-05 14:15 UTC (permalink / raw)
To: buildroot
>>>>> "Thomas" == Thomas Petazzoni <thomas.petazzoni@free-electrons.com> writes:
>> This works, but is afaik less efficient for the static lib case.
>>
>> The real fix is imho to build the object files twice, like how libtool
>> does it.
>>
>> If you look at the Debian package, they work around it by adding a
>> seperate .c -> .sho build rule, which adds -fPIC, and then link the .so
>> file with the .sho files instead.
Thomas> Are you sure there are not already many packages that build
Thomas> things only once with -fPIC and use that for both the static
Thomas> and the shared library?
Thomas> What you're proposing here is quite the opposite to what you
Thomas> merged (from me) in a33baa1ef9dadbec8e45d411c30d636fa6b8872a
Thomas> (icu: don't build object files twice).
I've never claimed I was consistent ;) What I'm saying is simply that
the "correct" way to do this, is to build the object files twice similar
to how E.G. libtool does it.
For something as small (and possibly performance sensitive) as bzip2 I
think it is worthwhile doing it.
--
Bye, Peter Korsgaard
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 14:15 ` Peter Korsgaard
@ 2013-06-05 14:25 ` Markos Chandras
2013-06-05 14:48 ` Peter Korsgaard
2013-06-05 15:22 ` Thomas Petazzoni
1 sibling, 1 reply; 12+ messages in thread
From: Markos Chandras @ 2013-06-05 14:25 UTC (permalink / raw)
To: buildroot
On 5 June 2013 15:15, Peter Korsgaard <jacmet@uclibc.org> wrote:
>>>>>> "Thomas" == Thomas Petazzoni <thomas.petazzoni@free-electrons.com> writes:
>
> >> This works, but is afaik less efficient for the static lib case.
> >>
> >> The real fix is imho to build the object files twice, like how libtool
> >> does it.
> >>
> >> If you look at the Debian package, they work around it by adding a
> >> seperate .c -> .sho build rule, which adds -fPIC, and then link the .so
> >> file with the .sho files instead.
>
> Thomas> Are you sure there are not already many packages that build
> Thomas> things only once with -fPIC and use that for both the static
> Thomas> and the shared library?
>
> Thomas> What you're proposing here is quite the opposite to what you
> Thomas> merged (from me) in a33baa1ef9dadbec8e45d411c30d636fa6b8872a
> Thomas> (icu: don't build object files twice).
>
> I've never claimed I was consistent ;) What I'm saying is simply that
> the "correct" way to do this, is to build the object files twice similar
> to how E.G. libtool does it.
>
> For something as small (and possibly performance sensitive) as bzip2 I
> think it is worthwhile doing it.
>
> --
> Bye, Peter Korsgaard
Hi Peter,
The problem here is that Debian uses a single Makefile to build both
the static and the shared library but in buildroot we use
the Makefile for the static one and Makefile-libbz2_so for the shared
one. In this case, doing what Debian did is not possible
but what we can do is to remove the *.o files within the
Makefile-libbz2_so before we try to build the shared library.
--
Regards,
Markos Chandras
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 14:25 ` Markos Chandras
@ 2013-06-05 14:48 ` Peter Korsgaard
2013-06-05 15:01 ` Markos Chandras
0 siblings, 1 reply; 12+ messages in thread
From: Peter Korsgaard @ 2013-06-05 14:48 UTC (permalink / raw)
To: buildroot
>>>>> "Markos" == Markos Chandras <markos.chandras@gmail.com> writes:
Hi,
Markos> The problem here is that Debian uses a single Makefile to build both
Markos> the static and the shared library but in buildroot we use
Markos> the Makefile for the static one and Makefile-libbz2_so for the shared
Markos> one. In this case, doing what Debian did is not possible
Markos> but what we can do is to remove the *.o files within the
Markos> Makefile-libbz2_so before we try to build the shared library.
Or we could just do something like:
define BZIP2_BUILD_CMDS
$(TARGET_MAKE_ENV)
$(MAKE) -C $(@D) libbz2.a bzip2 bzip2recover \
$(if $(BR2_PREFER_STATIC_LIB),,libbz2.so) \
$(TARGET_CONFIGURE_OPTS)
endef
E.G. only build the libbz2.so taget (which pulls in *.sho) if building
shared.
Or alternatively, keep Makefile-libbz2_so, but change it to use .sho
files instead of .o
--
Bye, Peter Korsgaard
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 14:48 ` Peter Korsgaard
@ 2013-06-05 15:01 ` Markos Chandras
0 siblings, 0 replies; 12+ messages in thread
From: Markos Chandras @ 2013-06-05 15:01 UTC (permalink / raw)
To: buildroot
On 5 June 2013 15:48, Peter Korsgaard <jacmet@uclibc.org> wrote:
>>>>>> "Markos" == Markos Chandras <markos.chandras@gmail.com> writes:
>
> Hi,
>
> Markos> The problem here is that Debian uses a single Makefile to build both
> Markos> the static and the shared library but in buildroot we use
> Markos> the Makefile for the static one and Makefile-libbz2_so for the shared
> Markos> one. In this case, doing what Debian did is not possible
> Markos> but what we can do is to remove the *.o files within the
> Markos> Makefile-libbz2_so before we try to build the shared library.
>
> Or we could just do something like:
>
> define BZIP2_BUILD_CMDS
> $(TARGET_MAKE_ENV)
> $(MAKE) -C $(@D) libbz2.a bzip2 bzip2recover \
> $(if $(BR2_PREFER_STATIC_LIB),,libbz2.so) \
> $(TARGET_CONFIGURE_OPTS)
> endef
>
> E.G. only build the libbz2.so taget (which pulls in *.sho) if building
> shared.
>
> Or alternatively, keep Makefile-libbz2_so, but change it to use .sho
> files instead of .o
>
> --
> Bye, Peter Korsgaard
Hi Peter,
Oh I've seen this e-mail a bit late. I just sent a new patch based on
the second proposal.
--
Regards,
Markos Chandras
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 14:15 ` Peter Korsgaard
2013-06-05 14:25 ` Markos Chandras
@ 2013-06-05 15:22 ` Thomas Petazzoni
2013-06-05 21:56 ` Peter Korsgaard
1 sibling, 1 reply; 12+ messages in thread
From: Thomas Petazzoni @ 2013-06-05 15:22 UTC (permalink / raw)
To: buildroot
Dear Peter Korsgaard,
On Wed, 05 Jun 2013 16:15:34 +0200, Peter Korsgaard wrote:
> Thomas> Are you sure there are not already many packages that build
> Thomas> things only once with -fPIC and use that for both the static
> Thomas> and the shared library?
>
> Thomas> What you're proposing here is quite the opposite to what you
> Thomas> merged (from me) in a33baa1ef9dadbec8e45d411c30d636fa6b8872a
> Thomas> (icu: don't build object files twice).
>
> I've never claimed I was consistent ;) What I'm saying is simply that
> the "correct" way to do this, is to build the object files twice similar
> to how E.G. libtool does it.
>
> For something as small (and possibly performance sensitive) as bzip2 I
> think it is worthwhile doing it.
I'm not sure I agree with your idea of making a different decision
depending on the package. Either we decide that all static libraries
should not be built with -fPIC, and we apply this rule on all packages,
or we decide that all static libraries are built with -fPIC, so that we
actually build object files only once.
In fact, I hadn't realized that libtool was building each and every .c
file twice, once without -fPIC for the static library, and once with
-fPIC for the shared library.
I believe we have three choices:
(1) When !BR2_PREFER_STATIC_LIB, pass --enable-shared --disable-static
instead of the current --enable-shared --enable-static. When I did
009d8fceab4db7815502e4b0565fe0ef531d512c, I wasn't aware that
having --enable-static was causing a double build of source files.
Had I realized that, I would have probably suggested a different
solution. If someone builds with !BR2_PREFER_STATIC_LIB, it's
pretty unlikely that the static version of the libraries will be
needed. There might be a few exceptions, but they can be handled
by the user by adding --enable-static to the CONF_OPT of the
specific packages he is interested in.
(2) When !BR2_PREFER_STATIC_LIB, find a way of telling libtool not to
build object files twice, and generate static libraries using the
-fPIC capable object files. It's slightly less efficient, but if
you're building !BR2_PREFER_STATIC_LIB, you're using shared
libraries for most of your applications anyway, so having a small
hit with the few static libraries isn't going to be really
noticeable.
(3) When !BR2_PREFER_STATIC_LIB, keep --enable-shared and
--enable-static as we have today, and make sure that object files
are always built twice, once without -fPIC, and once with. I
believe this is making the build time longer, for situations
(usage of static libraries when !BR2_PREFER_STATIC_LIB) that are
fairly uncommon.
In any case, the solution of "some packages have their static library
objects built without -fPIC, some other packages have their static
library objects built with -fPIC" is not really nice. Where's the
boundary between the first and second category of packages?
Best regards,
Thomas
--
Thomas Petazzoni, Free Electrons
Kernel, drivers, real-time and embedded Linux
development, consulting, training and support.
http://free-electrons.com
^ permalink raw reply [flat|nested] 12+ messages in thread
* [Buildroot] [PATCH] bzip2: Rearrange build order
2013-06-05 15:22 ` Thomas Petazzoni
@ 2013-06-05 21:56 ` Peter Korsgaard
0 siblings, 0 replies; 12+ messages in thread
From: Peter Korsgaard @ 2013-06-05 21:56 UTC (permalink / raw)
To: buildroot
>>>>> "Thomas" == Thomas Petazzoni <thomas.petazzoni@free-electrons.com> writes:
Hi,
Thomas> In fact, I hadn't realized that libtool was building each and
Thomas> every .c file twice, once without -fPIC for the static library,
Thomas> and once with -fPIC for the shared library.
Thomas> I believe we have three choices:
Yes, like we discussed on IRC I think we need to end up with 3 options:
- Build only shared libraries (default)
- Build only static libraries (BR2_PREFER_STATIC_LIB)
- Build both, and prefer shared libraries (what we have today)
--
Bye, Peter Korsgaard
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2013-06-05 21:56 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-06-05 12:56 [Buildroot] [PATCH] bzip2: Rearrange build order Markos Chandras
2013-06-05 13:08 ` Thomas Petazzoni
2013-06-05 13:50 ` Peter Korsgaard
2013-06-05 14:02 ` Markos Chandras
2013-06-05 14:04 ` Thomas Petazzoni
2013-06-05 14:08 ` Markos Chandras
2013-06-05 14:15 ` Peter Korsgaard
2013-06-05 14:25 ` Markos Chandras
2013-06-05 14:48 ` Peter Korsgaard
2013-06-05 15:01 ` Markos Chandras
2013-06-05 15:22 ` Thomas Petazzoni
2013-06-05 21:56 ` Peter Korsgaard
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox