]> git.pld-linux.org Git - packages/adobe-flash.git/commitdiff
- 64bit flash need to be 'patched' to avoid audio problems with glibc 2.13
authorArkadiusz Miśkiewicz <arekm@maven.pl>
Sun, 6 Mar 2011 15:44:11 +0000 (15:44 +0000)
committercvs2git <feedback@pld-linux.org>
Sun, 24 Jun 2012 12:13:13 +0000 (12:13 +0000)
Changed files:
    adobe-flash.spec -> 1.148
    memcpy-to-memmove.sh -> 1.1

adobe-flash.spec
memcpy-to-memmove.sh [new file with mode: 0644]

index aa6cd25ac09d7ecf192c00059fc309c4868f2815..827d16b6a14fc984abb51d023a8f0c382d5eb76f 100644 (file)
@@ -40,6 +40,7 @@ Source2:      mms.cfg
 Source3:       http://svn.pld-linux.org/svn/license-installer/license-installer.sh
 # Source3-md5: 329c25f457fea66ec502b7ef70cb9ede
 %endif
+Source4:       memcpy-to-memmove.sh
 URL:           http://www.adobe.com/products/flashplayer/
 %if %{with license_agreement}
 BuildRequires: rpmbuild(macros) >= 1.357
@@ -93,6 +94,14 @@ if [ "$v" != "$s" ]; then
        : wrong version
        exit 1
 fi
+
+%ifarch %{x8664}
+# Bug #354073: Patch binary to use memmove instead of memcpy from
+# Redhat's bug https://bugzilla.redhat.com/show_bug.cgi?id=638477#c94
+cp libflashplayer.so libflashplayer.so.orig
+/bin/bash %{SOURCE4} libflashplayer.so \
+|| (echo "memcpy-to-memmove.sh failed" && exit 1)
+%endif
 %endif
 
 %install
diff --git a/memcpy-to-memmove.sh b/memcpy-to-memmove.sh
new file mode 100644 (file)
index 0000000..b1632e5
--- /dev/null
@@ -0,0 +1,40 @@
+#!/bin/sh
+# Quick and dirty, but inefficient shellscript that
+# turns all memcpy calls into memmove calls
+# From Ray Strode
+
+set -e
+
+INPUT="$1"
+
+MEMCPY=0x$(objdump -S -j .plt $INPUT | grep memcpy |awk '{ print $1 }')
+[ $MEMCPY = "0x" ] && echo "Can't find memcpy call in $INPUT PLT" 1>&2 && exit 1
+
+MEMMOVE=0x$(objdump -S -j .plt $INPUT | grep memmove |awk '{ print $1 }')
+[ $MEMMOVE = "0x" ] && echo "Can't find memmove call in $INPUT PLT" 1>&2 && exit 2
+
+DELTA=$(($MEMMOVE - $MEMCPY))
+MEMCPY="$(printf '%x' $MEMCPY)"
+
+TEMP_OUTPUT="$(mktemp)"
+trap "rm -f $TEMP_OUTPUT" ERR
+
+cp $INPUT $TEMP_OUTPUT
+objdump -S -j .text $INPUT | while read offset e8 byte1 byte2 byte3 byte4 call call_offset rest; do
+    test "$call_offset" = "$MEMCPY" || continue;
+
+    OFFSET=$(printf "0x%x" $((0x${offset%:} + 1)))
+    NUMBER="0x${byte4}${byte3}${byte2}${byte1}"
+    echo -n "Changing call at offset $OFFSET from [${byte1} ${byte2} ${byte3} ${byte4}]"
+    NUMBER=$(printf "0x%08x" $(($NUMBER + $DELTA)))
+
+    BYTE1=$(printf "%02x" $((($NUMBER >> 24) & 0xff)))
+    BYTE2=$(printf "%02x" $((($NUMBER >> 16) & 0xff)))
+    BYTE3=$(printf "%02x" $((($NUMBER >>  8) & 0xff)))
+    BYTE4=$(printf "%02x" $((($NUMBER >>  0) & 0xff)))
+
+    echo " to [${BYTE4} ${BYTE3} ${BYTE2} ${BYTE1}]"
+    echo -ne "\x$BYTE4\x$BYTE3\x$BYTE2\x$BYTE1" | dd of=$TEMP_OUTPUT bs=1 seek=$(($OFFSET)) count=4 conv=notrunc 2> /dev/null
+done
+
+mv $TEMP_OUTPUT $INPUT
This page took 0.080506 seconds and 4 git commands to generate.