summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CHANGES1
-rw-r--r--scripts/find-debuginfo.sh30
2 files changed, 22 insertions, 9 deletions
diff --git a/CHANGES b/CHANGES
index 53ab1a366..f26c5ca8b 100644
--- a/CHANGES
+++ b/CHANGES
@@ -31,6 +31,7 @@
- flush pipe before exit 1 in check-files (#103867).
- perl.req: avoid regex misfire on '^use' in "= <<" assign (#109934).
- use perldeps {--provides|--requires}.
+ - find-debuginfo.sh: permit stripping unwritable by non-root (#112429).
4.2 -> 4.2.1:
- fix: nested %if handling, optind initialization posix vs. glibc.
diff --git a/scripts/find-debuginfo.sh b/scripts/find-debuginfo.sh
index aa37f8305..15f4c2c60 100644
--- a/scripts/find-debuginfo.sh
+++ b/scripts/find-debuginfo.sh
@@ -9,19 +9,31 @@ fi
LISTFILE=$BUILDDIR/debugfiles.list
SOURCEFILE=$BUILDDIR/debugsources.list
+debugdir="${RPM_BUILD_ROOT}/usr/lib/debug"
+
echo -n > $SOURCEFILE
# Strip ELF binaries
-for f in `find $RPM_BUILD_ROOT -type f \( -perm -0100 -or -perm -0010 -or -perm -0001 \) -exec file {} \; | \
+for f in `find $RPM_BUILD_ROOT -path "${debugdir}" -prune -o -type f \( -perm -0100 -or -perm -0010 -or -perm -0001 \) -exec file {} \; | \
sed -n -e 's/^\(.*\):[ ]*ELF.*, not stripped/\1/p'`
do
- BASEDIR=`dirname $f | sed -n -e "s#^$RPM_BUILD_ROOT#/#p"`
- [ "$BASEDIR" = "/usr/lib/debug" ] && continue;
- OUTPUTDIR=${RPM_BUILD_ROOT}/usr/lib/debug${BASEDIR}
- mkdir -p ${OUTPUTDIR}
+ dn=$(dirname $f | sed -n -e "s#^$RPM_BUILD_ROOT##p")
+ bn=$(basename $f .debug).debug
+
+ debugdn="${debugdir}${dn}"
+ debugfn="${debugdn}/${bn}"
+ [ -f "${debugfn}" ] && continue
+
+ mkdir -p "${debugdn}"
echo extracting debug info from $f
- /usr/lib/rpm/debugedit -b $RPM_BUILD_DIR -d /usr/src/debug -l $SOURCEFILE $f
- eu-strip -f $OUTPUTDIR/`basename $f`.debug $f || :
+ /usr/lib/rpm/debugedit -b "$RPM_BUILD_DIR" -d /usr/src/debug -l "$SOURCEFILE" "$f"
+ if test -w "$f"; then
+ eu-strip -f "${debugfn}" "$f" || :
+ else
+ chmod u+w "$f"
+ eu-strip -f "${debugfn}" "$f" || :
+ chmod u-w "$f"
+ fi
done
mkdir -p ${RPM_BUILD_ROOT}/usr/src/debug
@@ -29,5 +41,5 @@ cat $SOURCEFILE | (cd $RPM_BUILD_DIR; LANG=C sort -z -u | cpio -pd0m ${RPM_BUILD
# stupid cpio creates new directories in mode 0700, fixup
find ${RPM_BUILD_ROOT}/usr/src/debug -type d -print0 | xargs -0 chmod a+rx
-find ${RPM_BUILD_ROOT}/usr/lib/debug -type f | sed -n -e "s#^$RPM_BUILD_ROOT#/#p" > $LISTFILE
-find ${RPM_BUILD_ROOT}/usr/src/debug -mindepth 1 -maxdepth 1 | sed -n -e "s#^$RPM_BUILD_ROOT#/#p" >> $LISTFILE
+find ${RPM_BUILD_ROOT}/usr/lib/debug -type f | sed -n -e "s#^$RPM_BUILD_ROOT##p" > $LISTFILE
+find ${RPM_BUILD_ROOT}/usr/src/debug -mindepth 1 -maxdepth 1 | sed -n -e "s#^$RPM_BUILD_ROOT##p" >> $LISTFILE