From e1a2e4e6ad744a6b28a336de5ff254f6bc86c40d Mon Sep 17 00:00:00 2001 From: Josh Poimboeuf Date: Fri, 3 Mar 2017 10:32:24 -0600 Subject: [PATCH] kpatch-build: make clean_cache() wipe out ~/.kpatch completely When wiping out the ~/.kpatch cache before replacing it with a new kernel source, there's no need to keep anything around. Just wipe it all out and start over. Also, when building with the -s option, it doesn't need to touch ~/.kpatch/version or ~/.kpatch/src, so it can just skip the cleaning. That keeps the previous cache around for the next incantation of kpatch-build without '-s'. --- kpatch-build/kpatch-build | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/kpatch-build/kpatch-build b/kpatch-build/kpatch-build index 8b5bc04..73ecbee 100755 --- a/kpatch-build/kpatch-build +++ b/kpatch-build/kpatch-build @@ -90,8 +90,8 @@ cleanup() { } clean_cache() { - [[ -z $USERSRCDIR ]] && rm -rf "$SRCDIR" - rm -rf "$VERSIONFILE" + rm -rf "$CACHEDIR" + mkdir -p "$TEMPDIR" || die "Couldn't create $TEMPDIR" } check_pipe_status() { @@ -376,8 +376,6 @@ fi if [[ -n "$USERSRCDIR" ]]; then echo "Using source directory at $USERSRCDIR" - clean_cache - # save vmlinux before it gets removed with mrproper [[ "$VMLINUX" -ef "$SRCDIR"/vmlinux ]] && cp -f "$VMLINUX" $TEMPDIR/vmlinux && VMLINUX=$TEMPDIR/vmlinux @@ -390,6 +388,8 @@ else echo "Fedora/Red Hat distribution detected" rpm -q --quiet rpmdevtools || die "rpmdevtools not installed" + clean_cache + echo "Downloading kernel source for $ARCHVERSION" if [[ -z "$SRCRPM" ]]; then if [[ $DISTRO = fedora ]]; then @@ -403,8 +403,6 @@ else echo "Unpacking kernel source" - clean_cache - rpm -D "_topdir $RPMTOPDIR" -ivh "$SRCRPM" >> "$LOGFILE" 2>&1 || die rpmbuild -D "_topdir $RPMTOPDIR" -bp "--target=$(uname -m)" "$RPMTOPDIR"/SPECS/kernel.spec >> "$LOGFILE" 2>&1 || die "rpmbuild -bp failed. you may need to run 'yum-builddep kernel' first." @@ -447,6 +445,8 @@ else pkgver="${KVER}_$(dpkg-query -W -f='${Version}' linux-image-$ARCHVERSION)" pkgname="linux-source-${pkgver}_all" + clean_cache + cd $TEMPDIR echo "Downloading the kernel source for $ARCHVERSION" # Download source deb pkg @@ -456,7 +456,6 @@ else dpkg -x ${pkgname}.deb $TEMPDIR >> "$LOGFILE" || die "dpkg: Could not extract ${pkgname}.deb" # extract and move to SRCDIR tar $taroptions usr/src/linux-source-$KVER.tar.${extension} >> "$LOGFILE" || die "tar: Failed to extract kernel source package" - clean_cache mv linux-source-$KVER "$SRCDIR" || die cp "/boot/config-${ARCHVERSION}" "$SRCDIR/.config" || die if [[ "$ARCHVERSION" == *-* ]]; then