<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN">
<HTML>
 <HEAD>
   <TITLE> [Mageia-dev] need some help to build a linuxsampler.rpm
   </TITLE>
   <LINK REL="Index" HREF="index.html" >
   <LINK REL="made" HREF="mailto:mageia-dev%40mageia.org?Subject=Re%3A%20%5BMageia-dev%5D%20need%20some%20help%20to%20build%20a%20linuxsampler.rpm&In-Reply-To=%3C505F10E5.5050909%40mageia.org%3E">
   <META NAME="robots" CONTENT="index,nofollow">
   <META http-equiv="Content-Type" content="text/html; charset=us-ascii">
   <LINK REL="Previous"  HREF="018866.html">
   <LINK REL="Next"  HREF="018881.html">
 </HEAD>
 <BODY BGCOLOR="#ffffff">
   <H1>[Mageia-dev] need some help to build a linuxsampler.rpm</H1>
    <B>Thomas Backlund</B> 
    <A HREF="mailto:mageia-dev%40mageia.org?Subject=Re%3A%20%5BMageia-dev%5D%20need%20some%20help%20to%20build%20a%20linuxsampler.rpm&In-Reply-To=%3C505F10E5.5050909%40mageia.org%3E"
       TITLE="[Mageia-dev] need some help to build a linuxsampler.rpm">tmb at mageia.org
       </A><BR>
    <I>Sun Sep 23 15:38:45 CEST 2012</I>
    <P><UL>
        <LI>Previous message: <A HREF="018866.html">[Mageia-dev] need some help to build a linuxsampler.rpm
</A></li>
        <LI>Next message: <A HREF="018881.html">[Mageia-dev] need some help to build a linuxsampler.rpm
</A></li>
         <LI> <B>Messages sorted by:</B> 
              <a href="date.html#18868">[ date ]</a>
              <a href="thread.html#18868">[ thread ]</a>
              <a href="subject.html#18868">[ subject ]</a>
              <a href="author.html#18868">[ author ]</a>
         </LI>
       </UL>
    <HR>  
<!--beginarticle-->
<PRE>23.09.2012 16:19, PhilippeDidier skrev:
&gt;<i> Olivier Blin a &#233;crit :
</I>&gt;&gt;<i> PhilippeDidier &lt;<A HREF="https://www.mageia.org/mailman/listinfo/mageia-dev">philippedidier at laposte.net</A>&gt; writes:
</I>&gt;&gt;<i>
</I>&gt;&gt;&gt;<i> indeed the configured Makefile contains
</I>&gt;&gt;&gt;<i> LDFLAGS  option --as-needed htat worked for Mandriva !!!
</I>&gt;&gt;&gt;<i>
</I>&gt;&gt;&gt;<i> I need now to write a patch for the makefiles...
</I>&gt;&gt;&gt;<i> to fix it in a better way than overriding LDFLAGS
</I>&gt;&gt;&gt;<i>
</I>&gt;&gt;&gt;<i> May we now suppress the --as-needed option for LDFLAGS in every makefile ?
</I>&gt;&gt;<i>
</I>&gt;&gt;<i> No, you should not remove this option, this is the intended behavior.
</I>&gt;&gt;<i> It just exposed a missing -l flag in the software you are packaging.
</I>&gt;&gt;<i>
</I>&gt;&gt;<i> The proper fix, as Thomas said, is to patch the Makefile to add the
</I>&gt;&gt;<i> -lpthread flag where appropriate.
</I>&gt;&gt;<i>
</I>&gt;<i> Hello !
</I>&gt;<i> Some news :
</I>&gt;<i> Indeed it was more difficult than I thought :
</I>&gt;<i> There were 21 different Makefile.in in 21 directories to modify :
</I>&gt;<i> I wrote a patch that replaces
</I>&gt;<i> -LDFLAGS = @LDFLAGS@
</I>&gt;<i> by
</I>&gt;<i> +LDFLAGS = @LDFLAGS@ -lpthread
</I>&gt;<i> in each of them...
</I>&gt;<i>
</I>
And now you are overlinking :)

You only need to patch the Makefile(s) that is responsible for
building the code that relies on pthread


&gt;<i> Now each Makefile contains :
</I>&gt;<i> LDFLAGS =  -Wl,--as-needed -Wl,--no-undefined -Wl,-z,relro -Wl,-O1
</I>&gt;<i> -Wl,--build-id -Wl,--enable-new-dtags -lpthread
</I>&gt;<i>
</I>&gt;<i>
</I>&gt;<i> And I discover that my first workaround was indeed bad :
</I>&gt;<i> I used
</I>&gt;<i> %build
</I>&gt;<i> %configure2_5x
</I>&gt;<i> %make LDFLAGS=&quot;-lpthread&quot;
</I>&gt;<i>
</I>&gt;<i> instead of
</I>&gt;<i> %build
</I>&gt;<i> %configure2_5x
</I>&gt;<i> %make
</I>&gt;<i>
</I>&gt;<i> this allowed to package and I felt happy ;) ... but wrongly happy :(
</I>&gt;<i>
</I>&gt;<i>
</I>&gt;<i> Now that I use a correct LDFLAGS I got new errors about other undefined
</I>&gt;<i> references (thanks to --as-needed option)
</I>&gt;<i> ... and I feel sad :(
</I>&gt;<i>
</I>&gt;<i> There came now undefined references to 'dlopen' 'dlerror' 'dlclose'
</I>&gt;<i>
</I>&gt;<i> I had to add -ldl to each Makefile.in
</I>&gt;<i>
</I>
And overlinking again :)

&gt;<i> And now it's OK
</I>&gt;<i>
</I>&gt;<i> Thanks to all of you ! I'm now less ignorant than I was ...
</I>&gt;<i>
</I>&gt;<i> But packaging for Mageia will need more skill and more time than for
</I>&gt;<i> Mandriva ... and more patches ! (hope it's worth of it)
</I>&gt;<i>
</I>
Of course it is worth it...
By finding and fixing issues like this (and also send the fix upstream)
the quality of the code is improving...

&gt;<i> I will provide my spec and patch files to anyone (perhaps through
</I>&gt;<i> bugzilla with a package request)
</I>

--

Thomas


</PRE>

























<!--endarticle-->
    <HR>
    <P><UL>
        <!--threads-->
	<LI>Previous message: <A HREF="018866.html">[Mageia-dev] need some help to build a linuxsampler.rpm
</A></li>
	<LI>Next message: <A HREF="018881.html">[Mageia-dev] need some help to build a linuxsampler.rpm
</A></li>
         <LI> <B>Messages sorted by:</B> 
              <a href="date.html#18868">[ date ]</a>
              <a href="thread.html#18868">[ thread ]</a>
              <a href="subject.html#18868">[ subject ]</a>
              <a href="author.html#18868">[ author ]</a>
         </LI>
       </UL>

<hr>
<a href="https://www.mageia.org/mailman/listinfo/mageia-dev">More information about the Mageia-dev
mailing list</a><br>
</body></html>