Release new version 0.11.0
[grml-hwinfo.git] / grml-hwinfo
index 7643523..67cfac5 100755 (executable)
@@ -12,7 +12,7 @@
 
 # variables
 UNAME="$(uname -r)"
-PN="$(basename $0)"
+PN="$(basename "$0")"
 [ -n "$WORKING_DIR" -a -d "$WORKING_DIR" ] || WORKING_DIR=$(pwd)
 VERSION='***UNRELEASED***'
 
@@ -101,11 +101,11 @@ done
 # Generate output/temporary directory name & path, and output file path
 [ -n "$OUTDIRNAME" ] || OUTDIRNAME="grml-hwinfo-${DATE}"
 OUTDIR="${WORKING_DIR}/${OUTDIRNAME}"
-mkdir "${OUTDIR}" || { echo 'Directory "'${OUTDIR}'" already exists, aborting.'>&2 ; exit 1; }
+mkdir "${OUTDIR}" || { echo "Directory '${OUTDIR}' already exists, aborting." >&2 ; exit 1; }
 
 if [ -n "$GENERATE_FILE" ] ; then
   [ -n "$OUTFILE" ] && OUTFILE_="$OUTFILE" || OUTFILE_="${OUTDIR}.tar.bz2"
-  [ -e "${OUTFILE_}" ] && { echo 'File "'${OUTFILE_}'" already exists, aborting.'>&2 ; rm -r "${OUTDIR}"; exit 1; }
+  [ -e "${OUTFILE_}" ] && { echo "File '${OUTFILE_}' already exists, aborting." >&2 ; rm -r "${OUTDIR}"; exit 1; }
   OUTFILE=${OUTFILE_}
   touch "${OUTFILE}"
 fi
