New version, tarball. This corrects a case I'm seeing where wayland/mir are running desktop

but Xorg has not started, which means inxi can't get the video driver from Xorg.0.log as with X.

Added in extra data collection from lspci -v to include the driver for graphics card. this is
only used, for now, if the initial Xorg based driver test works.

Note that this may also work for systems that have not yet started X out of X, in console, I'm
not sure about that, but the graphics driver reporting should be improved.

Note that I'm not yet linking the driver to the specific card/device, it's just going to show
in a comma separated list, I couldn't find multi card systems where the card types are different,
like amd gpu with nvidia card, for example.

But this should correct an issue, at least to start, with expanding wayland support for systems
that don't use or have not started the desktop with Xorg/X11 etc.
This commit is contained in:
Harald Hope 2017-07-23 14:40:53 -07:00
parent 705094ed10
commit 33fe10f7ca
2 changed files with 68 additions and 18 deletions

56
inxi
View file

@ -1,8 +1,8 @@
#!/usr/bin/env bash #!/usr/bin/env bash
######################################################################## ########################################################################
#### Script Name: inxi #### Script Name: inxi
#### Version: 2.3.23 #### Version: 2.3.24
#### Date: 2017-06-29 #### Date: 2017-07-23
#### Patch Number: 00 #### Patch Number: 00
######################################################################## ########################################################################
#### SPECIAL THANKS #### SPECIAL THANKS
@ -6323,6 +6323,8 @@ get_graphics_card_data()
IGNORECASE=1 IGNORECASE=1
busId="" busId=""
trueCard="" trueCard=""
card=""
driver=""
} }
# not using 3D controller yet, needs research: |3D controller |display controller # not using 3D controller yet, needs research: |3D controller |display controller
# note: this is strange, but all of these can be either a separate or the same # note: this is strange, but all of these can be either a separate or the same
@ -6330,14 +6332,23 @@ get_graphics_card_data()
# cards are either the same or different. We want only the .0 version as a valid # cards are either the same or different. We want only the .0 version as a valid
# card. .1 would be for example: Display Adapter with bus id x:xx.1, not the right one # card. .1 would be for example: Display Adapter with bus id x:xx.1, not the right one
/vga compatible controller|3D controller|Display controller/ { /vga compatible controller|3D controller|Display controller/ {
trueCard=""
gsub(/'"$BAN_LIST_NORMAL"'/, "", $NF) gsub(/'"$BAN_LIST_NORMAL"'/, "", $NF)
gsub(/'"$BAN_LIST_ARRAY"'/, " ", $NF) gsub(/'"$BAN_LIST_ARRAY"'/, " ", $NF)
gsub(/^ +| +$/, "", $NF) gsub(/^ +| +$/, "", $NF)
gsub(/ [ \t]+/, " ", $NF) gsub(/ [ \t]+/, " ", $NF)
card=$NF
busId=gensub(/^([0-9a-f:\.]+) (.+)$/,"\\1",1,$1) busId=gensub(/^([0-9a-f:\.]+) (.+)$/,"\\1",1,$1)
trueCard=gensub(/(.*)\.([0-9]+)$/,"\\2",1,busId) trueCard=gensub(/(.*)\.([0-9]+)$/,"\\2",1,busId)
while (!/^$/) {
getline
if ( $1 ~ /Kernel driver in use/ ){
driver=$2
}
}
if ( trueCard == 0 ) { if ( trueCard == 0 ) {
print $NF "," busId print card "," busId "," driver
# print card "," busId "," driver > "/dev/tty"
} }
}' <<< "$Lspci_v_Data" ) ) }' <<< "$Lspci_v_Data" ) )
IFS="$ORIGINAL_IFS" IFS="$ORIGINAL_IFS"
@ -12849,9 +12860,9 @@ print_graphics_data()
eval $LOGFS eval $LOGFS
local graphics_data='' card_id='' i='' root_alert='' root_x_string='' a_graphics_working='' local graphics_data='' card_id='' i='' root_alert='' root_x_string='' a_graphics_working=''
local b_is_mesa='false' display_full_string='' card_bus_id='' card_data='' local b_is_mesa='false' display_full_string='' card_bus_id='' card_data=''
local res_tty='Resolution' xorg_data='' display_server_string='' chip_id='' local res_tty='Resolution' xorg_data='' display_server_string='' chip_id='' sep_pci=''
local spacer='' driver='' driver_string='' driver_plural='' direct_render_string='' local spacer='' driver='' driver_string='' driver_plural='' direct_render_string=''
local separator_loaded='' separator_unloaded='' separator_failed='' local sep_loaded='' sep_unloaded='' sep_failed='' b_pci_driver='false'
local loaded='' unloaded='' failed='' display_server_string='' b_force_tty='false' local loaded='' unloaded='' failed='' display_server_string='' b_force_tty='false'
local line_starter='Graphics:' part_1_data='' part_2_data='' b_advanced='true' local line_starter='Graphics:' part_1_data='' part_2_data='' b_advanced='true'
local screen_resolution="$( get_graphics_res_data 'reg' )" local screen_resolution="$( get_graphics_res_data 'reg' )"
@ -12892,7 +12903,8 @@ print_graphics_data()
get_graphics_driver get_graphics_driver
if [[ ${#A_GRAPHIC_DRIVERS[@]} -eq 0 ]];then if [[ ${#A_GRAPHIC_DRIVERS[@]} -eq 0 ]];then
driver=' N/A' driver=''
b_pci_driver='true'
else else
for (( i=0; i < ${#A_GRAPHIC_DRIVERS[@]}; i++ )) for (( i=0; i < ${#A_GRAPHIC_DRIVERS[@]}; i++ ))
do do
@ -12901,16 +12913,16 @@ print_graphics_data()
IFS="$ORIGINAL_IFS" IFS="$ORIGINAL_IFS"
case ${a_graphics_working[1]} in case ${a_graphics_working[1]} in
loaded) loaded)
loaded="$loaded$separator_loaded${a_graphics_working[0]}" loaded="$loaded$sep_loaded${a_graphics_working[0]}"
separator_loaded=',' sep_loaded=','
;; ;;
unloaded) unloaded)
unloaded="$unloaded$separator_unloaded${a_graphics_working[0]}" unloaded="$unloaded$sep_unloaded${a_graphics_working[0]}"
separator_unloaded=',' sep_unloaded=','
;; ;;
failed) failed)
failed="$failed$separator_failed${a_graphics_working[0]}" failed="$failed$sep_failed${a_graphics_working[0]}"
separator_failed=',' sep_failed=','
;; ;;
esac esac
done done
@ -12926,7 +12938,7 @@ print_graphics_data()
fi fi
# sometimes for some reason there is no driver found but the array is started # sometimes for some reason there is no driver found but the array is started
if [[ -z $driver ]];then if [[ -z $driver ]];then
driver=' N/A' b_pci_driver='true'
fi fi
if [[ ${#A_GRAPHIC_DRIVERS[@]} -gt 1 ]];then if [[ ${#A_GRAPHIC_DRIVERS[@]} -gt 1 ]];then
driver_plural='s' driver_plural='s'
@ -12954,8 +12966,6 @@ print_graphics_data()
[[ $display_server == 'wayland' || $display_server == 'mir' ]];then [[ $display_server == 'wayland' || $display_server == 'mir' ]];then
compositor_string="${C1}compositor$SEP3${C2} $compositor " compositor_string="${C1}compositor$SEP3${C2} $compositor "
fi fi
display_server_string="${C1}Display Server${SEP3}${C2} $display_server_string $compositor_string"
driver_string="${C1}driver$driver_plural$SEP3${C2}$driver "
if [[ $glx_renderer == '' && $B_ROOT == 'true' ]];then if [[ $glx_renderer == '' && $B_ROOT == 'true' ]];then
root_x_string='for root ' root_x_string='for root '
@ -12972,7 +12982,6 @@ print_graphics_data()
if [[ $b_force_tty == 'true' || $B_SHOW_DISPLAY_DATA != 'true' || $B_RUNNING_IN_DISPLAY != 'true' ]];then if [[ $b_force_tty == 'true' || $B_SHOW_DISPLAY_DATA != 'true' || $B_RUNNING_IN_DISPLAY != 'true' ]];then
res_tty='tty size' res_tty='tty size'
fi fi
if [[ -n $root_x_string ]];then if [[ -n $root_x_string ]];then
root_x_string="${C1}Advanced Data$SEP3${C2} N/A $root_x_string" root_x_string="${C1}Advanced Data$SEP3${C2} N/A $root_x_string"
fi fi
@ -12985,6 +12994,15 @@ print_graphics_data()
IFS="$ORIGINAL_IFS" IFS="$ORIGINAL_IFS"
card_bus_id='' card_bus_id=''
card_data=${a_graphics_working[0]} card_data=${a_graphics_working[0]}
if [[ $b_pci_driver == 'true' && ${a_graphics_working[2]} != '' ]];then
if [[ $sep_pci == ',' ]];then
driver_plural='s'
else
driver=' ' # front pad to match other matches
fi
driver=$driver$sep_pci${a_graphics_working[2]}
sep_pci=','
fi
if [[ $B_EXTRA_DATA == 'true' ]];then if [[ $B_EXTRA_DATA == 'true' ]];then
if [[ -n ${a_graphics_working[1]} ]];then if [[ -n ${a_graphics_working[1]} ]];then
card_bus_id="${a_graphics_working[1]}" card_bus_id="${a_graphics_working[1]}"
@ -13048,6 +13066,12 @@ print_graphics_data()
fi fi
line_starter=' ' line_starter=' '
graphics_data='' graphics_data=''
if [[ $driver == '' ]];then
driver=' N/A'
fi
display_server_string="${C1}Display Server${SEP3}${C2} $display_server_string $compositor_string"
driver_string="${C1}driver$driver_plural$SEP3${C2}$driver "
part_1_data="$display_server_string$driver_string" part_1_data="$display_server_string$driver_string"
part_2_data="${C1}$res_tty$SEP3${C2} $screen_resolution $root_x_string" part_2_data="${C1}$res_tty$SEP3${C2} $screen_resolution $root_x_string"

View file

@ -1,3 +1,29 @@
=====================================================================================
Version: 2.3.24
Patch Version: 00
Script Date: 2017-07-23
-----------------------------------
Changes:
-----------------------------------
New version, tarball. This corrects a case I'm seeing where wayland/mir are running desktop
but Xorg has not started, which means inxi can't get the video driver from Xorg.0.log as with X.
Added in extra data collection from lspci -v to include the driver for graphics card. this is
only used, for now, if the initial Xorg based driver test works.
Note that this may also work for systems that have not yet started X out of X, in console, I'm
not sure about that, but the graphics driver reporting should be improved.
Note that I'm not yet linking the driver to the specific card/device, it's just going to show
in a comma separated list, I couldn't find multi card systems where the card types are different,
like amd gpu with nvidia card, for example.
But this should correct an issue, at least to start, with expanding wayland support for systems
that don't use or have not started the desktop with Xorg/X11 etc.
-----------------------------------
-- Harald Hope - Sun, 23 Jul 2017 14:35:56 -0700
===================================================================================== =====================================================================================
Version: 2.3.23 Version: 2.3.23
Patch Version: 00 Patch Version: 00