xref: /openbmc/phosphor-debug-collector/ffdc (revision 5cca05a8)
13e3f28b4SMichael Tritz#!/bin/sh
23e3f28b4SMichael Tritz
3ab741df3SJayanth Othayoth# TODO openbmc/openbmc#1622 remove -e option related changes.
4ab741df3SJayanth Othayoth
53e3f28b4SMichael Tritzhelp=$'FFDC File Collection Script
63e3f28b4SMichael Tritz
73e3f28b4SMichael TritzCollects various FFDC files and system parameters and places them in a .tar
83e3f28b4SMichael Tritz
93e3f28b4SMichael Tritzusage: ffdc [OPTION]
103e3f28b4SMichael Tritz
113e3f28b4SMichael TritzOptions:
123e3f28b4SMichael Tritz   -d, --dir <directory>  Specify destination directory. Defaults to /tmp if
133e3f28b4SMichael Tritz                          invalid or unspecified.
14ab741df3SJayanth Othayoth   -e, --enable_dump      Enable BMC Dump specific features.
153e3f28b4SMichael Tritz   -h, --help             Display this help text and exit.
163e3f28b4SMichael Tritz'
173e3f28b4SMichael Tritz
183e3f28b4SMichael Tritzdeclare -a arr=(
193e3f28b4SMichael Tritz# Commands to be outputted into individual files
203e3f28b4SMichael Tritz# Format: "File name" "Command"
213e3f28b4SMichael Tritz      "Build_info.txt"            "cat /etc/version"
223e3f28b4SMichael Tritz      "FW_level.txt"              "cat /etc/os-release"
233e3f28b4SMichael Tritz      "BMC_OS.txt"                "uname -a"
243e3f28b4SMichael Tritz      "BMC_uptime.txt"            "uptime"
253e3f28b4SMichael Tritz      "BMC_disk_usage.txt"        "df -hT"
263e3f28b4SMichael Tritz
273e3f28b4SMichael Tritz      "systemctl_status.txt"      "systemctl status | cat"
283e3f28b4SMichael Tritz      "failed_services.txt"       "systemctl --failed"
293e3f28b4SMichael Tritz      "host_console.txt"          "cat /var/log/obmc-console.log"
303e3f28b4SMichael Tritz
313e3f28b4SMichael Tritz      "BMC_proc_list.txt"         "top -n 1 -b"
323e3f28b4SMichael Tritz      "BMC_journalctl.txt"        "journalctl --no-pager"
333e3f28b4SMichael Tritz      "BMC_dmesg.txt"             "dmesg"
343e3f28b4SMichael Tritz      "BMC_procinfo.txt"          "cat /proc/cpuinfo"
353e3f28b4SMichael Tritz      "BMC_meminfo.txt"           "cat /proc/meminfo"
363e3f28b4SMichael Tritz
373e3f28b4SMichael Tritz# Copy all content from these directories into directories in the .tar
383e3f28b4SMichael Tritz# Format: "Directory name" "Directory to copy"
393e3f28b4SMichael Tritz      "obmc"                      "/var/lib/obmc/"
40*5cca05a8SJayanth Othayoth      "core"                      "/var/lib/systemd/coredump"
413e3f28b4SMichael Tritz)
423e3f28b4SMichael Tritz
433e3f28b4SMichael Tritzdir=$"ffdc_$(date +"%Y-%m-%d_%H-%M-%S")"
443e3f28b4SMichael Tritzdest="/tmp"
45ab741df3SJayanth Othayothenable_dump=false
463e3f28b4SMichael Tritz
473e3f28b4SMichael Tritzwhile [[ $# -gt 0 ]]; do
483e3f28b4SMichael Tritz  key="$1"
493e3f28b4SMichael Tritz  case $key in
503e3f28b4SMichael Tritz    -d|--dir)
51599c7afeSJayanth Othayoth      mkdir -p "$2"
52599c7afeSJayanth Othayoth      if [ $? -eq 0 ]; then
533e3f28b4SMichael Tritz        dest="$2"
543e3f28b4SMichael Tritz      else
55599c7afeSJayanth Othayoth        echo "Failed to create the destination directory specified."
563e3f28b4SMichael Tritz        break
573e3f28b4SMichael Tritz      fi
583e3f28b4SMichael Tritz      shift 2
593e3f28b4SMichael Tritz      ;;
60ab741df3SJayanth Othayoth    -e|--enable_dump)
61ab741df3SJayanth Othayoth      enable_dump=true
62ab741df3SJayanth Othayoth      shift
63ab741df3SJayanth Othayoth      ;;
643e3f28b4SMichael Tritz    -h|--help)
653e3f28b4SMichael Tritz      echo "$help"
663e3f28b4SMichael Tritz      exit
673e3f28b4SMichael Tritz      ;;
683e3f28b4SMichael Tritz    *)
693e3f28b4SMichael Tritz      echo "Unknown option $1. Display available options with -h or --help"
703e3f28b4SMichael Tritz      exit
713e3f28b4SMichael Tritz      ;;
723e3f28b4SMichael Tritz  esac
733e3f28b4SMichael Tritzdone
743e3f28b4SMichael Tritz
753e3f28b4SMichael Tritzecho "Using destination directory $dest"
763e3f28b4SMichael Tritz
77ab741df3SJayanth Othayothif [ $enable_dump = true ]; then
78ab741df3SJayanth Othayoth  id=$(basename $dest)
79ab741df3SJayanth Othayoth  printf -v f_id "%08d" $id
80ab741df3SJayanth Othayoth  dir=$"obmcdump_"$f_id"_$(date +"%s")"
81ab741df3SJayanth Othayothfi
82ab741df3SJayanth Othayoth
83a19440dcSJayanth Othayothmkdir -p "$dest/$dir"
843e3f28b4SMichael Tritz
853e3f28b4SMichael Tritzfor ((i=0;i<${#arr[@]};i+=2)); do
863e3f28b4SMichael Tritz  if [ -d "${arr[i+1]}" ]; then
873e3f28b4SMichael Tritz    echo "Copying contents of ${arr[i+1]} to directory ./${arr[i]} ..."
883e3f28b4SMichael Tritz    mkdir "$dest/$dir/${arr[i]}"
893e3f28b4SMichael Tritz    cp -r ${arr[i+1]}/* $dest/$dir/${arr[i]}
903e3f28b4SMichael Tritz  else
913e3f28b4SMichael Tritz    echo "Collecting ${arr[i]}..."
923e3f28b4SMichael Tritz    ${arr[i+1]} >> "$dest/$dir/${arr[i]}"
933e3f28b4SMichael Tritz  fi
943e3f28b4SMichael Tritzdone
953e3f28b4SMichael Tritz
96a19440dcSJayanth Othayothtar -cf "$dest/$dir.tar" -C $dest $dir
973e3f28b4SMichael Tritzecho "Contents in $dest/$dir.tar"
983e3f28b4SMichael Tritz
993e3f28b4SMichael Tritzrm -r "$dest/$dir"
100