On 10/24/19 10:47 PM, Bhaskar Chowdhury wrote:modified , it will not spit this again.
This patch will remmove old kernel and associated modules directory from
the system.
Few interaction with the script ,below
1) â ~/git-linux/linux-kbuild [master âÂ18|â]
10:40 $ ./scripts/prune-kernel
2)10:41 $ ./scripts/prune-kernel -h
You need to use this script like this :
./scripts/prune-kernel -r kernel_version modules_directory_name
./scripts/prune-kernel -i option for interactive way to use it.
3) 10:41 $ ./scripts/prune-kernel -r 5.2.2 5.2.2-gentoo
Removed kernel version:5.2.2 and modules directory:5.2.2-gentoo from
the system.
4)10:41 $ ./scripts/prune-kernel -i
Want to removing old kernels and modules dir [YN]: Y
Please give another version to remove: 5.2.2
These 2 lines above could (should) be combined into one line. E.g.:
Enter kernel version to remove or blank/emtpy to exit:
/boot/vmlinuz-5.3.7-050307-generic
/boot/vmlinuz-5.3.6-050306-generic
find: â/boot/efiâ: Permission denied
too noisy.
Same as above ...modified and will not spit again.Please give the full modules directory name to remove: 5.2.2-gentoo
5.3.6-050306-generic
5.3.7-050307-generic
too noisy.
Replaced with mentioned word i.e enter.
Removed kernel version:5.2.2 and associated modules:5.2.2-gentoo
..Done.
Signed-off-by: Bhaskar Chowdhury <unixbhaskar@xxxxxxxxx>
---
To Bruce,
I have incorporated all the changes you asked for ,kindly review.
scripts/prune-kernel | 75 +++++++++++++++++++++++++++++++++-----------
1 file changed, 56 insertions(+), 19 deletions(-)
diff --git a/scripts/prune-kernel b/scripts/prune-kernel
index e8aa940bc0a9..292ba70d7770 100755
--- a/scripts/prune-kernel
+++ b/scripts/prune-kernel
@@ -1,21 +1,58 @@
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0
-
-# because I use CONFIG_LOCALVERSION_AUTO, not the same version again and
-# again, /boot and /lib/modules/ eventually fill up.
-# Dumb script to purge that stuff:
-
-for f in "$@"
-do
- if rpm -qf "/lib/modules/$f" >/dev/null; then
- echo "keeping $f (installed from rpm)"
- elif [ $(uname -r) = "$f" ]; then
- echo "keeping $f (running kernel) "
- else
- echo "removing $f"
- rm -f "/boot/initramfs-$f.img" "/boot/System.map-$f"
- rm -f "/boot/vmlinuz-$f" "/boot/config-$f"
- rm -rf "/lib/modules/$f"
- new-kernel-pkg --remove $f
- fi
-done
+#This script will delete old kernels and modules directory related to it interactively.
+#if you choose "-i" as interactive otherwise it will just go ahead and do the stuff once
+#you mentione the kernel_version and modules_directory_name as parameter.
mention
or better:
enter
For interactive use case we need that.+flag=$1
$flag is not used anywhere.
+kernel_ver=$2
remove_old_kernel() uses $kernel_version, not $kernel_ver.
+modules_dir_name=$3
remove_old_modules_dir() uses $modules_version, not $modules_dir_name.
+boot_dir=/boot
+modules_dir=/lib/modules
need a blank line here.Fixed.
Removed.
+remove_old_kernel() {
+ cd $boot_dir
+ find $boot_dir -name "vmlinuz-*" -type f -exec ls -1 {} \;
why the 'ls'? too noisy IMO.Fixed.
+ rm -If vmlinuz-$kernel_version System.map-$kernel_version config-$kernel_version
+ return 0
+}
need a blank line here.
Removed.+remove_old_modules_dir() {
+ cd $modules_dir
+ find $modules_dir -maxdepth 0 -type d -exec ls -1 {} \;
'ls' is too noisy.
It is required, without it , looks like this:
+ rm -rf $modules_version
+ return 0
+}
+while getopts :hir opt;
$opt is not used anywhere.
Yes ..
Does 'getopt's support long option strings? E.g.,
--interactive, --help, --remove.
Certain thing ..this space and tab killing me...how fix these damn thing+do
'do' has a trailing space after it. drop it.
+ case "$1" in
Is $1 the same as $flag here?
Fixed.+ -i | --interactive)
bad indentation above.
Fixed.+ printf "\n\n Want to removing old kernels and modules dir [YN]: %s"
+ read response
+ if [[ $response == "Y" ]];then
+ printf "Please give another version to remove: %s"
+ read kernel_version
+ remove_old_kernel
+ printf "Please give the full modules directory name to remove: %s"
+ read modules_version
+ remove_old_modules_dir
+ printf "\n\n\n Removed kernel version:$kernel_version and associated modules:$modules_version ..Done. \n\n"
+ elif [[ $response == "N" ]];then
+ exit 1
+ fi
+ ;;
+ -h | --help)
bad indentation.
Fixed.+
line above is just a bunch of spaces. bad.
+ printf "You need to use this script like this :\n
use tabs to indent, not spaces.
Fixed.+ $0 -r kernel_version modules_directory_name\n
+ $0 -i option for interactive way to use it.\n\n"
inconsistent indentation.
Fixed.+
line above is just spaces. Empty lines are OK, even good for
readablility, but they should not end with spaces or tabs.
Positional parameter shifting+ exit 1
+ ;;
+ -r | --remove)
+ shift $(( OPTIND - 1 ))
What is the purpose of the shift, when this case ends with exit?
Fixed.+ rm -f kernel_ver
$kernel_ver
Probably need to cd $boot_dir for above 'rm'.
or just rm -f $boot_dir/$kernel_ver
Fixed+ cd $modules_dir
+ rm -rf $modules_dir_name
+ printf "Removed kernel version:$kernel_ver and modules directory:$modules_dir_name from the system.\n\n"
+ exit 0
+ ;;
+ esac
esac indentation does not match case.
Fixed+ done
done indentation does not match do.
Nack.
--Bhaskar
~Randy
Attachment:
signature.asc
Description: PGP signature