mirror of
https://github.com/smxi/inxi.git
synced 2025-01-19 00:47:47 +00:00
Added HT, SMP, MCP detection, fixing a bug with core detection
This commit is contained in:
parent
cf162ee55c
commit
55088e4efd
147
inxi
147
inxi
|
@ -1,8 +1,15 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
########################################################################
|
########################################################################
|
||||||
#### Script Name: inxi
|
#### Script Name: inxi
|
||||||
#### version: 0.9
|
#### version: 0.9.1.b2.1
|
||||||
#### Date: December 24 2008
|
#### Date: January 3, 2009
|
||||||
|
########################################################################
|
||||||
|
#### SPECIAL THANKS
|
||||||
|
########################################################################
|
||||||
|
#### Special thanks to all those in lsc for their tireless dedication
|
||||||
|
#### with helping test inxi modules
|
||||||
|
########################################################################
|
||||||
|
#### ABOUT INXI
|
||||||
########################################################################
|
########################################################################
|
||||||
#### inxi is a fork of infobash 3.02, the original bash sys info script by locsmif
|
#### inxi is a fork of infobash 3.02, the original bash sys info script by locsmif
|
||||||
#### As time permits functionality improvements and recoding will occur.
|
#### As time permits functionality improvements and recoding will occur.
|
||||||
|
@ -40,6 +47,12 @@
|
||||||
#### ps;uptime(procps), glxinfo;xdpyinfo;xrandr(xbase-clients)
|
#### ps;uptime(procps), glxinfo;xdpyinfo;xrandr(xbase-clients)
|
||||||
#### Also the proc filesystem should be present and mounted
|
#### Also the proc filesystem should be present and mounted
|
||||||
####
|
####
|
||||||
|
#### Apparently unpatched bash 3.0 has arrays broken; bug reports:
|
||||||
|
#### http://ftp.gnu.org/gnu/bash/bash-3.0-patches/bash30-008
|
||||||
|
#### http://lists.gnu.org/archive/html/bug-bash/2004-08/msg00144.html
|
||||||
|
####
|
||||||
|
#### Arrays work in bash 2.05b, but "egrep -m" does not
|
||||||
|
####
|
||||||
#### RECOMMENDS (Needed to run certain features)
|
#### RECOMMENDS (Needed to run certain features)
|
||||||
#### For local interfaces/IP test: ifconfig (in net-tools for Debian systems)
|
#### For local interfaces/IP test: ifconfig (in net-tools for Debian systems)
|
||||||
#### runlevel(sysvinit): to view current runlevel while not in X window system
|
#### runlevel(sysvinit): to view current runlevel while not in X window system
|
||||||
|
@ -103,6 +116,7 @@ A_AUDIO_DATA=''
|
||||||
A_CMDL=''
|
A_CMDL=''
|
||||||
A_CPU_CORE_DATA=''
|
A_CPU_CORE_DATA=''
|
||||||
A_CPU_DATA=''
|
A_CPU_DATA=''
|
||||||
|
A_CPU_TYPE_PCNT_CCNT=''
|
||||||
A_DEBUG_BUFFER=''
|
A_DEBUG_BUFFER=''
|
||||||
A_GFX_CARD_DATA=''
|
A_GFX_CARD_DATA=''
|
||||||
A_GLX_DATA=''
|
A_GLX_DATA=''
|
||||||
|
@ -174,6 +188,7 @@ DIR_LSB_RELEASE='/etc/lsb-release'
|
||||||
DIR_SCSI='/proc/scsi/scsi'
|
DIR_SCSI='/proc/scsi/scsi'
|
||||||
DIR_MODULES='/proc/modules' #
|
DIR_MODULES='/proc/modules' #
|
||||||
DIR_PARTITIONS='/proc/partitions' #
|
DIR_PARTITIONS='/proc/partitions' #
|
||||||
|
DIR_IFCONFIG='/sbin/ifconfig'
|
||||||
|
|
||||||
### Variable initializations: constants
|
### Variable initializations: constants
|
||||||
DCOPOBJ="default"
|
DCOPOBJ="default"
|
||||||
|
@ -287,19 +302,21 @@ fi
|
||||||
########################################################################
|
########################################################################
|
||||||
main()
|
main()
|
||||||
{
|
{
|
||||||
|
|
||||||
init
|
|
||||||
# first two functions must be set first for colors etc. Remember, no debugger
|
# first two functions must be set first for colors etc. Remember, no debugger
|
||||||
# stuff works on these first two functions unless you set the debugging flag
|
# stuff works on these first two functions unless you set the debugging flag
|
||||||
# manually. Debugging flag -@ [number] will not work until get_parameters runs.
|
# manually. Debugging flag -@ [number] will not work until get_parameters runs.
|
||||||
set_calculated_variables
|
set_calculated_variables
|
||||||
|
|
||||||
|
# initialize some booleans
|
||||||
|
init
|
||||||
|
|
||||||
## this needs to run before the KONVI stuff is set below
|
## this needs to run before the KONVI stuff is set below
|
||||||
get_start_client
|
get_start_client
|
||||||
|
|
||||||
# Check for dependencies before running anything else except above functions
|
# Check for dependencies before running anything else except above functions
|
||||||
check_script_depends
|
check_script_depends
|
||||||
check_script_suggested_apps
|
check_script_suggested_apps
|
||||||
|
discover_ht_multicore_smp_cpu_data
|
||||||
|
|
||||||
# note: this only works if it's run from inside konversation as a script builtin or something
|
# note: this only works if it's run from inside konversation as a script builtin or something
|
||||||
# only do this if inxi has been started as a konversation script, otherwise bypass this
|
# only do this if inxi has been started as a konversation script, otherwise bypass this
|
||||||
|
@ -357,6 +374,7 @@ exit 0
|
||||||
|
|
||||||
# initialize some boleans, these directories are used throughout the script
|
# initialize some boleans, these directories are used throughout the script
|
||||||
# some apps are used for extended functions
|
# some apps are used for extended functions
|
||||||
|
# any directory used, should be checked here first
|
||||||
init()
|
init()
|
||||||
{
|
{
|
||||||
if [[ -d "/proc/" ]];then
|
if [[ -d "/proc/" ]];then
|
||||||
|
@ -390,19 +408,24 @@ init()
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# lack of ifconfig will throw an error only upon it's usage
|
# lack of ifconfig will throw an error only upon it's usage
|
||||||
if [[ -x ifconfig ]];then
|
if [[ -x ifconfig ]]; then
|
||||||
B_IFCONFIG='true'
|
B_IFCONFIG='true'
|
||||||
|
DIR_IFCONFIG='ifconfig' # change from full path to use $PATH
|
||||||
|
elif [[ -x "$DIR_IFCONFIG" ]];then
|
||||||
|
B_IFCONFIG='true'
|
||||||
|
else
|
||||||
|
A_INTERFACES_DATA=( "Interfaces tool requires missing app: $DIR_IFCONFIG" )
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -n $DISPLAY ]];then
|
if [[ -n $DISPLAY ]];then
|
||||||
B_X_RUNNING='true'
|
B_X_RUNNING='true'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -e $DIR_MODULES ]];then
|
if [[ -e "$DIR_MODULES" ]];then
|
||||||
B_MODULES_DIR='true'
|
B_MODULES_DIR='true'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -e $DIR_PARTITIONS ]];then
|
if [[ -e "$DIR_PARTITIONS" ]];then
|
||||||
B_PARTITIONS_DIR='true'
|
B_PARTITIONS_DIR='true'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -417,10 +440,10 @@ check_script_suggested_apps()
|
||||||
# bash version 3.0 is used in Puppy Linux
|
# bash version 3.0 is used in Puppy Linux
|
||||||
# versions older than 3.1 don't handle arrays
|
# versions older than 3.1 don't handle arrays
|
||||||
# distro's using below 2.05b are unknown, released in 2002
|
# distro's using below 2.05b are unknown, released in 2002
|
||||||
if [[ ${bash_array_test[1]} == "two" ]];then
|
if [[ ${bash_array_test[1]} -eq "two" ]];then
|
||||||
B_BASH_ARRAY='true'
|
B_BASH_ARRAY='true'
|
||||||
else
|
else
|
||||||
script_debugger "Suggestion: Bash v3.1 for optimal inxi output"
|
script_debugger "Suggestion: update to Bash v3.1 for optimal inxi output"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
@ -1348,6 +1371,89 @@ get_audio_alsa_data()
|
||||||
echo "$alsa_data"
|
echo "$alsa_data"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
## this is for counting processors and finding HT types
|
||||||
|
discover_ht_multicore_smp_cpu_data()
|
||||||
|
{
|
||||||
|
|
||||||
|
# in /proc/cpuinfo
|
||||||
|
# if > 1 processor && processor id == core id then Hyperthreaded (HT)
|
||||||
|
# if > 1 processor && different processor ids then Multiple Processors (SMP)
|
||||||
|
# if > 1 processor && processor id != core id then Multi-Core Processors (MCP)
|
||||||
|
# if = 1 processor then single core/processor Uni-Processor (UP)
|
||||||
|
|
||||||
|
if [[ $B_CPUINFO == 'true' ]]; then
|
||||||
|
{
|
||||||
|
A_CPU_TYPE_PCNT_CCNT=( $(gawk '
|
||||||
|
BEGIN { FS=": "; i = 0 } {IGNORECASE = 1}
|
||||||
|
/^processor/ { num_of_processors = $NF + 1 } # counts logical processors, both HT and physical
|
||||||
|
/^cpu cores/ { num_of_cores = $NF } # counts physical cores
|
||||||
|
/^physical/ { physical_id[i] = $NF } # array of physical cpus ids
|
||||||
|
/^core id/ { core_id[i] = $NF; i++ } # array of core ids
|
||||||
|
{
|
||||||
|
processors = 1
|
||||||
|
cores = 1 # single cores are obviously a Uni-processor
|
||||||
|
type = "UP"
|
||||||
|
cpu_temp = 0
|
||||||
|
core_temp = 0
|
||||||
|
|
||||||
|
# look for the largest id number, and assign it
|
||||||
|
for ( j = 0; j <= num_of_processors; j++)
|
||||||
|
{
|
||||||
|
if ( physical[j] > cpu_temp )
|
||||||
|
{
|
||||||
|
cpu_temp = physical[j]
|
||||||
|
}
|
||||||
|
if ( core_id[j] > core_temp )
|
||||||
|
{
|
||||||
|
core_temp = core_id[j]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
physical_cpu_count = cpu_temp + 1
|
||||||
|
core_count = core_temp + 1
|
||||||
|
|
||||||
|
# looking at logical processor counts over 1, which means either HT, SMP or MCP
|
||||||
|
if ( num_of_processors > 1 )
|
||||||
|
{
|
||||||
|
if ( physical_cpu_count == 1 )
|
||||||
|
{
|
||||||
|
if ( physical_cpu_count == core_count )
|
||||||
|
{
|
||||||
|
type = "HT" # this is more than likely a P4 w/HT or an Atom 270
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( core_count == num_of_cores && core_count == num_of_processors)
|
||||||
|
{
|
||||||
|
type = "MCP"
|
||||||
|
cores = core_count
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
type = "HT" # this is i7 or Atom 330
|
||||||
|
cores = core_count
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
type = "SMP"
|
||||||
|
processors = physical_cpu_count
|
||||||
|
|
||||||
|
if ( num_of_cores > 1 )
|
||||||
|
{
|
||||||
|
type = "SMPMC" # processors could be both MCP and SMP
|
||||||
|
cores = core_count
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
END { print type " " processors " " cores }
|
||||||
|
' $DIR_CPUINFO ))
|
||||||
|
}
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
## create A_CPU_CORE_DATA, currently with two values: integer core count; core string text
|
## create A_CPU_CORE_DATA, currently with two values: integer core count; core string text
|
||||||
## return value cpu core count string, this helps resolve the multi redundant lines of old style output
|
## return value cpu core count string, this helps resolve the multi redundant lines of old style output
|
||||||
get_cpu_core_count()
|
get_cpu_core_count()
|
||||||
|
@ -1355,17 +1461,8 @@ get_cpu_core_count()
|
||||||
if [[ $B_CPUINFO == 'true' ]]; then
|
if [[ $B_CPUINFO == 'true' ]]; then
|
||||||
## Because of the upcoming release of cpus with core counts over 6, a count of cores is given after Deca (10)
|
## Because of the upcoming release of cpus with core counts over 6, a count of cores is given after Deca (10)
|
||||||
# count the number of processors given
|
# count the number of processors given
|
||||||
local cpu_core_count=$(grep -ic "cpu cores" $DIR_CPUINFO| cut -d':' -f2)
|
local cpu_core_count=${A_CPU_TYPE_PCNT_CCNT[2]}
|
||||||
|
local cpu_type=${A_CPU_TYPE_PCNT_CCNT[0]}
|
||||||
if [[ $cpu_core_count -eq 0 ]];then
|
|
||||||
cpu_core_count=$(grep -ic "^processor" $DIR_CPUINFO| cut -d':' -f2)
|
|
||||||
fi
|
|
||||||
local cpu_alpha_count=''
|
|
||||||
|
|
||||||
if [[ $cpu_core_count -lt 2 ]]; then
|
|
||||||
cpu_core_count=1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# match the numberic value to an alpha value
|
# match the numberic value to an alpha value
|
||||||
case $cpu_core_count in
|
case $cpu_core_count in
|
||||||
|
@ -1382,7 +1479,9 @@ get_cpu_core_count()
|
||||||
*) cpu_alpha_count='Multi';;
|
*) cpu_alpha_count='Multi';;
|
||||||
esac
|
esac
|
||||||
# create array, core count integer; core count string
|
# create array, core count integer; core count string
|
||||||
A_CPU_CORE_DATA=( "$cpu_core_count" "$cpu_alpha_count Core" )
|
A_CPU_CORE_DATA=( "$cpu_core_count" "$cpu_alpha_count Core $cpu_type" )
|
||||||
|
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
## main cpu data collector
|
## main cpu data collector
|
||||||
|
@ -1793,7 +1892,7 @@ get_hdd_data_basic()
|
||||||
# final item is the total of the disk
|
# final item is the total of the disk
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
|
|
||||||
if [[ B_PARTITIONS_DIR == 'true' ]];then
|
if [[ $B_PARTITIONS_DIR == 'true' ]];then
|
||||||
A_HDD_DATA=( $( gawk -v hddused="$hdd_used" '
|
A_HDD_DATA=( $( gawk -v hddused="$hdd_used" '
|
||||||
/[hs]d[a-z]$/ {
|
/[hs]d[a-z]$/ {
|
||||||
driveSize = $(NF - 1)*1024/1000**3
|
driveSize = $(NF - 1)*1024/1000**3
|
||||||
|
@ -2073,7 +2172,7 @@ get_networking_local_ip_data()
|
||||||
{
|
{
|
||||||
if [[ $B_IFCONFIG == 'true' ]];then
|
if [[ $B_IFCONFIG == 'true' ]];then
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
A_INTERFACES_DATA=( $( ifconfig | gawk '
|
A_INTERFACES_DATA=( $( $DIR_IFCONFIG | gawk '
|
||||||
BEGIN { IGNORECASE=1 }
|
BEGIN { IGNORECASE=1 }
|
||||||
$0 !~ /^lo/ {
|
$0 !~ /^lo/ {
|
||||||
# not clear on why inet is coming through, but this gets rid of it
|
# not clear on why inet is coming through, but this gets rid of it
|
||||||
|
@ -2109,8 +2208,6 @@ get_networking_local_ip_data()
|
||||||
}
|
}
|
||||||
}') )
|
}') )
|
||||||
IFS="$ORIGINAL_IFS"
|
IFS="$ORIGINAL_IFS"
|
||||||
else
|
|
||||||
A_INTERFACES_DATA=( "Interfaces tool requires missing app: ifconfig" )
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue