Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/CISOfy/lynis.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormboelen <michael@cisofy.com>2014-10-14 12:03:29 +0400
committermboelen <michael@cisofy.com>2014-10-14 12:03:29 +0400
commit4fa5139bfa9e8188c99e80fe054d552123983573 (patch)
tree72eded8d3138b149ac246f6e72a8f2125ceda455
parentf5399981c21c32fbb9e2ab54170f26be99308722 (diff)
Improve function to search for kernels on disk and checking results
-rw-r--r--include/tests_kernel15
1 files changed, 8 insertions, 7 deletions
diff --git a/include/tests_kernel b/include/tests_kernel
index 8a81bd67..44839ba2 100644
--- a/include/tests_kernel
+++ b/include/tests_kernel
@@ -490,21 +490,24 @@
logtext "Result: /boot/vmlinuz not on disk, trying to find /boot/vmlinuz*"
# Extra current kernel version and replace dashes to allow numeric sort later on
MYKERNEL=`uname -r | sed 's/\.[a-z].*.//g' | sed 's/-[a-z].*.//g' | sed 's/-/./g'`
+ logtext "Result: using ${MYKERNEL} as my kernel version (stripped)"
FIND=`ls /boot/vmlinuz* 2> /dev/null`
if [ ! "${FIND}" = "" ]; then
# Display kernels, extract version numbers and sort them numeric per column (up to 6 numbers)
KERNELS=`ls /boot/vmlinuz* | sed 's/vmlinuz-//' | sed 's/\.[a-z].*.//g' | sed 's/-[a-z].*.//g' | sed 's./boot/..' | sed 's/-/./g' | sort -n -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 -k6,6 -t \.`
-
elif [ ! `ls /boot/kernel* 2> /dev/null` = "" ]; then
-
# Display kernels, extract version numbers and sort them numeric per column (up to 6 numbers)
# Examples:
# /boot/kernel-genkernel-x86_64-3.14.14-gentoo
KERNELS=`ls /boot/kernel* | awk -F- '{ if ($2=="genkernel") { print $4 }}' | grep "^[0-9]" | sort -n -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 -k6,6 -t \.`
- logtext "Result: using ${MYKERNEL} as my kernel version (stripped)"
+ else
+ ReportException "${TEST_NO}:2" "Can not find any vmlinuz or kernel files in /boot, which is unexpected"
+ fi
+ if [ ! "${KERNELS}" = "" ]; then
FOUND_KERNEL=0
for I in ${KERNELS}; do
- if [ ${FOUND_KERNEL} -eq 1 ]; then
+ # Check if we already found a kernel and it is not equal to what we run (e.g. double versions may exist)
+ if [ ${FOUND_KERNEL} -eq 1 -a ! "${MYKERNEL}" = "${I}" ]; then
logtext "Result: found a kernel (${I}) later than running one (${MYKERNEL})"
REBOOT_NEEDED=1
fi
@@ -525,9 +528,7 @@
REBOOT_NEEDED=0
fi
fi
- else
- ReportException "${TEST_NO}:2" "Can not find any vmlinuz or kernel files in /boot, which is unexpected"
- fi
+ fi
fi
# No files in /boot
else