mirror of
https://github.com/speed47/spectre-meltdown-checker
synced 2025-01-03 18:15:57 +01:00
chore: speed optimization of hw check and indentation fixes
This commit is contained in:
parent
90c2ae5de2
commit
dc5402b349
@ -851,7 +851,7 @@ pvulnstatus()
|
|||||||
|
|
||||||
case "$opt_batch_format" in
|
case "$opt_batch_format" in
|
||||||
text) _echo 0 "$1: $2 ($3)";;
|
text) _echo 0 "$1: $2 ($3)";;
|
||||||
short) short_output="${short_output}$1 ";;
|
short) short_output="${short_output}$1 ";;
|
||||||
json)
|
json)
|
||||||
case "$2" in
|
case "$2" in
|
||||||
UNK) is_vuln="null";;
|
UNK) is_vuln="null";;
|
||||||
@ -1334,10 +1334,9 @@ is_ucode_blacklisted()
|
|||||||
do
|
do
|
||||||
model=$(echo $tuple | cut -d, -f1)
|
model=$(echo $tuple | cut -d, -f1)
|
||||||
stepping=$(( $(echo $tuple | cut -d, -f2) ))
|
stepping=$(( $(echo $tuple | cut -d, -f2) ))
|
||||||
ucode=$(echo $tuple | cut -d, -f3)
|
|
||||||
echo "$ucode" | grep -q ^0x && ucode_decimal=$(( ucode ))
|
|
||||||
if [ "$cpu_model" = "$model" ] && [ "$cpu_stepping" = "$stepping" ]; then
|
if [ "$cpu_model" = "$model" ] && [ "$cpu_stepping" = "$stepping" ]; then
|
||||||
if [ "$cpu_ucode" = "$ucode_decimal" ] || [ "$cpu_ucode" = "$ucode" ]; then
|
ucode=$(( $(echo $tuple | cut -d, -f3) ))
|
||||||
|
if [ "$cpu_ucode" = "$ucode" ]; then
|
||||||
_debug "is_ucode_blacklisted: we have a match! ($cpu_model/$cpu_stepping/$cpu_ucode)"
|
_debug "is_ucode_blacklisted: we have a match! ($cpu_model/$cpu_stepping/$cpu_ucode)"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
@ -1352,7 +1351,7 @@ is_skylake_cpu()
|
|||||||
# is this a skylake cpu?
|
# is this a skylake cpu?
|
||||||
# return 0 if yes, 1 otherwise
|
# return 0 if yes, 1 otherwise
|
||||||
#if (boot_cpu_data.x86_vendor == X86_VENDOR_INTEL &&
|
#if (boot_cpu_data.x86_vendor == X86_VENDOR_INTEL &&
|
||||||
# boot_cpu_data.x86 == 6) {
|
# boot_cpu_data.x86 == 6) {
|
||||||
# switch (boot_cpu_data.x86_model) {
|
# switch (boot_cpu_data.x86_model) {
|
||||||
# case INTEL_FAM6_SKYLAKE_MOBILE:
|
# case INTEL_FAM6_SKYLAKE_MOBILE:
|
||||||
# case INTEL_FAM6_SKYLAKE_DESKTOP:
|
# case INTEL_FAM6_SKYLAKE_DESKTOP:
|
||||||
@ -1410,26 +1409,24 @@ is_latest_known_ucode()
|
|||||||
# 0: yes, 1: no, 2: unknown
|
# 0: yes, 1: no, 2: unknown
|
||||||
parse_cpu_details
|
parse_cpu_details
|
||||||
ucode_latest="latest microcode version for your CPU model is unknown"
|
ucode_latest="latest microcode version for your CPU model is unknown"
|
||||||
if ! is_intel && ! is_amd; then
|
# cpuid,version,date
|
||||||
|
if is_intel; then
|
||||||
|
cpu_brand_prefix=I
|
||||||
|
elif is_amd; then
|
||||||
|
cpu_brand_prefix=A
|
||||||
|
else
|
||||||
return 2
|
return 2
|
||||||
fi
|
fi
|
||||||
# cpuid,version,date
|
for tuple in $(read_mcedb | grep "$(printf "^$cpu_brand_prefix,0x%08X," "$cpu_cpuid")")
|
||||||
for tuple in $(read_mcedb)
|
|
||||||
do
|
do
|
||||||
cpu_brand=$( echo "$tuple" | cut -d, -f1)
|
ucode=$(( $(echo "$tuple" | cut -d, -f3) ))
|
||||||
is_intel && [ "$cpu_brand" != I ] && continue
|
ucode_date=$(echo "$tuple" | cut -d, -f4 | sed -r 's=(....)(..)(..)=\1/\2/\3=')
|
||||||
is_amd && [ "$cpu_brand" != A ] && continue
|
_debug "is_latest_known_ucode: with cpuid $cpu_cpuid has ucode $cpu_ucode, last known is $ucode from $ucode_date"
|
||||||
cpuid_decimal=$(( $(echo "$tuple" | cut -d, -f2) ))
|
ucode_latest=$(printf "latest version is 0x%x dated $ucode_date according to $mcedb_info" "$ucode")
|
||||||
ucode_decimal=$(( $(echo "$tuple" | cut -d, -f3) ))
|
if [ "$cpu_ucode" -ge "$ucode" ]; then
|
||||||
ucode_date=$( echo "$tuple" | cut -d, -f4)
|
return 0
|
||||||
if [ "$cpuid_decimal" = "$cpu_cpuid" ]; then
|
else
|
||||||
_debug "is_latest_known_ucode: with cpuid $cpu_cpuid has ucode $cpu_ucode, last known is $cpuid_decimal from $ucode_date"
|
return 1
|
||||||
ucode_latest=$(printf "latest version is 0x%x dated $ucode_date according to $mcedb_info" "$ucode_decimal")
|
|
||||||
if [ "$cpu_ucode" -ge "$ucode_decimal" ]; then
|
|
||||||
return 0
|
|
||||||
else
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
_debug "is_latest_known_ucode: this cpuid is not referenced ($cpu_cpuid)"
|
_debug "is_latest_known_ucode: this cpuid is not referenced ($cpu_cpuid)"
|
||||||
@ -1637,7 +1634,7 @@ if [ -e "$opt_kernel" ]; then
|
|||||||
if ! which "${opt_arch_prefix}readelf" >/dev/null 2>&1; then
|
if ! which "${opt_arch_prefix}readelf" >/dev/null 2>&1; then
|
||||||
_debug "readelf not found"
|
_debug "readelf not found"
|
||||||
kernel_err="missing '${opt_arch_prefix}readelf' tool, please install it, usually it's in the 'binutils' package"
|
kernel_err="missing '${opt_arch_prefix}readelf' tool, please install it, usually it's in the 'binutils' package"
|
||||||
elif [ "$opt_sysfs_only" = 1 ]; then
|
elif [ "$opt_sysfs_only" = 1 ] || [ "$opt_hw_only" = 1 ]; then
|
||||||
kernel_err='kernel image decompression skipped'
|
kernel_err='kernel image decompression skipped'
|
||||||
else
|
else
|
||||||
extract_kernel "$opt_kernel"
|
extract_kernel "$opt_kernel"
|
||||||
|
Loading…
Reference in New Issue
Block a user