X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=grml-hwinfo;h=72f79c0ae6f6891493633de0ce833c7401dac68c;hb=d116a7a066ded40f839b9d24d181c6e6cc933fad;hp=406f9b78776892fe5c3486fef591ca3a5f6fc76a;hpb=fb0e3560121d35f1b430a3cf3fd93a2f7b920d6a;p=grml-hwinfo.git diff --git a/grml-hwinfo b/grml-hwinfo index 406f9b7..72f79c0 100755 --- a/grml-hwinfo +++ b/grml-hwinfo @@ -112,7 +112,12 @@ fi # Generate output/temporary directory name & path, and output file path [ -n "$OUTDIRNAME" ] || OUTDIRNAME="grml-hwinfo-${DATE}" -OUTDIR="${WORKING_DIR}/${OUTDIRNAME}" +if $_opt_output_directory ; then + OUTDIR="${OUTDIRNAME}" +else + OUTDIR="${WORKING_DIR}/${OUTDIRNAME}" +fi + if $_opt_force ; then mkdir -p "${OUTDIR}" else @@ -150,36 +155,20 @@ exectest() { fi } -# echo a list of all disks and their size -# taken from http://cvs.debian.org/fai/lib/disk-info -diskandsize() { - local isdisk major minor blocks device suffix - while read _ _ blocks device _ ; do +# based on https://github.com/faiproject/fai/blob/master/lib/fai-disk-info +checkdisk() { + local isdisk device + while read _ _ _ device _ ; do isdisk=1 - # skip ide cdrom - [ -f "/proc/ide/${device}/media" ] && grep -q cdrom "/proc/ide/${device}/media" && isdisk=0 - [ "$isdisk" -eq 1 ] && echo "$device $blocks" - done -} - -list_disks() { - # print only every second entry; used by disk_info - i=0 - for ent in "$@" ; do - if [ "$i" -eq 0 ]; then - echo "$ent" - i=1 - else - i=0 - fi + # skip CDROMs + [ "$(stat -c %G /dev/"${device}")" = "disk" ] || isdisk=0 + [ "$isdisk" -eq 1 ] && echo "$device" done } 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) - # a list of all local disks, without size - disklist=$(list_disks "$device_size") + # the variable holds a newline separated list of devices + disklist=$(egrep ' etherd/e[[:digit:]]+\.[[:digit:]]+\b| i2o/hd.+\b| cciss/c.+d.+\b| ida/c.+d.+\b| rd/c.+d.+\b| fio.\b| hd.\b| sd[a-z]{1,2}\b|/disc\b| vd.\b| xvd.\b' /proc/partitions | checkdisk) } @@ -266,7 +255,11 @@ cd "${OUTDIR}" || exit 1 cat /proc/acpi/info > acpi_info fi - exectest acpi && acpi > ./acpi 2>acpi.error && acpi -v > ./acpi.version + if exectest acpi ; then + acpi > ./acpi 2>acpi.error + acpi --everything > ./acpi.everything 2>./acpi.everything.error + acpi -v > ./acpi.version + fi [ -r /proc/apm/ ] && apm > ./apm if exectest mcelog ; then @@ -372,7 +365,7 @@ cd "${OUTDIR}" || exit 1 if exectest hdparm ; then echo -e "hdparm -iv /dev/${disk}:\n" >> hdparm - hdparm -iv "/dev/$disk" >> ./hdparm + hdparm -iv "/dev/$disk" >> ./hdparm 2>> ./hdparm.error echo -e "\n\n" >> hdparm fi @@ -396,7 +389,7 @@ cd "${OUTDIR}" || exit 1 if exectest sg_inq ; then echo -e "sg_inq /dev/${disk}:\n" >> sg_inq - sg_inq "/dev/$disk" >> ./sg_inq + sg_inq "/dev/$disk" >> ./sg_inq 2>> ./sg_inq.error echo -e "\n\n" >> sg_inq fi