@@ -121,7 +121,7 @@ exectest() {
     echo 'Usage: exectest <binary>'>&2
     return 1
   else
-    if test -e "$(which $1)" ; then
+    if test -e "$(which "$1")" ; then
       return 0
     else
       grep -q "^$1"'$' missing_tools 2>/dev/null || echo "$1" >> missing_tools
@@ -134,10 +134,10 @@ exectest() {
 # taken from http://cvs.debian.org/fai/lib/disk-info
 diskandsize() {
   local isdisk major minor blocks device suffix
-  while read major minor blocks device suffix; do
+  while read _ _ blocks device _ ; do
     isdisk=1
     # skip ide cdrom
-    [ -f /proc/ide/$device/media ] && grep -q cdrom /proc/ide/$device/media && isdisk=0
+    [ -f "/proc/ide/${device}/media" ] && grep -q cdrom "/proc/ide/${device}/media" && isdisk=0
     [ "$isdisk" -eq 1 ] && echo "$device $blocks"
   done
 }
@@ -145,9 +145,9 @@ diskandsize() {
 list_disks() {
   # print only every second entry; used by disk_info
   i=0
-  for ent in $@; do
+  for ent in "$@" ; do
     if [ "$i" -eq 0 ]; then
-      echo $ent
+      echo "$ent"
       i=1
     else
       i=0
@@ -157,9 +157,9 @@ list_disks() {
 
 disk_info() {
   # the variable holds a space separated list of devices and their block size
-  device_size=`grep -E ' cciss/c.d.$| ida/c.d.$| rd/c.d.$| hd.$| sd.$|/disc$' /proc/partitions | diskandsize`
+  device_size=$(grep -E ' cciss/c.d.$| ida/c.d.$| rd/c.d.$| hd.$| sd.$|/disc$' /proc/partitions | diskandsize)
   # a list of all local disks, without size
-  disklist=`list_disks $device_size`
+  disklist=$(list_disks "$device_size")
 }
 
 
@@ -171,47 +171,66 @@ cd "${OUTDIR}" || exit 1
   echo "This might take a few seconds/minutes. Please be patient..."
 
   # some sysinfo
-  date > date
+  date > ./date
   if [ -r /etc/grml_version ] ; then
      cat /etc/grml_version > grml_version
   fi
   if [ -r /etc/debian_version ] ; then
      cat /etc/debian_version > debian_version
   fi
-  uname -a > uname
+  uname -a > ./uname
 
   # disks / devices
   [ -f /proc/scsi/scsi ] && cat /proc/scsi/scsi > scsi
-  exectest lspci && lspci -nn > lspci
+  exectest lspci && lspci -nn > ./lspci
   cat /proc/partitions > partitions
   find /proc/ide/ -name geometry -exec grep . {} \; > proc_ide 2>/dev/null
-  df -h > df 2>/dev/null
+  df -h > ./df 2>/dev/null
   for i in free lsmod mount lsdev lspnp lsusb ; do
-    exectest $i && $i > $i
+    exectest $i && $i > ./$i
   done
-  swapon -s > swapon 2>swapon.error
+  swapon -s > ./swapon 2>./swapon.error
 
   # proc stuff
   for i in cpuinfo interrupts cmdline devices dma fb iomem ioports \
     mdstat meminfo modules mtrr pci version ; do
     [ -r /proc/$i ] && cat /proc/$i > proc_$i
   done
-  exectest sysdump  && sysdump > sysdump 2>sysdump.error
+  exectest sysdump  && sysdump > ./sysdump 2>./sysdump.error
 
   # log
   dmesg > dmesg.cur
 
   # hwinfo
-  exectest discover && discover -v --type-summary --enable-bus all > discover 2> discover.2
+  exectest discover && discover -v --type-summary --enable-bus all > ./discover 2>./discover.error
   exectest hwinfo   && hwinfo log=hwinfo
-  exectest numactl  && numactl --hardware > numactl
-  exectest x86info  && x86info > x86info 2>x86info.2
-
-  # net stuff
-  exectest ifconfig  && ifconfig -v -a  > ifconfig
-  exectest ip        && ip route show   > ip_route
-  exectest ip        && ip link show    > ip_link
-  exectest route     && route -n        > route
+  exectest numactl  && numactl --hardware > ./numactl
+  exectest x86info  && x86info > ./x86info 2>./x86info.error
+  exectest lscpu    && lscpu > ./lscpu
+
+  # net stuff, net-tools:
+  exectest ifconfig && ifconfig -v -a > ./ifconfig
+  exectest route    && route -n       > ./route
+
+  # net stuff, iproute:
+  exectest ip && ip addrlabel list > ip_addrlabel
+  exectest ip && ip addr show      > ip_addr
+  exectest ip && ip link show      > ip_link
+  exectest ip && ip maddr show     > ip_maddr
+  exectest ip && ip mroute show    > ip_mroute
+  exectest ip && ip mrule show     > ip_mrule
+  exectest ip && ip neigh show     > ip_neigh
+  exectest ip && ip netns list     > ip_netns
+  exectest ip && ip ntable show    > ip_ntable
+  exectest ip && ip route show     > ip_route
+  exectest ip && if [ -r /etc/iproute2/rt_tables ] ; then
+                   grep -v '^#' /etc/iproute2/rt_tables | while read table _ ; do
+                     ip route show table "${table}" > "ip_route_table_${table}"
+                   done
+                 fi
+  exectest ip && ip rule show      > ip_rule
+  exectest ip && ip tunnel show    > ip_tunnel
+  exectest ip && ip tuntap show    > ip_tuntap
 
   # software
   if exectest dpkg ; then
@@ -221,27 +240,34 @@ cd "${OUTDIR}" || exit 1
 
   # power management
   exectest laptop-detect  && laptop-detect >/dev/null 2>/dev/null && echo "0" > laptop_detected
-  exectest acpi_available && acpi_available && cat /proc/acpi/info > acpi_info
-  exectest acpi && acpi > acpi 2> acpi.error && acpi -v > acpi.version
-  [ -r /proc/apm/ ] && apm > apm
+  if [ -r /proc/acpi/info ] ; then
+    cat /proc/acpi/info > acpi_info
+  fi
+
+  exectest acpi && acpi > ./acpi 2>acpi.error && acpi -v > ./acpi.version
+  [ -r /proc/apm/ ] && apm > ./apm
+
+  if exectest mcelog ; then
+    mcelog > ./mcelog 2>./mcelog.error
+  fi
 
   # kernel stuff
   if [ -r /proc/config.gz ] ; then
     zcat /proc/config.gz > kernelconfig
   else
-    [ -r /boot/config-$UNAME ] && cat /boot/config-$UNAME > kernelconfig
+    [ -r "/boot/config-${UNAME}" ] && cat "/boot/config-${UNAME}" > kernelconfig
   fi
 
-  exectest dpkg && COLUMNS=1000 dpkg -l linux-image-$UNAME 2>running_kernel.error \
-           | grep linux-image-$UNAME | tr -s ' ' > running_kernel 2>>running_kernel.error
-  dpkg -S /boot/vmlinuz-$(uname -r) >> running_kernel 2>>running_kernel.error
+  exectest dpkg && COLUMNS=1000 dpkg -l "linux-image-${UNAME}" 2>running_kernel.error \
+           | grep "linux-image-${UNAME}" | tr -s ' ' > running_kernel 2>>running_kernel.error
+  dpkg -S "/boot/vmlinuz-$(uname -r)" >> running_kernel 2>>running_kernel.error
 
   # X stuff
   if [ -n "${DISPLAY}" ] ; then
-    exectest xviddetect  && xviddetect         > xviddetect
-    exectest xvidtune    && xvidtune -show     > xdivtune
-    exectest xrandr      && xrandr             > xrandr
-    exectest xdpyinfo    && xdpyinfo           > xdpyinfo
+    exectest xviddetect  && xviddetect         > ./xviddetect
+    exectest xvidtune    && xvidtune -show     > ./xdivtune
+    exectest xrandr      && xrandr             > ./xrandr
+    exectest xdpyinfo    && xdpyinfo           > ./xdpyinfo
     X -version > x_version 2>&1
   fi
 
@@ -259,33 +285,46 @@ cd "${OUTDIR}" || exit 1
   else
     echo "running as root" > root
     disk_info
-    exectest sfdisk     && sfdisk -d > sfdisk 2>sfdisk.error
-    exectest dmidecode  && dmidecode > dmidecode
+    exectest sfdisk     && sfdisk -d > ./sfdisk 2>./sfdisk.error
+    exectest dmidecode  && dmidecode > ./dmidecode
 
     exectest dconf && dconf -o dconf
 
-    if [ -x /usr/share/doc/lm-sensors/examples/eeprom/decode-dimms.pl ] ; then
+    if exectest mcelog ; then
+      mcelog --dmi > mcelog_dmi 2>mcelog_dmi.error
+    fi
+
+    if exectest edac-util ; then
+      edac-util > ./edac-util 2>./edac-util.error
+      edac-util --report=full > edac-util_report 2>edac-util_report.error
+    fi
+
+    if exectest decode-dimms ; then
+      decode-dimms > ./decode-dimms 2>./decode-dimms.error
+    elif [ -x /usr/share/doc/lm-sensors/examples/eeprom/decode-dimms.pl ] ; then
       /usr/share/doc/lm-sensors/examples/eeprom/decode-dimms.pl > decode-dimms 2>decode-dimms.error
     fi
 
     # proxmox
-    exectest qm && qm list > qm 2>qm.error
+    exectest qm && qm list > ./qm 2>./qm.error
     # libvirt
-    exectest virsh && virsh list >virsh 2>virsh.error
+    exectest virsh && virsh list >./virsh 2>./virsh.error
     # openvz
-    exectest vzlist && vzlist >vzlist 2>vzlist.error
+    exectest vzlist && vzlist >./vzlist 2>./vzlist.error
     # vserver
-    exectest vserver-stat && vserver-stat >vserver-stat 2>vserver-stat.error
+    exectest vserver-stat && vserver-stat >./vserver-stat 2>./vserver-stat.error
 
-    exectest mdadm && mdadm --detail /dev/md[0-9]* >> mdadm 2>mdadm.error
+    exectest mdadm && mdadm --detail /dev/md[0-9]* >> ./mdadm 2>./mdadm.error
 
     # LVM
-    exectest pvs && pvs > pvs 2>pvs.error
-    exectest vgs && vgs > vgs 2>vgs.error
-    exectest lvs && lvs > lvs 2>lvs.error
-    exectest lvdisplay && lvdisplay > lvdisplay 2>lvdisplay.error
+    exectest pvs && pvs > ./pvs 2>./pvs.error
+    exectest vgs && vgs > ./vgs 2>./vgs.error
+    exectest lvs && lvs > ./lvs 2>./lvs.error
+    exectest lvdisplay && lvdisplay > ./lvdisplay 2>./lvdisplay.error
 
     exectest dmsetup && dmsetup ls > dmsetup_ls 2>dmsetup_ls.error
+    exectest dmsetup && dmsetup ls --tree > dmsetup_ls_tree 2>dmsetup_ls_tree.error
+    exectest lsblk && lsblk > ./lsblk 2>./lsblk.error
 
     # iSCSI
     if exectest iscsiadm ; then
@@ -297,47 +336,56 @@ cd "${OUTDIR}" || exit 1
       iscsiadm -m discovery > iscsiadm_discovery 2>iscsiadm_discovery.error
     fi
 
-    exectest lsscsi && lsscsi > lsscsi 2>lsscsi.error
+    if exectest lsscsi ; then
+      lsscsi    > ./lsscsi 2>./lsscsi.error
+      lsscsi -t > ./lsscsi_transport 2>./lsscsi_transport.error
+    fi
 
     for disk in $disklist; do
       if exectest smartctl ; then
         echo -e "smartctl -a /dev/${disk}:\n" >> smartctl
-        smartctl -a /dev/$disk >> smartctl
-        echo -e "\n\n" >> smartctl
+        smartctl -a "/dev/$disk" >> ./smartctl
+        echo -e "\n\n" >> ./smartctl
       fi
 
       if exectest hdparm ; then
         echo -e "hdparm -iv /dev/${disk}:\n" >> hdparm
-        hdparm -iv /dev/$disk >> hdparm
+        hdparm -iv "/dev/$disk" >> ./hdparm
         echo -e "\n\n" >> hdparm
       fi
 
       if exectest fdisk ; then
         echo -e "fdisk -lu /dev/${disk}:\n" >> fdisk
-        fdisk -lu /dev/$disk >>fdisk 2>>fdisk.error
+        fdisk -lu "/dev/$disk" >> ./fdisk 2>> ./fdisk.error
         echo -e "\n\n" >> fdisk
       fi
 
       if exectest parted ; then
         echo -e "parted -s /dev/${disk}:\n" >> parted
-        parted -s /dev/$disk print >> parted
+        parted -s "/dev/$disk" print >> ./parted
         echo -e "\n\n" >> parted
       fi
 
       if exectest sdparm ; then
         echo -e "sdparm --all --long /dev/${disk}:\n" >> sdparm
-        sdparm --all --long /dev/$disk >> sdparm
+        sdparm --all --long "/dev/$disk" >> ./sdparm
         echo -e "\n\n" >> sdparm
       fi
 
-      file -s /dev/$disk?* | grep -v ": empty" >> file_disk
+      if exectest sg_inq ; then
+        echo -e "sg_inq /dev/${disk}:\n" >> sg_inq
+        sg_inq "/dev/$disk" >> ./sg_inq
+        echo -e "\n\n" >> sg_inq
+      fi
+
+      file -s "/dev/${disk}"?* | grep -v ": empty" >> file_disk
     done
   fi
 )
 
 # get rid of empty files
 for file in *.error ; do
-  test -s $file || rm $file
+  test -s "$file" || rm -- "$file"
 done
 
 echo
@@ -347,7 +395,8 @@ cd "${WORKING_DIR}"
 # create tarball
 if [ -n "$GENERATE_FILE" ] ; then
   tar acf "${OUTFILE}" "${OUTDIRNAME}"
-  [ -r "$OUTFILE" ] && echo "$OUTFILE ("$(ls -ahl "$OUTFILE" | awk '{print $5}')") has been generated."
+  # shellcheck disable=SC2012
+  [ -r "$OUTFILE" ] && echo "$OUTFILE ($(ls -ahl -- "$OUTFILE" | awk '{print $5}')) has been generated."
 fi
 
 # remove (temporary) output directory if needed, else keep it, as it doubles