diff options
author | Gordon Malm <gengor@gentoo.org> | 2009-10-20 01:54:21 +0000 |
---|---|---|
committer | Gordon Malm <gengor@gentoo.org> | 2009-10-20 01:54:21 +0000 |
commit | 3d838d3b58332d6c4a5b4ee280321110ce05d1c7 (patch) | |
tree | a7c5ee1c046d5e4882c8f4bed34cc95919ffce31 /media-libs/xine-lib | |
parent | Remove check for X USE flag on gtk+, was never needed (diff) | |
download | historical-3d838d3b58332d6c4a5b4ee280321110ce05d1c7.tar.gz historical-3d838d3b58332d6c4a5b4ee280321110ce05d1c7.tar.bz2 historical-3d838d3b58332d6c4a5b4ee280321110ce05d1c7.zip |
Add TEXTREL patch from bug 164425
Package-Manager: portage-2.1.6.13/cvs/Linux i686
Diffstat (limited to 'media-libs/xine-lib')
-rw-r--r-- | media-libs/xine-lib/ChangeLog | 8 | ||||
-rw-r--r-- | media-libs/xine-lib/Manifest | 4 | ||||
-rw-r--r-- | media-libs/xine-lib/files/xine-lib-1.1.15-textrel-fix.patch | 648 | ||||
-rw-r--r-- | media-libs/xine-lib/xine-lib-1.1.16.3-r2.ebuild | 186 |
4 files changed, 844 insertions, 2 deletions
diff --git a/media-libs/xine-lib/ChangeLog b/media-libs/xine-lib/ChangeLog index ac286753a571..04b97d0a25c1 100644 --- a/media-libs/xine-lib/ChangeLog +++ b/media-libs/xine-lib/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for media-libs/xine-lib # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-libs/xine-lib/ChangeLog,v 1.608 2009/10/06 10:15:59 lxnay Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-libs/xine-lib/ChangeLog,v 1.609 2009/10/20 01:54:20 gengor Exp $ + +*xine-lib-1.1.16.3-r2 (20 Oct 2009) + + 20 Oct 2009; Gordon Malm <gengor@gentoo.org> + +files/xine-lib-1.1.15-textrel-fix.patch, +xine-lib-1.1.16.3-r2.ebuild: + Add TEXTREL patch from bug #164425. 06 Oct 2009; Fabio Erculiani <lxnay@gentoo.org> xine-lib-1.1.16.3-r1.ebuild: diff --git a/media-libs/xine-lib/Manifest b/media-libs/xine-lib/Manifest index e65b2db045e3..f24d843318de 100644 --- a/media-libs/xine-lib/Manifest +++ b/media-libs/xine-lib/Manifest @@ -1,5 +1,7 @@ +AUX xine-lib-1.1.15-textrel-fix.patch 29373 RMD160 4702a26f42251614f5f6c99b4770f82da36577ae SHA1 e04d04dbd736fd17be8cf0583d47630850a89bf9 SHA256 1d6aa047cb0a13f248aea2e06e16b9758b9c39d8b7e42b32d0b52b424d26b33e AUX xine-lib-1.1.16.3-libmpcdecsv7.patch 1798 RMD160 57ea11ed7ab5d345b588017ff38fde8cd4e2db59 SHA1 0f62d6d60809c641ae8147774225c113620f8a19 SHA256 111ecc67d11cb0847b2bf7ded7db776a08651ee5171d92da6a30f10430a3623b DIST xine-lib-1.1.16.3.tar.bz2 7468182 RMD160 279304a4e998472b2b5e79887e54c47765044ec6 SHA1 64c57c5f55ff37023cc4c3d93d4df3c06950d235 SHA256 d25a241efa55dc7d8f482336efa8bb7b9bb9d69b6df8a8a37f2660948fd67b52 EBUILD xine-lib-1.1.16.3-r1.ebuild 5603 RMD160 973c5a059cf3be2552d77cdc3cdf406857bf8fd2 SHA1 809472977bf54c14d68ae1b17de25ec32ac3bfe0 SHA256 dbefb04f25f89700ba14eb7fa28b578f5b4266d6399663aefe694e0b43922f8f -MISC ChangeLog 70130 RMD160 e1b97a3e94696b5809dd13404fc8a71f894fd6e2 SHA1 b4fe06c8d73ad67c39007b3b4d4daac7b32a7f4f SHA256 6e787514b0085afd8faeadb45ebdac627fbf315de9e4a26f68750d4f782d1a6c +EBUILD xine-lib-1.1.16.3-r2.ebuild 5679 RMD160 0843fcb011df92caae351044e7896fcca626b68d SHA1 56936c8dcd4a128bf65e4daf70e4addc7e07db56 SHA256 031784cf891b3007acf2bb8126882e26bad0cf29fea54c1feb9b5580543e2766 +MISC ChangeLog 70328 RMD160 c28354ecfe6c8cd31e12de94748368f88ea8a96b SHA1 3d12724507aeee96b41181fd1f982932a977475c SHA256 39b45a3277a4b9680fae86b1d1f2bde058f258f6a29a6920f3d610a1e1238301 MISC metadata.xml 2914 RMD160 bed4bab81a32b49e4923ddfcc02e8338a45ef7ef SHA1 fe3faf7dba7f929241acfe5eaa17b2f66bfb2722 SHA256 efe3b879c59c9971e1ffcd732c2bdbd8f60f2b173fde675a371202ceeb96b0fe diff --git a/media-libs/xine-lib/files/xine-lib-1.1.15-textrel-fix.patch b/media-libs/xine-lib/files/xine-lib-1.1.15-textrel-fix.patch new file mode 100644 index 000000000000..1c512127d56b --- /dev/null +++ b/media-libs/xine-lib/files/xine-lib-1.1.15-textrel-fix.patch @@ -0,0 +1,648 @@ +From: PaX Team <pageexec at freemail.hu> +Reference: http://bugs.gentoo.org/164425 + +--- a/src/post/deinterlace/plugins/tomsmocomp/SearchLoop0A.inc ++++ b/src/post/deinterlace/plugins/tomsmocomp/SearchLoop0A.inc +@@ -7,9 +7,9 @@ + // up by a little, and adjust later + + #ifdef IS_SSE2 +- "paddusb "MANGLE(ONES)", %%xmm7\n\t" // bias toward no motion ++ "paddusb "_ONES", %%xmm7\n\t" // bias toward no motion + #else +- "paddusb "MANGLE(ONES)", %%mm7\n\t" // bias toward no motion ++ "paddusb "_ONES", %%mm7\n\t" // bias toward no motion + #endif + + MERGE4PIXavg("(%%"XDI", %%"XCX")", "(%%"XSI", %%"XCX")") // center, in old and new +--- a/src/post/deinterlace/plugins/tomsmocomp/SearchLoopBottom.inc ++++ b/src/post/deinterlace/plugins/tomsmocomp/SearchLoopBottom.inc +@@ -18,7 +18,7 @@ + // Use the best weave if diffs less than 10 as that + // means the image is still or moving cleanly + // if there is motion we will clip which will catch anything +- "psubusb "MANGLE(FOURS)", %%mm7\n\t" // sets bits to zero if weave diff < 4 ++ "psubusb "_FOURS", %%mm7\n\t" // sets bits to zero if weave diff < 4 + "pxor %%mm0, %%mm0\n\t" + "pcmpeqb %%mm0, %%mm7\n\t" // all ff where weave better, else 00 + "pcmpeqb %%mm7, %%mm0\n\t" // all ff where bob better, else 00 +@@ -28,10 +28,10 @@ + #else + // Use the better of bob or weave + // pminub mm4, TENS // the most we care about +- V_PMINUB ("%%mm4", MANGLE(TENS), "%%mm0") // the most we care about ++ V_PMINUB ("%%mm4", _TENS, "%%mm0") // the most we care about + + "psubusb %%mm4, %%mm7\n\t" // foregive that much from weave est? +- "psubusb "MANGLE(FOURS)", %%mm7\n\t" // bias it a bit toward weave ++ "psubusb "_FOURS", %%mm7\n\t" // bias it a bit toward weave + "pxor %%mm0, %%mm0\n\t" + "pcmpeqb %%mm0, %%mm7\n\t" // all ff where weave better, else 00 + "pcmpeqb %%mm7, %%mm0\n\t" // all ff where bob better, else 00 +@@ -42,39 +42,39 @@ + + + // pminub mm0, Max_Vals // but clip to catch the stray error +-// V_PMINUB ("%%mm0", MANGLE(Max_Vals), "%%mm1") // but clip to catch the stray error ++// V_PMINUB ("%%mm0", _Max_Vals, "%%mm1") // but clip to catch the stray error + // pmaxub mm0, Min_Vals +-// V_PMAXUB ("%%mm0", MANGLE(Min_Vals)) ++// V_PMAXUB ("%%mm0", _Min_Vals) + + #endif + + + MOVX" "_pDest", %%"XAX"\n\t" +- ++ ADDX" "_olddx", %%"XAX"\n\t" ++ + #ifdef USE_VERTICAL_FILTER + "movq %%mm0, %%mm1\n\t" +- // pavgb mm0, qword ptr["XBX"] +- V_PAVGB ("%%mm0", "(%%"XBX")", "%%mm2", MANGLE(ShiftMask)) +- // movntq qword ptr["XAX"+"XDX"], mm0 +- V_MOVNTQ ("(%"XAX", %%"XDX")", "%%mm0") +- // pavgb mm1, qword ptr["XBX"+"XCX"] +- V_PAVGB ("%%mm1", "(%%"XBX", %%"XCX")", "%%mm2", MANGLE(ShiftMask)) +- "addq "_dst_pitchw", %%"XBX +- // movntq qword ptr["XAX"+"XDX"], mm1 +- V_MOVNTQ ("(%%"XAX", %%"XDX")", "%%mm1") ++ // pavgb mm0, qword ptr["XDX"] ++ V_PAVGB ("%%mm0", "(%%"XDX")", "%%mm2", _ShiftMask) ++ // movntq qword ptr["XAX"+"_olddx"], mm0 ++ V_MOVNTQ ("(%"XAX")", "%%mm0") ++ // pavgb mm1, qword ptr["XDX"+"XCX"] ++ V_PAVGB ("%%mm1", "(%%"XDX", %%"XCX")", "%%mm2", _ShiftMask) ++ "addq "_dst_pitchw", %%"XDX ++ // movntq qword ptr["XAX"+"_olddx"], mm1 ++ V_MOVNTQ ("(%%"XAX")", "%%mm1") + #else + +- // movntq qword ptr["XAX"+"XDX"], mm0 +- V_MOVNTQ ("(%%"XAX", %%"XDX")", "%%mm0") ++ // movntq qword ptr["XAX"+"_olddx"], mm0 ++ V_MOVNTQ ("(%%"XAX")", "%%mm0") + #endif + +- LEAX" 8(%%"XDX"), %%"XDX"\n\t" // bump offset pointer +- CMPX" "_Last8", %%"XDX"\n\t" // done with line? ++ ADDX" $8, "_olddx"\n\t" // bump offset pointer ++ MOVX" "_olddx", %%"XAX"\n\t" ++ CMPX" "_Last8", %%"XAX"\n\t" // done with line? + "jb 1b\n\t" // y + #endif + +- MOVX" "_oldbx", %%"XBX"\n\t" +- + : /* no outputs */ + + : "m"(pBob), +@@ -85,7 +85,17 @@ + "m"(pSrc), + "m"(pSrcP), + "m"(pBobP), +- "m"(oldbx) ++ "m"(olddx), ++ "m"(UVMask), ++ "m"(ShiftMask), ++ "m"(FOURS), ++ "m"(TENS), ++ "m"(Max_Vals), ++ "m"(Min_Vals), ++ "m"(YMask), ++ "m"(Max_Mov), ++ "m"(ONES), ++ "m"(DiffThres) + + : XAX, XCX, XDX, XSI, XDI, + #ifdef ARCH_X86 +--- a/src/post/deinterlace/plugins/tomsmocomp/SearchLoopTop.inc ++++ b/src/post/deinterlace/plugins/tomsmocomp/SearchLoopTop.inc +@@ -66,7 +66,17 @@ long dst_pitchw = dst_pitch; // local s + #define _pSrc "%5" + #define _pSrcP "%6" + #define _pBobP "%7" +-#define _oldbx "%8" ++#define _olddx "%8" ++#define _UVMask "%9" ++#define _ShiftMask "%10" ++#define _FOURS "%11" ++#define _TENS "%12" ++#define _Max_Vals "%13" ++#define _Min_Vals "%14" ++#define _YMask "%15" ++#define _Max_Mov "%16" ++#define _ONES "%17" ++#define _DiffThres "%18" + #endif + + for (y=1; y < FldHeight-1; y++) +@@ -77,75 +87,75 @@ long dst_pitchw = dst_pitch; // local s + // Loop general reg usage + // + // XAX - pBobP, then pDest +- // XBX - pBob ++ // XDX - pBob + // XCX - src_pitch2 +- // XDX - current offset ++ // _olddx - current offset + // XDI - prev weave pixels, 1 line up + // XSI - next weave pixels, 1 line up + +- // Save "XBX" (-fPIC) +- MOVX" %%"XBX", "_oldbx"\n\t" +- + #ifdef IS_SSE2 + + // sse2 code deleted for now + + #else + // simple bob first 8 bytes +- MOVX" "_pBob", %%"XBX"\n\t" ++ MOVX" "_pBob", %%"XDX"\n\t" + MOVX" "_src_pitch2", %%"XCX"\n\t" + + #ifdef USE_VERTICAL_FILTER +- "movq (%%"XBX"), %%mm0\n\t" +- "movq (%%"XBX", %%"XCX"), %%mm1\n\t" //, qword ptr["XBX"+"XCX"] ++ "movq (%%"XDX"), %%mm0\n\t" ++ "movq (%%"XDX", %%"XCX"), %%mm1\n\t" //, qword ptr["XDX"+"XCX"] + "movq %%mm0, %%mm2\n\t" +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // halfway between +- V_PAVGB ("%%mm0", "%%mm2", "%%mm3", MANGLE(ShiftMask)) // 1/4 way +- V_PAVGB ("%%mm1", "%%mm2", "%%mm3", MANGLE(ShiftMask)) // 3/4 way ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // halfway between ++ V_PAVGB ("%%mm0", "%%mm2", "%%mm3", _ShiftMask) // 1/4 way ++ V_PAVGB ("%%mm1", "%%mm2", "%%mm3", _ShiftMask) // 3/4 way + MOVX" "_pDest", %%"XDI"\n\t" + MOVX" "_dst_pitchw", %%"XAX"\n\t" + V_MOVNTQ ("(%%"XDI")", "%%mm0") + V_MOVNTQ ("(%%"XDI", %%"XAX")", "%%mm1") // qword ptr["XDI"+"XAX"], mm1 + + // simple bob last 8 bytes +- MOVX" "_Last8", %%"XDX"\n\t" +- LEAX" (%%"XBX", %%"XDX"), %%"XSI"\n\t" // ["XBX"+"XDX"] ++ MOVX" "_Last8", %%"XSI"\n\t" ++ MOVX" %%"XSI", "_olddx"\n\t" ++ ADDX" %%"XDX", %%"XSI"\n\t" // ["XDX"+"_olddx"] + "movq (%%"XSI"), %%mm0\n\t" + "movq (%%"XSI", %%"XCX"), %%mm1\n\t" // qword ptr["XSI"+"XCX"] + "movq %%mm0, %%mm2\n\t" +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // halfway between +- V_PAVGB ("%%mm0", "%%mm2", "%%mm3", MANGLE(ShiftMask)) // 1/4 way +- V_PAVGB ("%%mm1", "%%mm2", "%%mm3", MANGLE(ShiftMask)) // 3/4 way +- ADDX" %%"XDX", %%"XDI"\n\t" // last 8 bytes of dest ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // halfway between ++ V_PAVGB ("%%mm0", "%%mm2", "%%mm3", _ShiftMask) // 1/4 way ++ V_PAVGB ("%%mm1", "%%mm2", "%%mm3", _ShiftMask) // 3/4 way ++ ADDX" "_olddx", %%"XDI"\n\t" // last 8 bytes of dest + V_MOVNTQ ("%%"XDI"", "%%mm0") + V_MOVNTQ ("(%%"XDI", %%"XAX")", "%%mm1") // qword ptr["XDI"+"XAX"], mm1) + + #else +- "movq (%%"XBX"), %%mm0\n\t" +- // pavgb mm0, qword ptr["XBX"+"XCX"] +- V_PAVGB ("%%mm0", "(%%"XBX", %%"XCX")", "%%mm2", MANGLE(ShiftMask)) // qword ptr["XBX"+"XCX"], mm2, ShiftMask) ++ "movq (%%"XDX"), %%mm0\n\t" ++ // pavgb mm0, qword ptr["XDX"+"XCX"] ++ V_PAVGB ("%%mm0", "(%%"XDX", %%"XCX")", "%%mm2", _ShiftMask) // qword ptr["XDX"+"XCX"], mm2, ShiftMask) + MOVX" "_pDest", %%"XDI"\n\t" + V_MOVNTQ ("(%%"XDI")", "%%mm0") + + // simple bob last 8 bytes +- MOVX" "_Last8", %%"XDX"\n\t" +- LEAX" (%%"XBX", %%"XDX"), %%"XSI"\n\t" //"XSI", ["XBX"+"XDX"] ++ MOVX" "_Last8", %%"XSI"\n\t" ++ MOVX" %%"XSI", "_olddx"\n\t" ++ ADDX" %%"XDX", %%"XSI"\n\t" //"XSI", ["XDX"+"_olddx"] + "movq (%%"XSI"), %%mm0\n\t" + // pavgb mm0, qword ptr["XSI"+"XCX"] +- V_PAVGB ("%%mm0", "(%%"XSI", %%"XCX")", "%%mm2", MANGLE(ShiftMask)) // qword ptr["XSI"+"XCX"], mm2, ShiftMask) +- V_MOVNTQ ("(%%"XDI", %%"XDX")", "%%mm0") // qword ptr["XDI"+"XDX"], mm0) ++ V_PAVGB ("%%mm0", "(%%"XSI", %%"XCX")", "%%mm2", _ShiftMask) // qword ptr["XSI"+"XCX"], mm2, ShiftMask) ++ ADDX" "_olddx", %%"XDI"\n\t" ++ V_MOVNTQ ("(%%"XDI")", "%%mm0") // qword ptr["XDI"+"_olddx"], mm0) + #endif + // now loop and get the middle qwords + MOVX" "_pSrc", %%"XSI"\n\t" + MOVX" "_pSrcP", %%"XDI"\n\t" +- MOVX" $8, %%"XDX"\n\t" // curr offset longo all lines ++ MOVX" $8, "_olddx"\n\t" // curr offset longo all lines + + "1:\n\t" + MOVX" "_pBobP", %%"XAX"\n\t" + ADDX" $8, %%"XDI"\n\t" + ADDX" $8, %%"XSI"\n\t" +- ADDX" $8, %%"XBX"\n\t" +- ADDX" %%"XDX", %%"XAX"\n\t" ++ ADDX" $8, %%"XDX"\n\t" ++ ADDX" "_olddx", %%"XAX"\n\t" + + #ifdef USE_STRANGE_BOB + #include "StrangeBob.inc" +--- a/src/post/deinterlace/plugins/tomsmocomp/StrangeBob.inc ++++ b/src/post/deinterlace/plugins/tomsmocomp/StrangeBob.inc +@@ -31,22 +31,22 @@ + "pxor %%mm6, %%mm6\n\t" + "pxor %%mm7, %%mm7\n\t" + +- "movq -2(%%"XBX"), %%mm0\n\t" // value a from top left +- "movq -4(%%"XBX", %%"XCX"), %%mm1\n\t" // value m from bottom right ++ "movq -2(%%"XDX"), %%mm0\n\t" // value a from top left ++ "movq -4(%%"XDX", %%"XCX"), %%mm1\n\t" // value m from bottom right + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" + "psubusb %%mm0, %%mm1\n\t" + "por %%mm1, %%mm3\n\t" // abs(a,m) + +- "psubusb "MANGLE(DiffThres)", %%mm3\n\t" // nonzero where abs(a,m) > Thres else 0 ++ "psubusb "_DiffThres", %%mm3\n\t" // nonzero where abs(a,m) > Thres else 0 + "pxor %%mm4, %%mm4\n\t" + "pcmpeqb %%mm4, %%mm3\n\t" // now ff where abs(a,m) < Thres, else 00 + "pcmpeqb %%mm3, %%mm4\n\t" // here ff where abs(a,m) > Thres, else 00 + + +- "movq -4(%%"XBX"), %%mm0\n\t" // value j +- "movq 4(%%"XBX", %%"XCX"), %%mm1\n\t" // value n ++ "movq -4(%%"XDX"), %%mm0\n\t" // value j ++ "movq 4(%%"XDX", %%"XCX"), %%mm1\n\t" // value n + "movq %%mm0, %%mm2\n\t" + "pavgb %%mm1, %%mm2\n\t" // avg(j,n) + "movq %%mm0, %%mm3\n\t" +@@ -55,7 +55,7 @@ + "por %%mm1, %%mm0\n\t" // abs(j,n) + + "movq %%mm0, %%mm1\n\t" +- "psubusb "MANGLE(DiffThres)", %%mm1\n\t" // nonzero where abs(j,n) > Thres else 0 ++ "psubusb "_DiffThres", %%mm1\n\t" // nonzero where abs(j,n) > Thres else 0 + "pxor %%mm3, %%mm3\n\t" + "pcmpeqb %%mm3, %%mm1\n\t" // now ff where abs(j,n) < Thres, else 00 + +@@ -75,31 +75,31 @@ + "por %%mm0, %%mm7\n\t" + + // k & m +- "movq 2(%%"XBX"), %%mm0\n\t" // value c from top left +- "movq 4(%%"XBX", %%"XCX"), %%mm1\n\t" // value n from bottom right ++ "movq 2(%%"XDX"), %%mm0\n\t" // value c from top left ++ "movq 4(%%"XDX", %%"XCX"), %%mm1\n\t" // value n from bottom right + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" + "psubusb %%mm0, %%mm1\n\t" + "por %%mm1, %%mm3\n\t" // abs(c,n) + +- "psubusb "MANGLE(DiffThres)", %%mm3\n\t" // nonzero where abs(c,n) > Thres else 0 ++ "psubusb "_DiffThres", %%mm3\n\t" // nonzero where abs(c,n) > Thres else 0 + "pxor %%mm4, %%mm4\n\t" + "pcmpeqb %%mm4, %%mm3\n\t" // now ff where abs(c,n) < Thres, else 00 + "pcmpeqb %%mm3, %%mm4\n\t" // here ff where abs(c,n) > Thres, else 00 + + +- "movq 4(%%"XBX"), %%mm0\n\t" // value k +- "movq -4(%%"XBX", %%"XCX"), %%mm1\n\t" // value m ++ "movq 4(%%"XDX"), %%mm0\n\t" // value k ++ "movq -4(%%"XDX", %%"XCX"), %%mm1\n\t" // value m + "movq %%mm0, %%mm2\n\t" +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(k,m) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(k,m) + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm0\n\t" + "psubusb %%mm3, %%mm1\n\t" + "por %%mm1, %%mm0\n\t" // abs(k,m) + + "movq %%mm0, %%mm1\n\t" +- "psubusb "MANGLE(DiffThres)", %%mm1\n\t" // nonzero where abs(k,m) > Thres else 0 ++ "psubusb "_DiffThres", %%mm1\n\t" // nonzero where abs(k,m) > Thres else 0 + "pxor %%mm3, %%mm3\n\t" + "pcmpeqb %%mm3, %%mm1\n\t" // now ff where abs(k,m) < Thres, else 00 + +@@ -120,30 +120,30 @@ + + + // c & d +- "movq (%%"XBX"), %%mm0\n\t" // value b from top left +- "movq 2(%%"XBX", %%"XCX"), %%mm1\n\t" // value f from bottom right ++ "movq (%%"XDX"), %%mm0\n\t" // value b from top left ++ "movq 2(%%"XDX", %%"XCX"), %%mm1\n\t" // value f from bottom right + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" + "psubusb %%mm0, %%mm1\n\t" + "por %%mm1, %%mm3\n\t" // abs(b,f) + +- "psubusb "MANGLE(DiffThres)", %%mm3\n\t" // nonzero where abs(b,f) > Thres else 0 ++ "psubusb "_DiffThres", %%mm3\n\t" // nonzero where abs(b,f) > Thres else 0 + "pxor %%mm4, %%mm4\n\t" + "pcmpeqb %%mm4, %%mm3\n\t" // now ff where abs(b,f) < Thres, else 00 + "pcmpeqb %%mm3, %%mm4\n\t" // here ff where abs(b,f) > Thres, else 00 + +- "movq 2(%%"XBX"), %%mm0\n\t" // value c +- "movq -2(%%"XBX", %%"XCX"), %%mm1\n\t" // value d ++ "movq 2(%%"XDX"), %%mm0\n\t" // value c ++ "movq -2(%%"XDX", %%"XCX"), %%mm1\n\t" // value d + "movq %%mm0, %%mm2\n\t" +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(c,d) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(c,d) + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm0\n\t" + "psubusb %%mm3, %%mm1\n\t" + "por %%mm1, %%mm0\n\t" // abs(c,d) + + "movq %%mm0, %%mm1\n\t" +- "psubusb "MANGLE(DiffThres)", %%mm1\n\t" // nonzero where abs(c,d) > Thres else 0 ++ "psubusb "_DiffThres", %%mm1\n\t" // nonzero where abs(c,d) > Thres else 0 + "pxor %%mm3, %%mm3\n\t" + "pcmpeqb %%mm3, %%mm1\n\t" // now ff where abs(c,d) < Thres, else 00 + +@@ -163,30 +163,30 @@ + "por %%mm0, %%mm7\n\t" + + // a & f +- "movq (%%"XBX"), %%mm0\n\t" // value b from top left +- "movq -2(%%"XBX", %%"XCX"), %%mm1\n\t" // value d from bottom right ++ "movq (%%"XDX"), %%mm0\n\t" // value b from top left ++ "movq -2(%%"XDX", %%"XCX"), %%mm1\n\t" // value d from bottom right + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" + "psubusb %%mm0, %%mm1\n\t" + "por %%mm1, %%mm3\n\t" // abs(b,d) + +- "psubusb "MANGLE(DiffThres)", %%mm3\n\t" // nonzero where abs(b,d) > Thres else 0 ++ "psubusb "_DiffThres", %%mm3\n\t" // nonzero where abs(b,d) > Thres else 0 + "pxor %%mm4, %%mm4\n\t" + "pcmpeqb %%mm4, %%mm3\n\t" // now ff where abs(b,d) < Thres, else 00 + "pcmpeqb %%mm3, %%mm4\n\t" // here ff where abs(b,d) > Thres, else 00 + +- "movq -2(%%"XBX"), %%mm0\n\t" // value a +- "movq 2(%%"XBX", %%"XCX"), %%mm1\n\t" // value f ++ "movq -2(%%"XDX"), %%mm0\n\t" // value a ++ "movq 2(%%"XDX", %%"XCX"), %%mm1\n\t" // value f + "movq %%mm0, %%mm2\n\t" +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(a,f) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(a,f) + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm0\n\t" + "psubusb %%mm3, %%mm1\n\t" + "por %%mm1, %%mm0\n\t" // abs(a,f) + + "movq %%mm0, %%mm1\n\t" +- "psubusb "MANGLE(DiffThres)", %%mm1\n\t" // nonzero where abs(a,f) > Thres else 0 ++ "psubusb "_DiffThres", %%mm1\n\t" // nonzero where abs(a,f) > Thres else 0 + "pxor %%mm3, %%mm3\n\t" + "pcmpeqb %%mm3, %%mm1\n\t" // now ff where abs(a,f) < Thres, else 00 + +@@ -205,22 +205,22 @@ + "por %%mm2, %%mm6\n\t" + "por %%mm0, %%mm7\n\t" + +- "pand "MANGLE(YMask)", %%mm5\n\t" // mask out chroma from here +- "pand "MANGLE(YMask)", %%mm6\n\t" // mask out chroma from here +- "pand "MANGLE(YMask)", %%mm7\n\t" // mask out chroma from here ++ "pand "_YMask", %%mm5\n\t" // mask out chroma from here ++ "pand "_YMask", %%mm6\n\t" // mask out chroma from here ++ "pand "_YMask", %%mm7\n\t" // mask out chroma from here + + // b,e +- "movq (%%"XBX"), %%mm0\n\t" // value b from top +- "movq (%%"XBX", %%"XCX"), %%mm1\n\t" // value e from bottom ++ "movq (%%"XDX"), %%mm0\n\t" // value b from top ++ "movq (%%"XDX", %%"XCX"), %%mm1\n\t" // value e from bottom + "movq %%mm0, %%mm2\n\t" +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(b,e) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(b,e) + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm0\n\t" + "psubusb %%mm3, %%mm1\n\t" + "por %%mm1, %%mm0\n\t" // abs(b,e) + + "movq %%mm0, %%mm1\n\t" +- "psubusb "MANGLE(DiffThres)", %%mm1\n\t" // nonzero where abs(b,e) > Thres else 0 ++ "psubusb "_DiffThres", %%mm1\n\t" // nonzero where abs(b,e) > Thres else 0 + "pxor %%mm3, %%mm3\n\t" + "pcmpeqb %%mm3, %%mm1\n\t" // now ff where abs(b,e) < Thres, else 00 + +@@ -238,8 +238,8 @@ + "por %%mm0, %%mm7\n\t" + + // bob in any leftovers +- "movq (%%"XBX"), %%mm0\n\t" // value b from top +- "movq (%%"XBX", %%"XCX"), %%mm1\n\t" // value e from bottom ++ "movq (%%"XDX"), %%mm0\n\t" // value b from top ++ "movq (%%"XDX", %%"XCX"), %%mm1\n\t" // value e from bottom + + + // We will also calc here the max/min values to later limit comb +@@ -271,7 +271,7 @@ + "por %%mm2, %%mm3\n\t" // abs diff + // pmaxub %%mm3, %%mm4 // top or bottom pixel moved most + V_PMAXUB ("%%mm3", "%%mm4") // top or bottom pixel moved most +- "psubusb "MANGLE(DiffThres)", %%mm3\n\t" // moved more than allowed? or goes to 0? ++ "psubusb "_DiffThres", %%mm3\n\t" // moved more than allowed? or goes to 0? + "pxor %%mm4, %%mm4\n\t" + "pcmpeqb %%mm4, %%mm3\n\t" // now ff where low motion, else high motion + +@@ -283,19 +283,19 @@ + V_PMAXUB ("%%mm6", "%%mm2") + + "psubusb %%mm3, %%mm2\n\t" // maybe decrease it to 0000.. if no surround motion +-// "movq %%mm2, "MANGLE(Min_Vals)"\n\t" ++// "movq %%mm2, "_Min_Vals"\n\t" + + "movq %%mm0, %%mm2\n\t" + V_PMAXUB ("%%mm2", "%%mm1") + // pminub %%mm6, %%mm2 // clip our current results so far to be below this + V_PMINUB ("%%mm6", "%%mm2", "%%mm4") + "paddusb %%mm3, %%mm2\n\t" // maybe increase it to ffffff if no surround motion +-// "movq %%mm2, "MANGLE(Max_Vals)"\n\t" ++// "movq %%mm2, "_Max_Vals"\n\t" + #endif + + "movq %%mm0, %%mm2\n\t" + // pavgb %%mm2, %%mm1 // avg(b,e) +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(b,e) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(b,e) + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" +--- a/src/post/deinterlace/plugins/tomsmocomp/TomsMoCompAll.inc ++++ b/src/post/deinterlace/plugins/tomsmocomp/TomsMoCompAll.inc +@@ -33,8 +33,8 @@ static const int64_t __attribute__((__us + static const int64_t __attribute__((__used__)) FOURS = 0x0404040404040404ull; + static const int64_t __attribute__((__used__)) ONES = 0x0101010101010101ull; + static const int64_t __attribute__((__used__)) ShiftMask = 0xfefffefffefffeffull; +-//static int64_t Min_Vals = 0x0000000000000000ull; +-//static int64_t Max_Vals = 0x0000000000000000ull; ++static int64_t Min_Vals = 0x0000000000000000ull; ++static int64_t Max_Vals = 0x0000000000000000ull; + #endif + + #ifndef TopFirst +@@ -69,7 +69,7 @@ static void FUNCT_NAME(uint8_t *output, + int rowsize; + int FldHeight; + int stride = (width*2); +- long oldbx; ++ long olddx; + + + src_pitch = stride*2; +--- a/src/post/deinterlace/plugins/tomsmocomp/WierdBob.inc ++++ b/src/post/deinterlace/plugins/tomsmocomp/WierdBob.inc +@@ -14,22 +14,22 @@ + // selected for the smallest of abs(a,f), abs(c,d), or abs(b,e), etc. + + // a,f +- "movq -2(%%"XBX"), %%mm0\n\t" // value a from top left +- "movq 2(%%"XBX", %%"XCX"), %%mm1\n\t" // value f from bottom right ++ "movq -2(%%"XDX"), %%mm0\n\t" // value a from top left ++ "movq 2(%%"XDX", %%"XCX"), %%mm1\n\t" // value f from bottom right + "movq %%mm0, %%mm6\n\t" + // pavgb %%mm6, %%mm1 // avg(a,f), also best so far +- V_PAVGB ("%%mm6", "%%mm1", "%%mm7", MANGLE(ShiftMask)) // avg(a,f), also best so far ++ V_PAVGB ("%%mm6", "%%mm1", "%%mm7", _ShiftMask) // avg(a,f), also best so far + "movq %%mm0, %%mm7\n\t" + "psubusb %%mm1, %%mm7\n\t" + "psubusb %%mm0, %%mm1\n\t" + "por %%mm1, %%mm7\n\t" // abs diff, also best so far + + // c,d +- "movq 2(%%"XBX"), %%mm0\n\t" // value a from top left +- "movq -2(%%"XBX", %%"XCX"), %%mm1\n\t" // value f from bottom right ++ "movq 2(%%"XDX"), %%mm0\n\t" // value a from top left ++ "movq -2(%%"XDX", %%"XCX"), %%mm1\n\t" // value f from bottom right + "movq %%mm0, %%mm2\n\t" + // pavgb %%mm2, %%mm1 // avg(c,d) +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(c,d) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(c,d) + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" + "psubusb %%mm0, %%mm1\n\t" +@@ -49,15 +49,15 @@ + + "por %%mm2, %%mm6\n\t" // and merge new & old vals keeping best + "por %%mm1, %%mm7\n\t" +- "por "MANGLE(UVMask)", %%mm7\n\t" // but we know chroma is worthless so far +- "pand "MANGLE(YMask)", %%mm5\n\t" // mask out chroma from here also ++ "por "_UVMask", %%mm7\n\t" // but we know chroma is worthless so far ++ "pand "_YMask", %%mm5\n\t" // mask out chroma from here also + + // j,n +- "movq -4(%%"XBX"), %%mm0\n\t" // value j from top left +- "movq 4(%%"XBX", %%"XCX"), %%mm1\n\t" // value n from bottom right ++ "movq -4(%%"XDX"), %%mm0\n\t" // value j from top left ++ "movq 4(%%"XDX", %%"XCX"), %%mm1\n\t" // value n from bottom right + "movq %%mm0, %%mm2\n\t" + // pavgb %%mm2, %%mm1 // avg(j,n) +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(j,n) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(j,n) + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" + "psubusb %%mm0, %%mm1\n\t" +@@ -79,11 +79,11 @@ + "por %%mm1, %%mm7\n\t" // " + + // k, m +- "movq 4(%%"XBX"), %%mm0\n\t" // value k from top right +- "movq -4(%%"XBX", %%"XCX"), %%mm1\n\t" // value n from bottom left ++ "movq 4(%%"XDX"), %%mm0\n\t" // value k from top right ++ "movq -4(%%"XDX", %%"XCX"), %%mm1\n\t" // value n from bottom left + "movq %%mm0, %%mm4\n\t" + // pavgb %%mm4, %%mm1 // avg(k,m) +- V_PAVGB ("%%mm4", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(k,m) ++ V_PAVGB ("%%mm4", "%%mm1", "%%mm3", _ShiftMask) // avg(k,m) + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" +@@ -108,8 +108,8 @@ + "por %%mm1, %%mm7\n\t" // " + + // b,e +- "movq (%%"XBX"), %%mm0\n\t" // value b from top +- "movq (%%"XBX", %%"XCX"), %%mm1\n\t" // value e from bottom ++ "movq (%%"XDX"), %%mm0\n\t" // value b from top ++ "movq (%%"XDX", %%"XCX"), %%mm1\n\t" // value e from bottom + + // We will also calc here the max/min values to later limit comb + // so the max excursion will not exceed the Max_Comb constant +@@ -140,7 +140,7 @@ + "por %%mm2, %%mm3\n\t" // abs diff + // pmaxub %%mm3, %%mm4 // top or bottom pixel moved most + V_PMAXUB ("%%mm3", "%%mm4") // top or bottom pixel moved most +- "psubusb "MANGLE(Max_Mov)", %%mm3\n\t" // moved more than allowed? or goes to 0? ++ "psubusb "_Max_Mov", %%mm3\n\t" // moved more than allowed? or goes to 0? + "pxor %%mm4, %%mm4\n\t" + "pcmpeqb %%mm4, %%mm3\n\t" // now ff where low motion, else high motion + +@@ -152,19 +152,19 @@ + V_PMAXUB ("%%mm6", "%%mm2") + + "psubusb %%mm3, %%mm2\n\t" // maybe decrease it to 0000.. if no surround motion +-// "movq %%mm2, "MANGLE(Min_Vals)"\n\t" ++// "movq %%mm2, "_Min_Vals"\n\t" + + "movq %%mm0, %%mm2\n\t" + V_PMAXUB ("%%mm2", "%%mm1") + // pminub %%mm6, %%mm2 // clip our current results so far to be below this + V_PMINUB ("%%mm6", "%%mm2", "%%mm4") + "paddusb %%mm3, %%mm2\n\t" // maybe increase it to ffffff if no surround motion +-// "movq %%mm2, "MANGLE(Max_Vals)"\n\t" ++// "movq %%mm2, "_Max_Vals"\n\t" + #endif + + "movq %%mm0, %%mm2\n\t" + // pavgb %%mm2, %%mm1 // avg(b,e) +- V_PAVGB ("%%mm2", "%%mm1", "%%mm3", MANGLE(ShiftMask)) // avg(b,e) ++ V_PAVGB ("%%mm2", "%%mm1", "%%mm3", _ShiftMask) // avg(b,e) + + "movq %%mm0, %%mm3\n\t" + "psubusb %%mm1, %%mm3\n\t" +--- a/src/post/deinterlace/plugins/tomsmocomp/tomsmocompmacros.h ++++ b/src/post/deinterlace/plugins/tomsmocomp/tomsmocompmacros.h +@@ -114,7 +114,7 @@ + "por %%xmm0, %%xmm5\n\t" /* and merge new & old vals */ \ + "por %%xmm2, %%xmm7\n\t" + +-#define RESET_CHROMA "por "MANGLE(UVMask)", %%xmm7\n\t" ++#define RESET_CHROMA "por "_UVMask", %%xmm7\n\t" + + #else // ifdef IS_SSE2 + +@@ -126,7 +126,7 @@ + "psubusb %%mm1, %%mm2\n\t" \ + "psubusb %%mm0, %%mm3\n\t" \ + "por %%mm3, %%mm2\n\t" \ +- V_PAVGB ("%%mm0", "%%mm1", "%%mm3", MANGLE(ShiftMask)) /* avg of 2 pixels */ \ ++ V_PAVGB ("%%mm0", "%%mm1", "%%mm3", _ShiftMask) /* avg of 2 pixels */ \ + "movq %%mm2, %%mm3\n\t" /* another copy of our our weights */ \ + "pxor %%mm1, %%mm1\n\t" \ + "psubusb %%mm7, %%mm3\n\t" /* nonzero where old weights lower, else 0 */ \ +@@ -144,14 +144,14 @@ + "movq "PADDR2A", %%mm1\n\t" /* our pixel2 value */ \ + "movq "PADDR1B", %%mm2\n\t" /* our 4 pixels */ \ + "movq "PADDR2B", %%mm3\n\t" /* our pixel2 value */ \ +- V_PAVGB("%%mm0", "%%mm2", "%%mm2", MANGLE(ShiftMask)) \ +- V_PAVGB("%%mm1", "%%mm3", "%%mm3", MANGLE(ShiftMask)) \ ++ V_PAVGB("%%mm0", "%%mm2", "%%mm2", _ShiftMask) \ ++ V_PAVGB("%%mm1", "%%mm3", "%%mm3", _ShiftMask) \ + "movq %%mm0, %%mm2\n\t" /* another copy of our pixel1 value */ \ + "movq %%mm1, %%mm3\n\t" /* another copy of our pixel1 value */ \ + "psubusb %%mm1, %%mm2\n\t" \ + "psubusb %%mm0, %%mm3\n\t" \ + "por %%mm3, %%mm2\n\t" \ +- V_PAVGB("%%mm0", "%%mm1", "%%mm3", MANGLE(ShiftMask)) /* avg of 2 pixels */ \ ++ V_PAVGB("%%mm0", "%%mm1", "%%mm3", _ShiftMask) /* avg of 2 pixels */ \ + "movq %%mm2, %%mm3\n\t" /* another copy of our our weights */ \ + "pxor %%mm1, %%mm1\n\t" \ + "psubusb %%mm7, %%mm3\n\t" /* nonzero where old weights lower, else 0 */ \ +@@ -164,7 +164,7 @@ + "por %%mm0, %%mm5\n\t" /* and merge new & old vals */ \ + "por %%mm2, %%mm7\n\t" + +-#define RESET_CHROMA "por "MANGLE(UVMask)", %%mm7\n\t" ++#define RESET_CHROMA "por "_UVMask", %%mm7\n\t" + + #endif + diff --git a/media-libs/xine-lib/xine-lib-1.1.16.3-r2.ebuild b/media-libs/xine-lib/xine-lib-1.1.16.3-r2.ebuild new file mode 100644 index 000000000000..d2ecd8630294 --- /dev/null +++ b/media-libs/xine-lib/xine-lib-1.1.16.3-r2.ebuild @@ -0,0 +1,186 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-libs/xine-lib/xine-lib-1.1.16.3-r2.ebuild,v 1.1 2009/10/20 01:54:20 gengor Exp $ + +EAPI=1 + +inherit autotools eutils flag-o-matic toolchain-funcs multilib + +# This should normally be empty string, unless a release has a suffix. +if [[ "${P/_pre/}" != "${P}" ]]; then + SRC_URI="mirror://gentoo/${P}.tar.bz2" +else + MY_PKG_SUFFIX="" + MY_P="${PN}-${PV/_/-}${MY_PKG_SUFFIX}" + S="${WORKDIR}/${MY_P}" + + SRC_URI="mirror://sourceforge/xine/${MY_P}.tar.bz2" +fi + +DESCRIPTION="Core libraries for Xine movie player" +HOMEPAGE="http://xine.sourceforge.net" + +LICENSE="GPL-2" +SLOT="1" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86 ~x86-fbsd" + +IUSE="-aalib -libcaca -arts esd win32codecs nls +css +X directfb +vorbis +alsa +gnome sdl speex +theora ipv6 altivec opengl aac -fbcon +xv xvmc +-samba dxr3 vidix mng -flac -oss +v4l xinerama vcd +a52 +mad -imagemagick +dts ++modplug -gtk pulseaudio -mmap -truetype wavpack +musepack +xcb -jack +-real +vis" + +RDEPEND="X? ( x11-libs/libXext + x11-libs/libX11 ) + xv? ( x11-libs/libXv ) + xvmc? ( x11-libs/libXvMC ) + xinerama? ( x11-libs/libXinerama ) + win32codecs? ( >=media-libs/win32codecs-0.50 ) + esd? ( media-sound/esound ) + css? ( >=media-libs/libdvdcss-1.2.7 ) + arts? ( kde-base/arts ) + alsa? ( media-libs/alsa-lib ) + aalib? ( media-libs/aalib ) + directfb? ( >=dev-libs/DirectFB-0.9.9 ) + gnome? ( >=gnome-base/gnome-vfs-2.0 ) + flac? ( >=media-libs/flac-1.1.2 ) + sdl? ( >=media-libs/libsdl-1.1.5 ) + dxr3? ( >=media-libs/libfame-0.9.0 ) + vorbis? ( media-libs/libogg media-libs/libvorbis ) + theora? ( media-libs/libogg media-libs/libvorbis >=media-libs/libtheora-1.0_alpha6 ) + speex? ( media-libs/libogg media-libs/libvorbis media-libs/speex ) + libcaca? ( >=media-libs/libcaca-0.99_beta14 ) + samba? ( net-fs/samba ) + mng? ( media-libs/libmng ) + vcd? ( media-video/vcdimager ) + a52? ( >=media-libs/a52dec-0.7.4-r5 ) + mad? ( media-libs/libmad ) + imagemagick? ( media-gfx/imagemagick ) + dts? ( media-libs/libdca ) + aac? ( >=media-libs/faad2-2.6.1 ) + >=media-video/ffmpeg-0.4.9_p20070129 + modplug? ( media-libs/libmodplug ) + nls? ( virtual/libintl ) + gtk? ( =x11-libs/gtk+-2* ) + pulseaudio? ( media-sound/pulseaudio ) + truetype? ( =media-libs/freetype-2* media-libs/fontconfig ) + virtual/libiconv + wavpack? ( >=media-sound/wavpack-4.31 ) + musepack? ( media-libs/libmpcdecsv7 ) + xcb? ( >=x11-libs/libxcb-1.0 ) + jack? ( >=media-sound/jack-audio-connection-kit-0.100 ) + real? ( + x86? ( media-libs/win32codecs ) + x86-fbsd? ( media-libs/win32codecs ) + amd64? ( media-libs/amd64codecs ) )" + +DEPEND="${RDEPEND} + X? ( x11-libs/libXt + x11-proto/xproto + x11-proto/videoproto + x11-proto/xf86vidmodeproto + xinerama? ( x11-proto/xineramaproto ) ) + v4l? ( virtual/os-headers ) + dev-util/pkgconfig + sys-devel/libtool + nls? ( sys-devel/gettext )" + +src_unpack() { + unpack ${A} + cd "${S}" + rm -f ltmain.sh m4/{libtool,lt*}.m4 || die "libtool patch failed" + epatch "${FILESDIR}"/${P}-libmpcdecsv7.patch + # Bug 164425 + epatch "${FILESDIR}"/${PN}-1.1.15-textrel-fix.patch + eautoreconf +} + +src_compile() { + #prevent quicktime crashing + append-flags -frename-registers -ffunction-sections + + # Specific workarounds for too-few-registers arch... + if [[ $(tc-arch) == "x86" ]]; then + filter-flags -fforce-addr + filter-flags -momit-leaf-frame-pointer # break on gcc 3.4/4.x + filter-flags -fno-omit-frame-pointer #breaks per bug #149704 + is-flag -O? || append-flags -O2 + fi + + # Set the correct win32 dll path, bug #197236 + local win32dir + if has_multilib_profile ; then + win32dir=/usr/$(ABI="x86" get_libdir)/win32 + else + win32dir=/usr/$(get_libdir)/win32 + fi + + # Too many file names are the same (xine_decoder.c), change the builddir + # So that the relative path is used to identify them. + mkdir "${WORKDIR}/build" + + ECONF_SOURCE="${S}" econf \ + $(use_enable gnome gnomevfs) \ + $(use_enable nls) \ + $(use_enable ipv6) \ + $(use_enable samba) \ + $(use_enable altivec) \ + $(use_enable v4l) \ + $(use_enable mng) \ + $(use_with imagemagick) \ + $(use_enable gtk gdkpixbuf) \ + $(use_enable aac faad) --with-external-libfaad \ + $(use_with flac libflac) \ + $(use_with vorbis) \ + $(use_with speex) \ + $(use_with theora) \ + $(use_with wavpack) \ + $(use_enable modplug) \ + $(use_enable a52 a52dec) --with-external-a52dec \ + $(use_enable mad) --with-external-libmad \ + $(use_enable dts) --with-external-libdts \ + $(use_enable musepack) --with-external-libmpcdec \ + $(use_with X x) \ + $(use_enable xinerama) \ + $(use_enable vidix) \ + $(use_enable dxr3) \ + $(use_enable directfb) \ + $(use_enable fbcon fb) \ + $(use_enable opengl) \ + $(use_enable aalib) \ + $(use_with libcaca caca) \ + $(use_with sdl) \ + $(use_enable xvmc) \ + $(use_with xcb) \ + $(use_enable oss) \ + $(use_with alsa) \ + $(use_with arts) \ + $(use_with esd esound) \ + $(use_with pulseaudio) \ + $(use_with jack) \ + $(use_enable vcd) --without-internal-vcdlibs \ + $(use_enable win32codecs w32dll) \ + $(use_enable real real-codecs) \ + $(use_enable mmap) \ + $(use_with truetype freetype) $(use_with truetype fontconfig) \ + $(use_enable vis) \ + --enable-asf \ + --with-external-ffmpeg \ + --disable-optimizations \ + --disable-syncfb \ + --with-xv-path=/usr/$(get_libdir) \ + --with-w32-path=${win32dir} \ + --with-real-codecs-path=/usr/$(get_libdir)/codecs \ + --enable-fast-install \ + --disable-dependency-tracking + + emake || die "emake failed." +} + +src_install() { + emake DESTDIR="${D}" \ + docdir="/usr/share/doc/${PF}" htmldir="/usr/share/doc/${PF}/html" \ + install || die "emake install failed." + + dodoc ChangeLog +} |