- change disk usage handling to take hardlinks into account
[bnc#720150] OBS-URL: https://build.opensuse.org/package/show/Base:System/rpm?expand=0&rev=439
This commit is contained in:
parent
6ba1111188
commit
87becdafd6
@ -1,81 +0,0 @@
|
|||||||
#! /bin/bash
|
|
||||||
|
|
||||||
IFS=$'\n'
|
|
||||||
|
|
||||||
is_opensuse=false
|
|
||||||
|
|
||||||
if test "$1" = "--opensuse"; then
|
|
||||||
if test "$2" -gt 0; then
|
|
||||||
is_opensuse=true
|
|
||||||
fi
|
|
||||||
shift 2
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! $is_opensuse; then
|
|
||||||
trap 'rm -f "$tmp"' EXIT
|
|
||||||
tmp=$(mktemp)
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
while read f; do
|
|
||||||
test -e "$f" || continue
|
|
||||||
is_module=""
|
|
||||||
case "$f" in
|
|
||||||
*.debug)
|
|
||||||
continue
|
|
||||||
;;
|
|
||||||
*/boot/vmlinu[xz]-*)
|
|
||||||
flavor=${f##*/vmlinu[xz]-}
|
|
||||||
flavor=${flavor%.gz}
|
|
||||||
echo "kernel-uname-r = $flavor"
|
|
||||||
version=${flavor}
|
|
||||||
flavor=${flavor##*-}
|
|
||||||
;;
|
|
||||||
*/lib/modules/*/*.ko | */lib/modules/*/*.ko.gz | */boot/vmlinu[xz]*)
|
|
||||||
is_module="1"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
continue
|
|
||||||
esac
|
|
||||||
if $is_opensuse; then
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
unzip=false
|
|
||||||
case "$f" in
|
|
||||||
*.gz | */boot/vmlinuz*)
|
|
||||||
unzip=true
|
|
||||||
esac
|
|
||||||
if $unzip && gzip -cd "$f" >"$tmp"; then
|
|
||||||
f=$tmp
|
|
||||||
fi
|
|
||||||
if test -z "$flavor" -a -n "$is_module" ; then
|
|
||||||
flavor=$(/sbin/modinfo -F vermagic "$f")
|
|
||||||
flavor=${flavor%% *}
|
|
||||||
version=${flavor}
|
|
||||||
flavor=${flavor##*-}
|
|
||||||
fi
|
|
||||||
if test -z "$flavor"; then
|
|
||||||
echo "warning: cannot determine kernel flavor from $(/sbin/modinfo -F vermagic "$f" 2>&1)" >&2
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
objdir=$(readlink /lib/modules/$version/build)
|
|
||||||
objdir_build=$RPM_BUILD_ROOT$(readlink $RPM_BUILD_ROOT/lib/modules/$version/build)
|
|
||||||
for i in $objdir_build $objdir ; do
|
|
||||||
ksym_provides=$i/scripts/mod/ksym-provides
|
|
||||||
[ -x $ksym_provides ] && break
|
|
||||||
done
|
|
||||||
if [ -x $ksym_provides ] ; then
|
|
||||||
$ksym_provides $flavor $f
|
|
||||||
else
|
|
||||||
major=${version%%.*}
|
|
||||||
sub=${version#*.}
|
|
||||||
sub=${sub%%.*}
|
|
||||||
if [ "$major" -ge 4 -a "$sub" -ge 10 ] ; then
|
|
||||||
echo "error: cannot determine ksym provides of $f - missing ksym-povides tool." >&2
|
|
||||||
else
|
|
||||||
nm "$f" \
|
|
||||||
| sed -r -ne "s/^0*([0-9a-f]+) A __crc_(.+)/ksym($flavor:\\2) = \\1/p"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done \
|
|
||||||
| sort -u
|
|
@ -1,29 +0,0 @@
|
|||||||
#! /bin/bash
|
|
||||||
|
|
||||||
IFS=$'\n'
|
|
||||||
|
|
||||||
is_opensuse=false
|
|
||||||
|
|
||||||
if test "$1" = "--opensuse"; then
|
|
||||||
if test "$2" -gt 0; then
|
|
||||||
is_opensuse=true
|
|
||||||
fi
|
|
||||||
shift 2
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! $is_opensuse && ! test -e /sbin/modprobe; then
|
|
||||||
cat > /dev/null
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
for f in $(grep -E '/lib/modules/.+\.ko$' | grep -v '/lib/modules/[^/]*/kernel/'); do
|
|
||||||
flavor=${f#*/lib/modules/}
|
|
||||||
flavor=${flavor%%/*}
|
|
||||||
if $is_opensuse; then
|
|
||||||
echo "kernel-uname-r = $flavor"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
flavor=${flavor##*-}
|
|
||||||
/sbin/modprobe --dump-modversions "$f" \
|
|
||||||
| sed -r -ne "s/^0x0*([0-9a-f]+)[[:blank:]]+(.+)/ksym($flavor:\\2) = \\1/p"
|
|
||||||
done | sort -u
|
|
120
findksyms.diff
120
findksyms.diff
@ -1,5 +1,5 @@
|
|||||||
--- ./scripts/Makefile.am.orig 2018-01-31 13:08:32.644956731 +0000
|
--- ./scripts/Makefile.am.orig 2018-02-14 09:42:12.958726157 +0000
|
||||||
+++ ./scripts/Makefile.am 2018-01-31 13:09:24.081819852 +0000
|
+++ ./scripts/Makefile.am 2018-02-14 09:43:26.605515718 +0000
|
||||||
@@ -19,6 +19,7 @@ EXTRA_DIST = \
|
@@ -19,6 +19,7 @@ EXTRA_DIST = \
|
||||||
tgpg vpkg-provides.sh \
|
tgpg vpkg-provides.sh \
|
||||||
find-requires find-provides \
|
find-requires find-provides \
|
||||||
@ -16,3 +16,119 @@
|
|||||||
metainfo.prov \
|
metainfo.prov \
|
||||||
mono-find-requires mono-find-provides \
|
mono-find-requires mono-find-provides \
|
||||||
pkgconfigdeps.sh libtooldeps.sh \
|
pkgconfigdeps.sh libtooldeps.sh \
|
||||||
|
--- ./scripts/find-provides.ksyms.orig 2018-02-14 09:42:54.757606752 +0000
|
||||||
|
+++ ./scripts/find-provides.ksyms 2018-02-14 09:42:39.165651303 +0000
|
||||||
|
@@ -0,0 +1,81 @@
|
||||||
|
+#! /bin/bash
|
||||||
|
+
|
||||||
|
+IFS=$'\n'
|
||||||
|
+
|
||||||
|
+is_opensuse=false
|
||||||
|
+
|
||||||
|
+if test "$1" = "--opensuse"; then
|
||||||
|
+ if test "$2" -gt 0; then
|
||||||
|
+ is_opensuse=true
|
||||||
|
+ fi
|
||||||
|
+ shift 2
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if ! $is_opensuse; then
|
||||||
|
+ trap 'rm -f "$tmp"' EXIT
|
||||||
|
+ tmp=$(mktemp)
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+
|
||||||
|
+while read f; do
|
||||||
|
+ test -e "$f" || continue
|
||||||
|
+ is_module=""
|
||||||
|
+ case "$f" in
|
||||||
|
+ *.debug)
|
||||||
|
+ continue
|
||||||
|
+ ;;
|
||||||
|
+ */boot/vmlinu[xz]-*)
|
||||||
|
+ flavor=${f##*/vmlinu[xz]-}
|
||||||
|
+ flavor=${flavor%.gz}
|
||||||
|
+ echo "kernel-uname-r = $flavor"
|
||||||
|
+ version=${flavor}
|
||||||
|
+ flavor=${flavor##*-}
|
||||||
|
+ ;;
|
||||||
|
+ */lib/modules/*/*.ko | */lib/modules/*/*.ko.gz | */boot/vmlinu[xz]*)
|
||||||
|
+ is_module="1"
|
||||||
|
+ ;;
|
||||||
|
+ *)
|
||||||
|
+ continue
|
||||||
|
+ esac
|
||||||
|
+ if $is_opensuse; then
|
||||||
|
+ continue
|
||||||
|
+ fi
|
||||||
|
+ unzip=false
|
||||||
|
+ case "$f" in
|
||||||
|
+ *.gz | */boot/vmlinuz*)
|
||||||
|
+ unzip=true
|
||||||
|
+ esac
|
||||||
|
+ if $unzip && gzip -cd "$f" >"$tmp"; then
|
||||||
|
+ f=$tmp
|
||||||
|
+ fi
|
||||||
|
+ if test -z "$flavor" -a -n "$is_module" ; then
|
||||||
|
+ flavor=$(/sbin/modinfo -F vermagic "$f")
|
||||||
|
+ flavor=${flavor%% *}
|
||||||
|
+ version=${flavor}
|
||||||
|
+ flavor=${flavor##*-}
|
||||||
|
+ fi
|
||||||
|
+ if test -z "$flavor"; then
|
||||||
|
+ echo "warning: cannot determine kernel flavor from $(/sbin/modinfo -F vermagic "$f" 2>&1)" >&2
|
||||||
|
+ continue
|
||||||
|
+ fi
|
||||||
|
+ objdir=$(readlink /lib/modules/$version/build)
|
||||||
|
+ objdir_build=$RPM_BUILD_ROOT$(readlink $RPM_BUILD_ROOT/lib/modules/$version/build)
|
||||||
|
+ for i in $objdir_build $objdir ; do
|
||||||
|
+ ksym_provides=$i/scripts/mod/ksym-provides
|
||||||
|
+ [ -x $ksym_provides ] && break
|
||||||
|
+ done
|
||||||
|
+ if [ -x $ksym_provides ] ; then
|
||||||
|
+ $ksym_provides $flavor $f
|
||||||
|
+ else
|
||||||
|
+ major=${version%%.*}
|
||||||
|
+ sub=${version#*.}
|
||||||
|
+ sub=${sub%%.*}
|
||||||
|
+ if [ "$major" -ge 4 -a "$sub" -ge 10 ] ; then
|
||||||
|
+ echo "error: cannot determine ksym provides of $f - missing ksym-povides tool." >&2
|
||||||
|
+ else
|
||||||
|
+ nm "$f" \
|
||||||
|
+ | sed -r -ne "s/^0*([0-9a-f]+) A __crc_(.+)/ksym($flavor:\\2) = \\1/p"
|
||||||
|
+ fi
|
||||||
|
+ fi
|
||||||
|
+done \
|
||||||
|
+| sort -u
|
||||||
|
--- ./scripts/find-requires.ksyms.orig 2018-02-14 09:43:00.437590470 +0000
|
||||||
|
+++ ./scripts/find-requires.ksyms 2018-02-14 09:42:45.621632854 +0000
|
||||||
|
@@ -0,0 +1,29 @@
|
||||||
|
+#! /bin/bash
|
||||||
|
+
|
||||||
|
+IFS=$'\n'
|
||||||
|
+
|
||||||
|
+is_opensuse=false
|
||||||
|
+
|
||||||
|
+if test "$1" = "--opensuse"; then
|
||||||
|
+ if test "$2" -gt 0; then
|
||||||
|
+ is_opensuse=true
|
||||||
|
+ fi
|
||||||
|
+ shift 2
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+if ! $is_opensuse && ! test -e /sbin/modprobe; then
|
||||||
|
+ cat > /dev/null
|
||||||
|
+ exit 0
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
+for f in $(grep -E '/lib/modules/.+\.ko$' | grep -v '/lib/modules/[^/]*/kernel/'); do
|
||||||
|
+ flavor=${f#*/lib/modules/}
|
||||||
|
+ flavor=${flavor%%/*}
|
||||||
|
+ if $is_opensuse; then
|
||||||
|
+ echo "kernel-uname-r = $flavor"
|
||||||
|
+ continue
|
||||||
|
+ fi
|
||||||
|
+ flavor=${flavor##*-}
|
||||||
|
+ /sbin/modprobe --dump-modversions "$f" \
|
||||||
|
+ | sed -r -ne "s/^0x0*([0-9a-f]+)[[:blank:]]+(.+)/ksym($flavor:\\2) = \\1/p"
|
||||||
|
+done | sort -u
|
||||||
|
60
hardlinks.diff
Normal file
60
hardlinks.diff
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
--- lib/rpmfiles.h.orig
|
||||||
|
+++ lib/rpmfiles.h
|
||||||
|
@@ -156,7 +156,7 @@ typedef rpmFlags rpmfiFlags;
|
||||||
|
|
||||||
|
#define RPMFI_FLAGS_ERASE \
|
||||||
|
(RPMFI_NOFILECLASS | RPMFI_NOFILELANGS | \
|
||||||
|
- RPMFI_NOFILEMTIMES | RPMFI_NOFILERDEVS | RPMFI_NOFILEINODES | \
|
||||||
|
+ RPMFI_NOFILEMTIMES | RPMFI_NOFILERDEVS | \
|
||||||
|
RPMFI_NOFILEVERIFYFLAGS)
|
||||||
|
|
||||||
|
#define RPMFI_FLAGS_INSTALL \
|
||||||
|
--- lib/transaction.c.orig
|
||||||
|
+++ lib/transaction.c
|
||||||
|
@@ -412,6 +412,8 @@ static void handleInstInstalledFile(const rpmts ts, rpmte p, rpmfiles fi, int fx
|
||||||
|
{
|
||||||
|
rpmfs fs = rpmteGetFileStates(p);
|
||||||
|
int isCfgFile = ((rpmfilesFFlags(otherFi, ofx) | rpmfilesFFlags(fi, fx)) & RPMFILE_CONFIG);
|
||||||
|
+ int nlink;
|
||||||
|
+ const int *links;
|
||||||
|
|
||||||
|
if (XFA_SKIPPING(rpmfsGetAction(fs, fx)))
|
||||||
|
return;
|
||||||
|
@@ -481,7 +483,10 @@ static void handleInstInstalledFile(const rpmts ts, rpmte p, rpmfiles fi, int fx
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- rpmfilesSetFReplacedSize(fi, fx, rpmfilesFSize(otherFi, ofx));
|
||||||
|
+ /* Only account for the last file of a hardlink set */
|
||||||
|
+ nlink = rpmfilesFLinks(otherFi, ofx, &links);
|
||||||
|
+ if (nlink <= 1 || links[nlink - 1] == ofx)
|
||||||
|
+ rpmfilesSetFReplacedSize(fi, fx, rpmfilesFSize(otherFi, ofx));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
@@ -491,6 +496,7 @@ static void handleInstInstalledFile(const rpmts ts, rpmte p, rpmfiles fi, int fx
|
||||||
|
static void handleOverlappedFiles(rpmts ts, fingerPrintCache fpc, rpmte p, rpmfiles fi)
|
||||||
|
{
|
||||||
|
rpm_loff_t fixupSize = 0;
|
||||||
|
+ rpm_loff_t fileSize = 0;
|
||||||
|
int i, j;
|
||||||
|
rpmfs fs = rpmteGetFileStates(p);
|
||||||
|
rpmfs otherFs;
|
||||||
|
@@ -675,9 +681,16 @@ assert(otherFi != NULL);
|
||||||
|
}
|
||||||
|
rpmfilesFree(otherFi);
|
||||||
|
|
||||||
|
+ fileSize = rpmfilesFSize(fi, i);
|
||||||
|
+ nlink = rpmfilesFLinks(fi, i, &links);
|
||||||
|
+ if (nlink > 1 && links[nlink - 1] != i) {
|
||||||
|
+ /* Only account for the last file of a hardlink set */
|
||||||
|
+ fileSize = 0;
|
||||||
|
+ fixupSize = 0;
|
||||||
|
+ }
|
||||||
|
/* Update disk space info for a file. */
|
||||||
|
rpmtsUpdateDSI(ts, fpEntryDev(fpc, fiFps), fpEntryDir(fpc, fiFps),
|
||||||
|
- rpmfilesFSize(fi, i), rpmfilesFReplacedSize(fi, i),
|
||||||
|
+ fileSize, rpmfilesFReplacedSize(fi, i),
|
||||||
|
fixupSize, rpmfsGetAction(fs, i));
|
||||||
|
|
||||||
|
}
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Feb 14 10:45:25 CET 2018 - mls@suse.de
|
||||||
|
|
||||||
|
- change disk usage handling to take hardlinks into account
|
||||||
|
[bnc#720150]
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Feb 7 17:23:48 UTC 2018 - msuchanek@suse.com
|
Wed Feb 7 17:23:48 UTC 2018 - msuchanek@suse.com
|
||||||
|
|
||||||
|
9
rpm.spec
9
rpm.spec
@ -63,8 +63,6 @@ Source10: beecrypt-4.1.2.tar.bz2
|
|||||||
Source11: db-4.8.30.tar.bz2
|
Source11: db-4.8.30.tar.bz2
|
||||||
Source12: baselibs.conf
|
Source12: baselibs.conf
|
||||||
Source13: rpmconfigcheck.service
|
Source13: rpmconfigcheck.service
|
||||||
Source14: find-provides.ksyms
|
|
||||||
Source15: find-requires.ksyms
|
|
||||||
Patch1: beecrypt-4.1.2.diff
|
Patch1: beecrypt-4.1.2.diff
|
||||||
Patch2: db.diff
|
Patch2: db.diff
|
||||||
Patch3: rpm-4.12.0.1-fix-bashisms.patch
|
Patch3: rpm-4.12.0.1-fix-bashisms.patch
|
||||||
@ -132,6 +130,7 @@ Patch103: find-lang-qt-qm.patch
|
|||||||
Patch108: debugedit-macro.diff
|
Patch108: debugedit-macro.diff
|
||||||
Patch109: pythondistdeps.diff
|
Patch109: pythondistdeps.diff
|
||||||
Patch111: debugedit-bnc1076819.diff
|
Patch111: debugedit-bnc1076819.diff
|
||||||
|
Patch112: hardlinks.diff
|
||||||
Patch6464: auto-config-update-aarch64-ppc64le.diff
|
Patch6464: auto-config-update-aarch64-ppc64le.diff
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
#
|
#
|
||||||
@ -228,18 +227,16 @@ rm -f rpmdb/db.h
|
|||||||
%patch -P 85
|
%patch -P 85
|
||||||
%patch -P 93 -P 94 -P 99
|
%patch -P 93 -P 94 -P 99
|
||||||
%patch -P 100 -P 102 -P 103 -P 108
|
%patch -P 100 -P 102 -P 103 -P 108
|
||||||
%patch -P 109 -P 111
|
%patch -P 109 -P 111 -P 112
|
||||||
|
|
||||||
%ifarch aarch64 ppc64le
|
%ifarch aarch64 ppc64le
|
||||||
%patch6464
|
%patch6464
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
cp %{SOURCE14} %{SOURCE15} scripts
|
|
||||||
|
|
||||||
cp config.guess config.sub db/dist/
|
cp config.guess config.sub db/dist/
|
||||||
cp config.guess config.sub beecrypt/
|
cp config.guess config.sub beecrypt/
|
||||||
#chmod 755 scripts/find-supplements{,.ksyms}
|
#chmod 755 scripts/find-supplements{,.ksyms}
|
||||||
chmod 755 scripts/find-provides.ksyms scripts/find-requires.ksyms
|
#chmod 755 scripts/find-provides.ksyms scripts/find-requires.ksyms
|
||||||
#chmod 755 scripts/firmware.prov
|
#chmod 755 scripts/firmware.prov
|
||||||
#chmod 755 scripts/debuginfo.prov
|
#chmod 755 scripts/debuginfo.prov
|
||||||
tar -xjvf %{SOURCE1}
|
tar -xjvf %{SOURCE1}
|
||||||
|
Loading…
Reference in New Issue
Block a user