public inbox for gentoo-hardened@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-hardened] removing .text relocations from mplayer and xine-lib
@ 2005-05-29 15:27 René Rhéaume
  2005-05-29 17:24 ` Ned Ludd
  0 siblings, 1 reply; 6+ messages in thread
From: René Rhéaume @ 2005-05-29 15:27 UTC (permalink / raw
  To: gentoo-hardened

Where is the patch that removes .text relocations from mplayer and
xine-lib? Solar said on IRC that was one lying around somewhere. I
searched on Gentoo Bugzilla and on the Web with Google and I did not
find it.

Why? This is what I get from /usr/bin/xine (part of xine-ui)
This is xine (X11 gui) - a free video player v0.99.3.
(c) 2000-2004 The xine Team.
Can't modify /usr/lib/xine/plugins/1.0.0/post/xineplug_post_planar.so's 
text section. Use GCC option -fPIC for shared objects, please.

Hmm, there is already a PIC patch applied to xine-lib.

-- 
gentoo-hardened@gentoo.org mailing list


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

* Re: [gentoo-hardened] removing .text relocations from mplayer and xine-lib
  2005-05-29 15:27 [gentoo-hardened] removing .text relocations from mplayer and xine-lib René Rhéaume
@ 2005-05-29 17:24 ` Ned Ludd
  2005-05-30 16:49   ` René Rhéaume
  0 siblings, 1 reply; 6+ messages in thread
From: Ned Ludd @ 2005-05-29 17:24 UTC (permalink / raw
  To: gentoo-hardened

[-- Attachment #1: Type: text/plain, Size: 966 bytes --]

On Sun, 2005-05-29 at 11:27 -0400, René Rhéaume wrote:
> Where is the patch that removes .text relocations from mplayer and
> xine-lib? Solar said on IRC that was one lying around somewhere. I
> searched on Gentoo Bugzilla and on the Web with Google and I did not
> find it.

I could not find where I put it and your the second person to
ask/request it today so I did another. 

See attached untested patch for mplayer..

It may be easier to just have them do 
#if (defined (__PIC__) && !defined(PIC))
# define PIC __PIC__
#endif

> Why? This is what I get from /usr/bin/xine (part of xine-ui)
> This is xine (X11 gui) - a free video player v0.99.3.
> (c) 2000-2004 The xine Team.
> Can't modify /usr/lib/xine/plugins/1.0.0/post/xineplug_post_planar.so's 
> text section. Use GCC option -fPIC for shared objects, please.
> 
> Hmm, there is already a PIC patch applied to xine-lib.

It's probably not complete like mplayer was not. 


-- 
Ned Ludd <solar@gentoo.org>

[-- Attachment #2: MPlayer-1.0pre7-more-pic-updates.patch --]
[-- Type: text/x-patch, Size: 7885 bytes --]

diff -Nrup MPlayer-1.0pre7.unpacked/libavcodec/common.h MPlayer-1.0pre7/libavcodec/common.h
--- MPlayer-1.0pre7.unpacked/libavcodec/common.h	2005-04-16 16:41:13.000000000 -0400
+++ MPlayer-1.0pre7/libavcodec/common.h	2005-05-29 13:05:40.000000000 -0400
@@ -219,13 +219,13 @@ static inline float floorf(float f) { 
 // Use rip-relative addressing if compiling PIC code on x86-64.
 #    if defined(__MINGW32__) || defined(__CYGWIN__) || \
         defined(__OS2__) || (defined (__OpenBSD__) && !defined(__ELF__))
-#        if defined(ARCH_X86_64) && defined(PIC)
+#        if defined(ARCH_X86_64) && defined(__PIC__)
 #            define MANGLE(a) "_" #a"(%%rip)"
 #        else
 #            define MANGLE(a) "_" #a
 #        endif
 #    else
-#        if defined(ARCH_X86_64) && defined(PIC)
+#        if defined(ARCH_X86_64) && defined(__PIC__)
 #            define MANGLE(a) #a"(%%rip)"
 #        else
 #            define MANGLE(a) #a
diff -Nrup MPlayer-1.0pre7.unpacked/libavcodec/i386/dsputil_mmx.c MPlayer-1.0pre7/libavcodec/i386/dsputil_mmx.c
--- MPlayer-1.0pre7.unpacked/libavcodec/i386/dsputil_mmx.c	2005-04-16 16:41:13.000000000 -0400
+++ MPlayer-1.0pre7/libavcodec/i386/dsputil_mmx.c	2005-05-29 13:01:39.000000000 -0400
@@ -59,7 +59,7 @@ static const uint64_t ff_pb_FC attribute
     "pcmpeqd %%" #regd ", %%" #regd " \n\t"\
     "paddb %%" #regd ", %%" #regd " \n\t" ::)
 
-#ifndef PIC
+#ifndef __PIC__
 #define MOVQ_BONE(regd)  __asm __volatile ("movq %0, %%" #regd " \n\t" ::"m"(mm_bone))
 #define MOVQ_WTWO(regd)  __asm __volatile ("movq %0, %%" #regd " \n\t" ::"m"(mm_wtwo))
 #else
diff -Nrup MPlayer-1.0pre7.unpacked/libavcodec/i386/dsputil_mmx_avg.h MPlayer-1.0pre7/libavcodec/i386/dsputil_mmx_avg.h
--- MPlayer-1.0pre7.unpacked/libavcodec/i386/dsputil_mmx_avg.h	2005-04-16 16:41:13.000000000 -0400
+++ MPlayer-1.0pre7/libavcodec/i386/dsputil_mmx_avg.h	2005-05-29 13:15:32.000000000 -0400
@@ -90,7 +90,7 @@ static void DEF(put_pixels4_l2)(uint8_t 
 	"add	$16, %2			\n\t"
 	"subl	$4, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -137,7 +137,7 @@ static void DEF(put_pixels8_l2)(uint8_t 
 	"add	$32, %2			\n\t"
 	"subl	$4, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -207,7 +207,7 @@ static void DEF(put_no_rnd_pixels8_l2)(u
 	"add	$32, %2			\n\t"
 	"subl	$4, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -262,7 +262,7 @@ static void DEF(avg_pixels4_l2)(uint8_t 
 	"add	$16, %2			\n\t"
 	"subl	$4, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -314,7 +314,7 @@ static void DEF(avg_pixels8_l2)(uint8_t 
 	"add	$32, %2			\n\t"
 	"subl	$4, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -402,7 +402,7 @@ static void DEF(put_pixels16_l2)(uint8_t
 	"add	$32, %2			\n\t"
 	"subl	$2, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -456,7 +456,7 @@ static void DEF(avg_pixels16_l2)(uint8_t
 	"add	$32, %2			\n\t"
 	"subl	$2, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -529,7 +529,7 @@ static void DEF(put_no_rnd_pixels16_l2)(
 	"add	$32, %2			\n\t"
 	"subl	$2, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
diff -Nrup MPlayer-1.0pre7.unpacked/libavcodec/i386/dsputil_mmx_rnd.h MPlayer-1.0pre7/libavcodec/i386/dsputil_mmx_rnd.h
--- MPlayer-1.0pre7.unpacked/libavcodec/i386/dsputil_mmx_rnd.h	2005-04-16 16:41:13.000000000 -0400
+++ MPlayer-1.0pre7/libavcodec/i386/dsputil_mmx_rnd.h	2005-05-29 13:01:00.000000000 -0400
@@ -96,7 +96,7 @@ static void DEF(put, pixels8_l2)(uint8_t
 	"add	%5, %3			\n\t"
 	"subl	$4, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
         :"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
         :"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
@@ -191,7 +191,7 @@ static void DEF(put, pixels16_l2)(uint8_
 	"add	$32, %2			\n\t"
 	"subl	$2, %0			\n\t"
 	"jnz	1b			\n\t"
-#ifdef PIC //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
+#ifdef __PIC__ //Note "+bm" and "+mb" are buggy too (with gcc 3.2.2 at least) and cant be used
 	:"+m"(h), "+a"(src1), "+c"(src2), "+d"(dst)
 #else
 	:"+b"(h), "+a"(src1), "+c"(src2), "+d"(dst)
diff -Nrup MPlayer-1.0pre7.unpacked/libavcodec/libpostproc/mangle.h MPlayer-1.0pre7/libavcodec/libpostproc/mangle.h
--- MPlayer-1.0pre7.unpacked/libavcodec/libpostproc/mangle.h	2005-04-16 16:41:13.000000000 -0400
+++ MPlayer-1.0pre7/libavcodec/libpostproc/mangle.h	2005-05-29 13:05:40.000000000 -0400
@@ -11,13 +11,13 @@
 /* Use rip-relative addressing if compiling PIC code on x86-64. */
 #if defined(__CYGWIN__) || defined(__MINGW32__) || defined(__OS2__) || \
    (defined(__OpenBSD__) && !defined(__ELF__))
-#if defined(ARCH_X86_64) && defined(PIC)
+#if defined(ARCH_X86_64) && defined(__PIC__)
 #define MANGLE(a) "_" #a"(%%rip)"
 #else
 #define MANGLE(a) "_" #a
 #endif
 #else
-#if defined(ARCH_X86_64) && defined(PIC)
+#if defined(ARCH_X86_64) && defined(__PIC__)
 #define MANGLE(a) #a"(%%rip)"
 #else
 #define MANGLE(a) #a
diff -Nrup MPlayer-1.0pre7.unpacked/libavcodec/msmpeg4.c MPlayer-1.0pre7/libavcodec/msmpeg4.c
--- MPlayer-1.0pre7.unpacked/libavcodec/msmpeg4.c	2005-04-16 16:41:13.000000000 -0400
+++ MPlayer-1.0pre7/libavcodec/msmpeg4.c	2005-05-29 12:55:56.000000000 -0400
@@ -723,7 +723,7 @@ static inline int msmpeg4_pred_dc(MpegEn
        necessitate to modify mpegvideo.c. The problem comes from the
        fact they decided to store the quantized DC (which would lead
        to problems if Q could vary !) */
-#if (defined(ARCH_X86) || defined(ARCH_X86_64)) && !defined PIC
+#if (defined(ARCH_X86) || defined(ARCH_X86_64)) && !defined __PIC__
     asm volatile(
         "movl %3, %%eax		\n\t"
 	"shrl $1, %%eax		\n\t"

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

* Re: [gentoo-hardened] removing .text relocations from mplayer and xine-lib
  2005-05-29 17:24 ` Ned Ludd
@ 2005-05-30 16:49   ` René Rhéaume
  2005-06-02 12:42     ` Peter S. Mazinger
  0 siblings, 1 reply; 6+ messages in thread
From: René Rhéaume @ 2005-05-30 16:49 UTC (permalink / raw
  To: gentoo-hardened

I found out symlinking libtool-nofpic to libtool (which produces PIC
binaries) eliminates most of the relocations. I am able to build on
Gentoo either outside Portage or using my custom ebuild.

Just add "use x86 && has_pic && ln -sf libtool ${S}/libtool-nofpic"
right after econf. You can also comment RESTRICT="nostrip" in the
ebuild and add "strict" to your FEATURES to get the list of the
remaining TEXTREL binaries, which are on my system:

$(get-libdir)/xine/plugins/${PV}/post/xineplug_post_{planar,tvtime}.so
$(get-libdir)/xine/plugins/${PV}/xineplug_decode_{ff,w32dll,qt}.so

Feedback from other architectures is appreciated.

Also, it seems that "use x86 && has_pic && append-flags -UHAVE_MMX" is
not needed. I can build fine either with or without.

*This paragraph is more a note to myself, but can be interesting for
those with older gcc versions*
I also tried this symlinking trick on my half-Mandr* install and got
two build errors (make -k). It is probably a bug from that old
gcc-3.2-1mdk I get as I already have to patch xine-lib to disable SIMD
code generation in FAAD code even when I generate non-PIC code.
Faulty files are:
${S}/src/libffmpeg/libavcodec/i386/mpegvideo_mmx_template.c
${S}/src/libffmpeg/libavcodec/libpostproc/postprocess_template.c
Error message: can't find a register in class `GENERAL_REGS' while
reloading `asm'

OS Specs:
* Gentoo 2004.3, x86, hardened, µclibc 0.9.27, running kernel
2.4.30-hardened-r1, with Hardened GCC 3.3.5-r1
* half-Mandr* 9.0, i586, glibc 2.2.5, running kernel 2.4.28-19rrsecure
(lck+grsec+i2c+security fixes, mainly), with GCC 3.2-1mdk

-- 
gentoo-hardened@gentoo.org mailing list


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

* Re: [gentoo-hardened] removing .text relocations from mplayer and xine-lib
  2005-05-30 16:49   ` René Rhéaume
@ 2005-06-02 12:42     ` Peter S. Mazinger
  2005-06-04 15:31       ` René Rhéaume
  0 siblings, 1 reply; 6+ messages in thread
From: Peter S. Mazinger @ 2005-06-02 12:42 UTC (permalink / raw
  To: gentoo-hardened

On Mon, 30 May 2005, René Rhéaume wrote:

> I found out symlinking libtool-nofpic to libtool (which produces PIC
> binaries) eliminates most of the relocations. I am able to build on
> Gentoo either outside Portage or using my custom ebuild.
> 
> Just add "use x86 && has_pic && ln -sf libtool ${S}/libtool-nofpic"
> right after econf. You can also comment RESTRICT="nostrip" in the
> ebuild and add "strict" to your FEATURES to get the list of the
> remaining TEXTREL binaries, which are on my system:

Better yet, add --enable-fpic to econf. The change proposed above w/ the 
link is allowed conditionally, if use has_pic && use x86 (probably amd64 
too)
 
> $(get-libdir)/xine/plugins/${PV}/post/xineplug_post_{planar,tvtime}.so
> $(get-libdir)/xine/plugins/${PV}/xineplug_decode_{ff,w32dll,qt}.so

xineplug_decode_ff.so is clean as of 1.0.1, I remove the rest from the 
system, else xine-lib fails to load (see original bug-report, failure on 
planar)

> 
> Feedback from other architectures is appreciated.
> 
> Also, it seems that "use x86 && has_pic && append-flags -UHAVE_MMX" is
> not needed. I can build fine either with or without.

it disables mmx/asm code for any case

> 
> *This paragraph is more a note to myself, but can be interesting for
> those with older gcc versions*
> I also tried this symlinking trick on my half-Mandr* install and got
> two build errors (make -k). It is probably a bug from that old
> gcc-3.2-1mdk I get as I already have to patch xine-lib to disable SIMD
> code generation in FAAD code even when I generate non-PIC code.
> Faulty files are:
> ${S}/src/libffmpeg/libavcodec/i386/mpegvideo_mmx_template.c
> ${S}/src/libffmpeg/libavcodec/libpostproc/postprocess_template.c
> Error message: can't find a register in class `GENERAL_REGS' while
> reloading `asm'

see how this is solved in the ffmpeg ebuild, important is to disable 
mmx/asm code.

Peter

-- 
Peter S. Mazinger <ps dot m at gmx dot net>           ID: 0xA5F059F2
Key fingerprint = 92A4 31E1 56BC 3D5A 2D08  BB6E C389 975E A5F0 59F2

-- 
gentoo-hardened@gentoo.org mailing list


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

* Re: [gentoo-hardened] removing .text relocations from mplayer and xine-lib
  2005-06-02 12:42     ` Peter S. Mazinger
@ 2005-06-04 15:31       ` René Rhéaume
  2005-06-09 12:43         ` Peter S. Mazinger
  0 siblings, 1 reply; 6+ messages in thread
From: René Rhéaume @ 2005-06-04 15:31 UTC (permalink / raw
  To: gentoo-hardened

> Better yet, add --enable-fpic to econf. The change proposed above w/ the
> link is allowed conditionally, if use has_pic && use x86 (probably amd64
> too)
Yes, --enable-fpic worked.

> xineplug_decode_ff.so is clean as of 1.0.1, I remove the rest from the
> system, else xine-lib fails to load (see original bug-report, failure on
> planar)
Which revision? I based my ebuild on 1.0.1-r1 and I have never been
able to suppress text relocations from xineplug_decode_ff.so. Grr, the
Xine team remade the ffmpeg build system from scratch using the GNU
autotools. Also, when I looked up for 'planar' in Gentoo Bugzilla, I
got the famous 'Zarro boogs found' message.

But why xineplug_decode_w32dll.so is built even when win32codecs is
not in USE? Looks like a build system bug to be resolved upstream.

-- 
gentoo-hardened@gentoo.org mailing list


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

* Re: [gentoo-hardened] removing .text relocations from mplayer and xine-lib
  2005-06-04 15:31       ` René Rhéaume
@ 2005-06-09 12:43         ` Peter S. Mazinger
  0 siblings, 0 replies; 6+ messages in thread
From: Peter S. Mazinger @ 2005-06-09 12:43 UTC (permalink / raw
  To: gentoo-hardened

On Sat, 4 Jun 2005, René Rhéaume wrote:

> > Better yet, add --enable-fpic to econf. The change proposed above w/ the
> > link is allowed conditionally, if use has_pic && use x86 (probably amd64
> > too)
> Yes, --enable-fpic worked.
> 
> > xineplug_decode_ff.so is clean as of 1.0.1, I remove the rest from the
> > system, else xine-lib fails to load (see original bug-report, failure on
> > planar)
> Which revision? I based my ebuild on 1.0.1-r1 and I have never been

1.0.3 is clean for sure

> able to suppress text relocations from xineplug_decode_ff.so. Grr, the
> Xine team remade the ffmpeg build system from scratch using the GNU
> autotools. Also, when I looked up for 'planar' in Gentoo Bugzilla, I
> got the famous 'Zarro boogs found' message.

The text relocation in tvtime is due to MMX code usage (although 
-UHAVE_MMX is used, it is not honoured), I have changed ifdef ARCH_X86 w/
if defined(ARCH_X86) && defined(HAVE_MMX)

The text relocation in planar is due to faulty ffmpeg (libpostproc.a 's
objects are not built -fPIC)

I have solved it like this:
-ffmpeg is built fully PIC (also the objects for libpostproc.*)
-modified xine-lib/planar to use the installed libpostproc, not the one 
provided in xine-lib sources.

Peter

-- 
Peter S. Mazinger <ps dot m at gmx dot net>           ID: 0xA5F059F2
Key fingerprint = 92A4 31E1 56BC 3D5A 2D08  BB6E C389 975E A5F0 59F2

-- 
gentoo-hardened@gentoo.org mailing list


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

end of thread, other threads:[~2005-06-09 12:43 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-05-29 15:27 [gentoo-hardened] removing .text relocations from mplayer and xine-lib René Rhéaume
2005-05-29 17:24 ` Ned Ludd
2005-05-30 16:49   ` René Rhéaume
2005-06-02 12:42     ` Peter S. Mazinger
2005-06-04 15:31       ` René Rhéaume
2005-06-09 12:43         ` Peter S. Mazinger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox